30 builder.single_output<
float3>(
"Axis");
31 builder.single_output<
float>(
"Angle");
41 mask.foreach_index([&](
const int64_t i) {
43 axes[i] = axis_angle.
axis();
44 angles[i] = axis_angle.
angle().radian();
57 using namespace value_elem;
58 const RotationElem rotation_elem =
params.get_input_elem<RotationElem>(
"Rotation");
59 params.set_output_elem(
"Axis", rotation_elem.axis);
60 params.set_output_elem(
"Angle", rotation_elem.angle);
65 using namespace value_elem;
66 RotationElem rotation_elem;
67 rotation_elem.axis =
params.get_output_elem<VectorElem>(
"Axis");
68 rotation_elem.angle =
params.get_output_elem<FloatElem>(
"Angle");
70 rotation_elem.euler = VectorElem::all();
72 params.set_input_elem(
"Rotation", rotation_elem);
78 const float angle =
params.get_output<
float>(
"Angle");
86 params.set_input(
"Rotation", rotation);
#define NODE_CLASS_CONVERTER
#define NOD_REGISTER_NODE(REGISTER_FUNC)
void set_signature(const Signature *signature)
void set_matching_fn(const mf::MultiFunction *fn)
QuaterniontoAxisAngleFunction()
void call(const IndexMask &mask, mf::Params params, mf::Context) const override
local_group_size(16, 16) .push_constant(Type b
void node_register_type(bNodeType *ntype)
QuaternionBase< T > to_quaternion(const AxisAngleBase< T, AngleT > &axis_angle)
AxisAngleBase< T, AngleT > to_axis_angle(const EulerXYZBase< T > &euler)
MatBase< T, NumCol, NumRow > normalize(const MatBase< T, NumCol, NumRow > &a)
static void node_eval_elem(value_elem::ElemEvalParams ¶ms)
static void node_register()
static void node_build_multi_function(NodeMultiFunctionBuilder &builder)
static void node_eval_inverse(inverse_eval::InverseEvalParams ¶ms)
static void node_eval_inverse_elem(value_elem::InverseElemEvalParams ¶ms)
static void node_declare(NodeDeclarationBuilder &b)
void fn_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
NodeInverseElemEvalFunction eval_inverse_elem
NodeInverseEvalFunction eval_inverse
NodeElemEvalFunction eval_elem
NodeMultiFunctionBuildFunction build_multi_function
NodeDeclareFunction declare
const AngleT & angle() const
const vec3_type & axis() const
static QuaternionBase identity()