Blender V5.0
node_geo_edge_split.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
9
10#include "node_geometry_util.hh"
11
13
15{
16 b.use_custom_socket_order();
17 b.allow_any_socket_order();
18 b.add_input<decl::Geometry>("Mesh")
19 .supported_type(GeometryComponent::Type::Mesh)
20 .description("Mesh whose edges to split");
21 b.add_output<decl::Geometry>("Mesh").propagate_all().align_with_previous();
22 b.add_input<decl::Bool>("Selection").default_value(true).hide_value().field_on_all();
23}
24
26{
27 GeometrySet geometry_set = params.extract_input<GeometrySet>("Mesh");
28
29 const Field<bool> selection_field = params.extract_input<Field<bool>>("Selection");
30
31 geometry::foreach_real_geometry(geometry_set, [&](GeometrySet &geometry_set) {
32 if (const Mesh *mesh = geometry_set.get_mesh()) {
33 const bke::MeshFieldContext field_context{*mesh, AttrDomain::Edge};
34 fn::FieldEvaluator selection_evaluator{field_context, mesh->edges_num};
35 selection_evaluator.set_selection(selection_field);
36 selection_evaluator.evaluate();
37 const IndexMask mask = selection_evaluator.get_evaluated_selection_as_mask();
38 if (mask.is_empty()) {
39 return;
40 }
41
43 *geometry_set.get_mesh_for_write(), mask, params.get_attribute_filter("Mesh"));
44 }
45 });
46
47 params.set_output("Mesh", std::move(geometry_set));
48}
49
50static void node_register()
51{
52 static blender::bke::bNodeType ntype;
53
54 geo_node_type_base(&ntype, "GeometryNodeSplitEdges", GEO_NODE_SPLIT_EDGES);
55 ntype.ui_name = "Split Edges";
56 ntype.ui_description = "Duplicate mesh edges and break connections with the surrounding faces";
57 ntype.enum_name_legacy = "SPLIT_EDGES";
60 ntype.declare = node_declare;
62}
64
65} // namespace blender::nodes::node_geo_edge_split_cc
#define NODE_CLASS_GEOMETRY
Definition BKE_node.hh:461
#define GEO_NODE_SPLIT_EDGES
#define NOD_REGISTER_NODE(REGISTER_FUNC)
void set_selection(Field< bool > selection)
Definition FN_field.hh:383
IndexMask get_evaluated_selection_as_mask() const
Definition field.cc:817
uiWidgetBaseParameters params[MAX_WIDGET_BASE_BATCH]
ccl_device_inline float2 mask(const MaskType mask, const float2 a)
void node_register_type(bNodeType &ntype)
Definition node.cc:2416
void foreach_real_geometry(bke::GeometrySet &geometry, FunctionRef< void(bke::GeometrySet &geometry_set)> fn)
void split_edges(Mesh &mesh, const IndexMask &selected_edges, 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, std::string idname, const std::optional< int16_t > legacy_type)
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
NodeDeclareFunction declare
Definition BKE_node.hh:362