22 b.add_input<
decl::Bool>(
"Local Space").default_value(
true).field_on_all();
36 const IndexMask selection = evaluator.get_evaluated_selection_as_mask();
39 const VArray<bool> local_spaces = evaluator.get_evaluated<
bool>(2);
44 const float3 pivot = pivots[i];
45 float4x4 &instance_transform = transforms[i];
47 if (local_spaces[i]) {
49 rescale_m4(instance_transform.ptr(), scales[i]);
53 const float4x4 original_transform = instance_transform;
55 rescale_m4(instance_transform.ptr(), scales[i]);
57 instance_transform *= original_transform;
68 params.set_output(
"Instances", std::move(geometry_set));
#define NODE_CLASS_GEOMETRY
void rescale_m4(float mat[4][4], const float scale[3])
#define NOD_REGISTER_NODE(REGISTER_FUNC)
void set_selection(Field< bool > selection)
local_group_size(16, 16) .push_constant(Type b
void node_register_type(bNodeType *ntype)
MatT from_location(const typename MatT::loc_type &location)
static void scale_instances(GeoNodeExecParams ¶ms, bke::Instances &instances)
static void node_geo_exec(GeoNodeExecParams params)
static void node_register()
static void node_declare(NodeDeclarationBuilder &b)
void geo_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
Instances * get_instances_for_write()
NodeGeometryExecFunction geometry_node_execute
NodeDeclareFunction declare