Blender V4.3
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
8
10
12
14{
15 b.add_input<decl::Geometry>("Mesh").supported_type(GeometryComponent::Type::Mesh);
16 b.add_input<decl::Bool>("Selection").default_value(true).hide_value().field_on_all();
17 b.add_output<decl::Geometry>("Curve").propagate_all();
18}
19
21{
22 GeometrySet geometry_set = params.extract_input<GeometrySet>("Mesh");
23
24 geometry_set.modify_geometry_sets([&](GeometrySet &geometry_set) {
25 const Mesh *mesh = geometry_set.get_mesh();
26 if (mesh == nullptr) {
27 geometry_set.remove_geometry_during_modify();
28 return;
29 }
30
31 const bke::MeshFieldContext context{*mesh, AttrDomain::Edge};
32 fn::FieldEvaluator evaluator{context, mesh->edges_num};
33 evaluator.add(params.get_input<Field<bool>>("Selection"));
34 evaluator.evaluate();
35 const IndexMask selection = evaluator.get_evaluated_as_mask(0);
36 if (selection.is_empty()) {
37 geometry_set.remove_geometry_during_modify();
38 return;
39 }
40
42 *mesh, selection, params.get_attribute_filter("Curve"));
43 geometry_set.replace_curves(bke::curves_new_nomain(std::move(curves)));
45 });
46
47 params.set_output("Curve", std::move(geometry_set));
48}
49
50static void node_register()
51{
52 static blender::bke::bNodeType ntype;
53
54 geo_node_type_base(&ntype, GEO_NODE_MESH_TO_CURVE, "Mesh to Curve", NODE_CLASS_GEOMETRY);
55 ntype.declare = node_declare;
58}
60
61} // namespace blender::nodes::node_geo_mesh_to_curve_cc
#define NODE_CLASS_GEOMETRY
Definition BKE_node.hh:418
#define NOD_REGISTER_NODE(REGISTER_FUNC)
int add(GField field, GVArray *varray_ptr)
Definition field.cc:756
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
Curves * curves_new_nomain(int points_num, int curves_num)
bke::CurvesGeometry mesh_to_curve_convert(const Mesh &mesh, const IndexMask &selection, const bke::AttributeFilter &attribute_filter)
static void node_geo_exec(GeoNodeExecParams params)
static void node_declare(NodeDeclarationBuilder &b)
void geo_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
void keep_only_during_modify(Span< GeometryComponent::Type > component_types)
void replace_curves(Curves *curves, GeometryOwnershipType ownership=GeometryOwnershipType::Owned)
const Mesh * get_mesh() const
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