polygonjs-engine
Version:
node-based webgl 3D engine https://polygonjs.com
59 lines (52 loc) • 1.72 kB
text/typescript
import {Number3} from '../../../types/GlobalTypes';
import {BaseNodeGlMathFunctionArg2GlNode} from './_BaseMathFunction';
import Quaternion from './gl/quaternion.glsl';
import {GlConnectionPointType} from '../utils/io/connections/Gl';
import {FunctionGLDefinition} from './utils/GLDefinition';
enum InputName {
AXIS = 'axis',
ANGLE = 'angle',
}
const InputNames: Array<InputName> = [InputName.AXIS, InputName.ANGLE];
interface IDefaultValues {
[InputName.AXIS]: Number3;
[InputName.ANGLE]: number;
}
const DEFAULT_AXIS: Number3 = [0, 0, 1];
const DEFAULT_ANGLE: number = 0;
const DefaultValues: IDefaultValues = {
[InputName.AXIS]: DEFAULT_AXIS,
[InputName.ANGLE]: DEFAULT_ANGLE,
};
export class QuatFromAxisAngleGlNode extends BaseNodeGlMathFunctionArg2GlNode {
static type() {
return 'quatFromAxisAngle';
}
initializeNode() {
super.initializeNode();
this.io.connection_points.set_input_name_function((index: number) => InputNames[index]);
this.io.connection_points.set_expected_input_types_function(() => [
GlConnectionPointType.VEC3,
GlConnectionPointType.FLOAT,
]);
this.io.connection_points.set_expected_output_types_function(() => [GlConnectionPointType.VEC4]);
}
// protected _gl_input_name(index: number) {
// return InputNames[index];
// }
param_default_value(name: string) {
return DefaultValues[name as InputName];
}
gl_method_name(): string {
return 'quatFromAxisAngle';
}
// protected _expected_input_types() {
// return [ConnectionPointType.VEC3, ConnectionPointType.FLOAT];
// }
// protected expected_output_types() {
// return [ConnectionPointType.VEC4];
// }
gl_function_definitions() {
return [new FunctionGLDefinition(this, Quaternion)];
}
}