blanchon's picture
Update
6ce4ca6
export function xyzFromString(child: Element): [x: number, y: number, z: number] | undefined {
const arr = numberStringToArray(child, "xyz");
if (!arr || arr.length != 3) {
return;
}
return arr as [x: number, y: number, z: number];
}
export function rpyFromString(
child: Element
): [roll: number, pitch: number, yaw: number] | undefined {
const arr = numberStringToArray(child, "rpy");
if (!arr || arr.length != 3) {
return;
}
return arr as [roll: number, pitch: number, yaw: number];
}
export function rgbaFromString(
child: Element
): [r: number, g: number, b: number, a: number] | undefined {
const arr = numberStringToArray(child, "rgba");
if (!arr || arr.length != 4) {
return;
}
return arr as [r: number, g: number, b: number, a: number];
}
export function numberStringToArray(child: Element, name: string = "xyz"): number[] | undefined {
// parse a list of values from a string
// (like "1.0 2.2 3.0" into an array like [1, 2.2, 3])
// used in URDF for position, orientation an color values
if (child.hasAttribute(name)) {
const xyzStr = child.getAttribute(name)?.split(" ");
if (xyzStr) {
const arr = [];
for (const nr of xyzStr) {
arr.push(parseFloat(nr));
}
return arr;
}
}
}
export function radToEuler(rad: number): number {
return (rad * 180) / Math.PI;
}
export function numberArrayToColor([r, g, b]: [number, number, number]): string {
const toHex = (n: number) => Math.round(n).toString(16).padStart(2, "0");
// 0.06, 0.4, 0.1, 1
return `#${toHex(r * 255)}${toHex(g * 255)}${toHex(b * 255)}`;
}