24 static auto fn = mf::build::SI2_SO<float4x4, float4x4, float4x4>(
32 params.set_output_elem(
"Matrix", MatrixElem::all());
38 const MatrixElem first_input_elem = MatrixElem::all();
39 params.set_input_elem(
"Matrix", first_input_elem);
47 params.set_input(
"Matrix", first_input);
54 ntype.
ui_name =
"Multiply Matrices";
55 ntype.
ui_description =
"Perform a matrix multiplication on two input matrices";
#define NODE_CLASS_CONVERTER
#define FN_NODE_MATRIX_MULTIPLY
#define NOD_REGISTER_NODE(REGISTER_FUNC)
void set_matching_fn(const mf::MultiFunction *fn)
void node_register_type(bNodeType &ntype)
CartesianBasis invert(const CartesianBasis &basis)
static void node_eval_inverse(inverse_eval::InverseEvalParams ¶ms)
static void node_build_multi_function(NodeMultiFunctionBuilder &builder)
static void node_register()
static void node_eval_inverse_elem(value_elem::InverseElemEvalParams ¶ms)
static void node_declare(NodeDeclarationBuilder &b)
static void node_eval_elem(value_elem::ElemEvalParams ¶ms)
MatBase< float, 4, 4 > float4x4
void fn_node_type_base(blender::bke::bNodeType *ntype, std::string idname, const std::optional< int16_t > legacy_type)
NodeInverseElemEvalFunction eval_inverse_elem
NodeInverseEvalFunction eval_inverse
std::string ui_description
NodeElemEvalFunction eval_elem
NodeMultiFunctionBuildFunction build_multi_function
const char * enum_name_legacy
NodeDeclareFunction declare