Blender V4.3
node_geo_curve_reverse.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 "BLI_task.hh"
6
7#include "BKE_curves.hh"
9
10#include "node_geometry_util.hh"
11
13
15{
16 b.add_input<decl::Geometry>("Curve").supported_type(
18 b.add_input<decl::Bool>("Selection").default_value(true).hide_value().field_on_all();
19 b.add_output<decl::Geometry>("Curve").propagate_all();
20}
21
23 const fn::FieldContext &field_context,
24 const Field<bool> &selection_field)
25{
26 fn::FieldEvaluator selection_evaluator{field_context, curves.curves_num()};
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()) {
31 return;
32 }
33 curves.reverse_curves(selection);
34}
35
36static void reverse_grease_pencil(GreasePencil &grease_pencil, const Field<bool> &selection_field)
37{
38 using namespace blender::bke::greasepencil;
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) {
42 continue;
43 }
44 bke::CurvesGeometry &curves = drawing->strokes_for_write();
45 const bke::GreasePencilLayerFieldContext field_context(
46 grease_pencil, AttrDomain::Curve, layer_index);
47 reverse_curve(curves, field_context, selection_field);
48 drawing->tag_topology_changed();
49 }
50}
51
53{
54 GeometrySet geometry_set = params.extract_input<GeometrySet>("Curve");
55 Field<bool> selection_field = params.extract_input<Field<bool>>("Selection");
56
58
59 geometry_set.modify_geometry_sets([&](GeometrySet &geometry_set) {
60 if (Curves *curves_id = geometry_set.get_curves_for_write()) {
61 bke::CurvesGeometry &curves = curves_id->geometry.wrap();
62 const bke::CurvesFieldContext field_context{*curves_id, AttrDomain::Curve};
63 reverse_curve(curves, field_context, selection_field);
64 }
65 if (GreasePencil *grease_pencil = geometry_set.get_grease_pencil_for_write()) {
66 reverse_grease_pencil(*grease_pencil, selection_field);
67 }
68 });
69
70 params.set_output("Curve", std::move(geometry_set));
71}
72
73static void node_register()
74{
75 static blender::bke::bNodeType ntype;
76 geo_node_type_base(&ntype, GEO_NODE_REVERSE_CURVE, "Reverse Curve", NODE_CLASS_GEOMETRY);
77 ntype.declare = node_declare;
80}
81NOD_REGISTER_NODE(node_register)
82
83} // namespace blender::nodes::node_geo_curve_reverse_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)
static void remember_deformed_positions_if_necessary(GeometrySet &geometry)
bke::CurvesGeometry & strokes_for_write()
local_group_size(16, 16) .push_constant(Type b
uiWidgetBaseParameters params[MAX_WIDGET_BASE_BATCH]
void node_register_type(bNodeType *ntype)
Definition node.cc:1708
static void node_declare(NodeDeclarationBuilder &b)
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)
void modify_geometry_sets(ForeachSubGeometryCallback callback)
GreasePencil * get_grease_pencil_for_write()
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