Blender V4.3
node_geo_curve_subdivide.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2023 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
5#include "BKE_curves.hh"
7
9
10#include "UI_resources.hh"
11
12#include "node_geometry_util.hh"
13
15
17{
18 b.add_input<decl::Geometry>("Curve").supported_type(
20 b.add_input<decl::Int>("Cuts").default_value(1).min(0).max(1000).field_on_all().description(
21 "The number of control points to create on the segment following each point");
22 b.add_output<decl::Geometry>("Curve").propagate_all();
23}
24
25static Curves *subdivide_curves(const Curves &src_curves_id,
26 Field<int> &cuts_field,
27 const bke::AttributeFilter &attribute_filter)
28{
29 const bke::CurvesGeometry &src_curves = src_curves_id.geometry.wrap();
30
31 const bke::CurvesFieldContext field_context{src_curves_id, AttrDomain::Point};
32 fn::FieldEvaluator evaluator{field_context, src_curves.points_num()};
33 evaluator.add(cuts_field);
34 evaluator.evaluate();
35 const VArray<int> cuts = evaluator.get_evaluated<int>(0);
36
37 if (cuts.is_single() && cuts.get_internal_single() < 1) {
38 return nullptr;
39 }
40
42 src_curves, src_curves.curves_range(), cuts, attribute_filter);
43
44 Curves *dst_curves_id = bke::curves_new_nomain(std::move(dst_curves));
45 bke::curves_copy_parameters(src_curves_id, *dst_curves_id);
46 return dst_curves_id;
47}
48
50 Field<int> &cuts_field,
51 const AttributeFilter &attribute_filter)
52{
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));
56
57 if (drawing == nullptr) {
58 continue;
59 }
60
61 const bke::CurvesGeometry &src_curves = drawing->strokes();
62 const bke::GreasePencilLayerFieldContext field_context{
63 grease_pencil, AttrDomain::Point, layer_index};
64
65 fn::FieldEvaluator evaluator{field_context, src_curves.points_num()};
66 evaluator.add(cuts_field);
67 evaluator.evaluate();
68 const VArray<int> cuts = evaluator.get_evaluated<int>(0);
69
70 if (cuts.is_single() && cuts.get_internal_single() < 1) {
71 continue;
72 }
73
75 src_curves, src_curves.curves_range(), cuts, attribute_filter);
76
77 drawing->strokes_for_write() = std::move(dst_curves);
78 drawing->tag_topology_changed();
79 }
80}
81
83{
84 GeometrySet geometry_set = params.extract_input<GeometrySet>("Curve");
85 Field<int> cuts_field = params.extract_input<Field<int>>("Cuts");
86
88 const NodeAttributeFilter &attribute_filter = params.get_attribute_filter("Curve");
89
90 geometry_set.modify_geometry_sets([&](GeometrySet &geometry_set) {
91 if (geometry_set.has_curves()) {
92 const Curves &src_curves_id = *geometry_set.get_curves();
93 Curves *dst_curves_id = subdivide_curves(src_curves_id, cuts_field, attribute_filter);
94 if (dst_curves_id) {
95 geometry_set.replace_curves(dst_curves_id);
96 }
97 }
98 if (geometry_set.has_grease_pencil()) {
99 GreasePencil &grease_pencil = *geometry_set.get_grease_pencil_for_write();
100 subdivide_grease_pencil_curves(grease_pencil, cuts_field, attribute_filter);
101 }
102 });
103 params.set_output("Curve", geometry_set);
104}
105
106static void node_register()
107{
108 static blender::bke::bNodeType ntype;
109
110 geo_node_type_base(&ntype, GEO_NODE_SUBDIVIDE_CURVE, "Subdivide Curve", NODE_CLASS_GEOMETRY);
111 ntype.declare = node_declare;
114}
115NOD_REGISTER_NODE(node_register)
116
117} // namespace blender::nodes::node_geo_curve_subdivide_cc
Low-level operations for curves.
Low-level operations for grease pencil.
#define NODE_CLASS_GEOMETRY
Definition BKE_node.hh:418
#define NOD_REGISTER_NODE(REGISTER_FUNC)
IndexRange curves_range() const
static void remember_deformed_positions_if_necessary(GeometrySet &geometry)
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
local_group_size(16, 16) .push_constant(Type b
uiWidgetBaseParameters params[MAX_WIDGET_BASE_BATCH]
void curves_copy_parameters(const Curves &src, Curves &dst)
void node_register_type(bNodeType *ntype)
Definition node.cc:1708
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_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)
CurvesGeometry geometry
void modify_geometry_sets(ForeachSubGeometryCallback callback)
Defines a node type.
Definition BKE_node.hh:218
NodeGeometryExecFunction geometry_node_execute
Definition BKE_node.hh:339
NodeDeclareFunction declare
Definition BKE_node.hh:347