21 "The number of control points to create on the segment following each point");
33 evaluator.add(cuts_field);
35 const VArray<int> cuts = evaluator.get_evaluated<
int>(0);
42 src_curves, src_curves.
curves_range(), cuts, attribute_filter);
53 using namespace bke::greasepencil;
54 for (
const int layer_index : grease_pencil.layers().index_range()) {
55 Drawing *drawing = grease_pencil.get_eval_drawing(grease_pencil.layer(layer_index));
57 if (drawing ==
nullptr) {
63 grease_pencil, AttrDomain::Point, layer_index};
66 evaluator.add(cuts_field);
68 const VArray<int> cuts = evaluator.get_evaluated<
int>(0);
75 src_curves, src_curves.
curves_range(), cuts, attribute_filter);
92 const Curves &src_curves_id = *geometry_set.get_curves();
93 Curves *dst_curves_id = subdivide_curves(src_curves_id, cuts_field, attribute_filter);
95 geometry_set.replace_curves(dst_curves_id);
99 GreasePencil &grease_pencil = *geometry_set.get_grease_pencil_for_write();
100 subdivide_grease_pencil_curves(grease_pencil, cuts_field, attribute_filter);
103 params.set_output(
"Curve", geometry_set);
Low-level operations for curves.
Low-level operations for grease pencil.
#define NODE_CLASS_GEOMETRY
#define NOD_REGISTER_NODE(REGISTER_FUNC)
T get_internal_single() const
IndexRange curves_range() const
static void remember_deformed_positions_if_necessary(GeometrySet &geometry)
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
void tag_topology_changed()
local_group_size(16, 16) .push_constant(Type b
void curves_copy_parameters(const Curves &src, Curves &dst)
void node_register_type(bNodeType *ntype)
Curves * curves_new_nomain(int points_num, int curves_num)
bke::CurvesGeometry subdivide_curves(const bke::CurvesGeometry &src_curves, const IndexMask &selection, const VArray< int > &cuts, const bke::AttributeFilter &attribute_filter={})
static void node_register()
static void node_declare(NodeDeclarationBuilder &b)
static void node_geo_exec(GeoNodeExecParams params)
static void subdivide_grease_pencil_curves(GreasePencil &grease_pencil, Field< int > &cuts_field, const AttributeFilter &attribute_filter)
static Curves * subdivide_curves(const Curves &src_curves_id, Field< int > &cuts_field, const bke::AttributeFilter &attribute_filter)
void geo_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
bool has_grease_pencil() const
void modify_geometry_sets(ForeachSubGeometryCallback callback)
NodeGeometryExecFunction geometry_node_execute
NodeDeclareFunction declare