Blender V5.0
node_geo_mesh_to_curve.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 "DNA_mesh_types.h"
6
7#include "NOD_rna_define.hh"
8
10#include "GEO_mesh_to_curve.hh"
11
12#include "UI_interface_c.hh"
14
15#include "node_geometry_util.hh"
16
18
19enum class Mode : int8_t {
20 Edges = 0,
21 Faces = 1,
22};
23
25{
26 b.add_input<decl::Geometry>("Mesh")
27 .supported_type(GeometryComponent::Type::Mesh)
28 .description("Mesh to convert to curves");
29 b.add_input<decl::Bool>("Selection").default_value(true).hide_value().field_on_all();
30 b.add_output<decl::Geometry>("Curve").propagate_all();
31}
32
33static void node_layout(uiLayout *layout, bContext * /*C*/, PointerRNA *ptr)
34{
35 layout->prop(ptr, "mode", UI_ITEM_R_EXPAND, std::nullopt, 0);
36}
37
39{
40 const Mode mode = Mode(params.node().custom1);
41 GeometrySet geometry_set = params.extract_input<GeometrySet>("Mesh");
42
43 geometry::foreach_real_geometry(geometry_set, [&](GeometrySet &geometry_set) {
44 const Mesh *mesh = geometry_set.get_mesh();
45 if (mesh == nullptr) {
46 geometry_set.keep_only({GeometryComponent::Type::Edit});
47 return;
48 }
49
50 switch (mode) {
51 case Mode::Edges: {
52 const bke::MeshFieldContext context{*mesh, AttrDomain::Edge};
53 fn::FieldEvaluator evaluator{context, mesh->edges_num};
54 evaluator.add(params.get_input<Field<bool>>("Selection"));
55 evaluator.evaluate();
56 const IndexMask selection = evaluator.get_evaluated_as_mask(0);
57 if (selection.is_empty()) {
58 geometry_set.keep_only({GeometryComponent::Type::Edit});
59 return;
60 }
61
63 *mesh, selection, params.get_attribute_filter("Curve"));
64 geometry_set.replace_curves(bke::curves_new_nomain(std::move(curves)));
65 break;
66 }
67 case Mode::Faces: {
68 const bke::MeshFieldContext context{*mesh, AttrDomain::Face};
69 fn::FieldEvaluator evaluator{context, mesh->faces_num};
70 evaluator.add(params.get_input<Field<bool>>("Selection"));
71 evaluator.evaluate();
72 const IndexMask selection = evaluator.get_evaluated_as_mask(0);
73 if (selection.is_empty()) {
74 geometry_set.keep_only({GeometryComponent::Type::Edit});
75 return;
76 }
77
79 *mesh, selection, params.get_attribute_filter("Curve"));
80 geometry_set.replace_curves(bke::curves_new_nomain(std::move(curves)));
81 break;
82 }
83 }
84 geometry_set.keep_only({GeometryComponent::Type::Curve, GeometryComponent::Type::Edit});
85 });
86
87 params.set_output("Curve", std::move(geometry_set));
88}
89
90static void node_rna(StructRNA *srna)
91{
92 static const EnumPropertyItem mode_items[] = {
93 {int(Mode::Edges),
94 "EDGES",
95 0,
96 "Edges",
97 "Convert mesh edges to curve segments. Attributes are propagated to curve points."},
98 {int(Mode::Faces),
99 "FACES",
100 0,
101 "Faces",
102 "Convert each mesh face to a cyclic curve. Face attributes are propagated to curves."},
103 {0, nullptr, 0, nullptr, nullptr},
104 };
105
107 srna, "mode", "Mode", "", mode_items, NOD_inline_enum_accessors(custom1), int(Mode::Edges));
108}
109
110static void node_register()
111{
112 static blender::bke::bNodeType ntype;
113
114 geo_node_type_base(&ntype, "GeometryNodeMeshToCurve", GEO_NODE_MESH_TO_CURVE);
115 ntype.ui_name = "Mesh to Curve";
116 ntype.ui_description = "Generate a curve from a mesh";
117 ntype.enum_name_legacy = "MESH_TO_CURVE";
119 ntype.declare = node_declare;
123 node_rna(ntype.rna_ext.srna);
124}
126
127} // namespace blender::nodes::node_geo_mesh_to_curve_cc
#define NODE_CLASS_GEOMETRY
Definition BKE_node.hh:461
#define GEO_NODE_MESH_TO_CURVE
#define NOD_REGISTER_NODE(REGISTER_FUNC)
#define NOD_inline_enum_accessors(member)
@ UI_ITEM_R_EXPAND
int add(GField field, GVArray *varray_ptr)
Definition field.cc:751
IndexMask get_evaluated_as_mask(int field_index)
Definition field.cc:804
uiWidgetBaseParameters params[MAX_WIDGET_BASE_BATCH]
void node_register_type(bNodeType &ntype)
Definition node.cc:2416
Curves * curves_new_nomain(int points_num, int curves_num)
void foreach_real_geometry(bke::GeometrySet &geometry, FunctionRef< void(bke::GeometrySet &geometry_set)> fn)
bke::CurvesGeometry mesh_edges_to_curves_convert(const Mesh &mesh, const IndexMask &selection, const bke::AttributeFilter &attribute_filter)
bke::CurvesGeometry mesh_faces_to_curves_convert(const Mesh &mesh, const IndexMask &selection, const bke::AttributeFilter &attribute_filter)
static void node_layout(uiLayout *layout, bContext *, PointerRNA *ptr)
static void node_geo_exec(GeoNodeExecParams params)
static void node_declare(NodeDeclarationBuilder &b)
PropertyRNA * RNA_def_node_enum(StructRNA *srna, const char *identifier, const char *ui_name, const char *ui_description, const EnumPropertyItem *static_items, const EnumRNAAccessors accessors, std::optional< int > default_value, const EnumPropertyItemFunc item_func, const bool allow_animation)
void geo_node_type_base(blender::bke::bNodeType *ntype, std::string idname, const std::optional< int16_t > legacy_type)
StructRNA * srna
int edges_num
int faces_num
void keep_only(Span< GeometryComponent::Type > component_types)
void replace_curves(Curves *curves, GeometryOwnershipType ownership=GeometryOwnershipType::Owned)
const Mesh * get_mesh() const
Defines a node type.
Definition BKE_node.hh:238
std::string ui_description
Definition BKE_node.hh:244
NodeGeometryExecFunction geometry_node_execute
Definition BKE_node.hh:354
const char * enum_name_legacy
Definition BKE_node.hh:247
void(* draw_buttons)(uiLayout *, bContext *C, PointerRNA *ptr)
Definition BKE_node.hh:259
NodeDeclareFunction declare
Definition BKE_node.hh:362
void prop(PointerRNA *ptr, PropertyRNA *prop, int index, int value, eUI_Item_Flag flag, std::optional< blender::StringRef > name_opt, int icon, std::optional< blender::StringRef > placeholder=std::nullopt)
PointerRNA * ptr
Definition wm_files.cc:4238