27 selection_evaluator.add(selection_field);
28 selection_evaluator.evaluate();
29 const IndexMask selection = selection_evaluator.get_evaluated_as_mask(0);
30 if (selection.is_empty()) {
33 curves.reverse_curves(selection);
39 for (
const int layer_index : grease_pencil.layers().index_range()) {
40 Drawing *drawing = grease_pencil.get_eval_drawing(grease_pencil.layer(layer_index));
41 if (drawing ==
nullptr) {
46 grease_pencil, AttrDomain::Curve, layer_index);
61 bke::CurvesGeometry &curves = curves_id->geometry.wrap();
62 const bke::CurvesFieldContext field_context{*curves_id, AttrDomain::Curve};
70 params.set_output(
"Curve", std::move(geometry_set));
Low-level operations for curves.
Low-level operations for grease pencil.
#define NODE_CLASS_GEOMETRY
#define NOD_REGISTER_NODE(REGISTER_FUNC)
static void remember_deformed_positions_if_necessary(GeometrySet &geometry)
bke::CurvesGeometry & strokes_for_write()
void tag_topology_changed()
local_group_size(16, 16) .push_constant(Type b
void node_register_type(bNodeType *ntype)
static void node_declare(NodeDeclarationBuilder &b)
static void node_register()
static void reverse_grease_pencil(GreasePencil &grease_pencil, const Field< bool > &selection_field)
static void node_geo_exec(GeoNodeExecParams params)
static void reverse_curve(bke::CurvesGeometry &curves, const fn::FieldContext &field_context, const Field< bool > &selection_field)
void geo_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
Curves * get_curves_for_write()
void modify_geometry_sets(ForeachSubGeometryCallback callback)
GreasePencil * get_grease_pencil_for_write()
NodeGeometryExecFunction geometry_node_execute
NodeDeclareFunction declare