26 auto &count_input =
b.add_input<
decl::Int>(
"Count")
41 .description(
"Limit the maximum value of the radius in order to avoid overlapping fillets");
44 const bNode *node =
b.node_or_null();
45 if (node !=
nullptr) {
68 const bool limit_radius,
72 evaluator.add(radius_field);
79 evaluator.get_evaluated<
float>(0),
84 evaluator.add(*count_field);
88 evaluator.get_evaluated<
float>(0),
89 evaluator.get_evaluated<
int>(1),
101 const bool limit_radius,
105 for (
const int layer_index : grease_pencil.layers().index_range()) {
106 Drawing *drawing = grease_pencil.get_eval_drawing(grease_pencil.layer(layer_index));
107 if (drawing ==
nullptr) {
115 grease_pencil, AttrDomain::Curve, layer_index);
136 const bool limit_radius =
params.extract_input<
bool>(
"Limit Radius");
138 std::optional<Field<int>> count_field;
164 grease_pencil, mode, count_field, radius_field, limit_radius, attribute_filter);
168 params.set_output(
"Curve", std::move(geometry_set));
178 "Align Bézier handles to create circular arcs at each control point"},
183 "Add control points along a circular arc (handle type is vector if Bézier Spline)"},
184 {0,
nullptr, 0,
nullptr,
nullptr},
190 "How to choose number of vertices on fillet",
Low-level operations for grease pencil.
#define NODE_STORAGE_FUNCS(StorageT)
#define NODE_CLASS_GEOMETRY
GeometryNodeCurveFilletMode
@ GEO_NODE_CURVE_FILLET_BEZIER
@ GEO_NODE_CURVE_FILLET_POLY
#define NOD_REGISTER_NODE(REGISTER_FUNC)
#define NOD_storage_enum_accessors(member)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
IndexRange curves_range() const
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
void tag_topology_changed()
void make_available(bNode &node) const
local_group_size(16, 16) .push_constant(Type b
void curves_copy_parameters(const Curves &src, Curves &dst)
void node_type_storage(bNodeType *ntype, const char *storagename, void(*freefunc)(bNode *node), void(*copyfunc)(bNodeTree *dest_ntree, bNode *dest_node, const bNode *src_node))
void node_register_type(bNodeType *ntype)
Curves * curves_new_nomain(int points_num, int curves_num)
bke::CurvesGeometry fillet_curves_bezier(const bke::CurvesGeometry &src_curves, const IndexMask &curve_selection, const VArray< float > &radius, bool limit_radius, const bke::AttributeFilter &attribute_filter)
bke::CurvesGeometry fillet_curves_poly(const bke::CurvesGeometry &src_curves, const IndexMask &curve_selection, const VArray< float > &radius, const VArray< int > &counts, bool limit_radius, const bke::AttributeFilter &attribute_filter)
static void node_init(bNodeTree *, bNode *node)
static void node_rna(StructRNA *srna)
static bke::CurvesGeometry fillet_curve(const bke::CurvesGeometry &src_curves, const GeometryNodeCurveFilletMode mode, const fn::FieldContext &field_context, const std::optional< Field< int > > &count_field, const Field< float > &radius_field, const bool limit_radius, const AttributeFilter &attribute_filter)
static void node_geo_exec(GeoNodeExecParams params)
static void node_declare(NodeDeclarationBuilder &b)
static void node_layout(uiLayout *layout, bContext *, PointerRNA *ptr)
static void node_register()
static void fillet_grease_pencil(GreasePencil &grease_pencil, const GeometryNodeCurveFilletMode mode, const std::optional< Field< int > > &count_field, const Field< float > &radius_field, const bool limit_radius, const AttributeFilter &attribute_filter)
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, int type, const char *name, short nclass)
void node_free_standard_storage(bNode *node)
void node_copy_standard_storage(bNodeTree *, bNode *dest_node, const bNode *src_node)
const Curves * get_curves() const
bool has_grease_pencil() const
void replace_curves(Curves *curves, GeometryOwnershipType ownership=GeometryOwnershipType::Owned)
void modify_geometry_sets(ForeachSubGeometryCallback callback)
GreasePencil * get_grease_pencil_for_write()
void(* initfunc)(bNodeTree *ntree, bNode *node)
NodeGeometryExecFunction geometry_node_execute
void(* draw_buttons)(uiLayout *, bContext *C, PointerRNA *ptr)
NodeDeclareFunction declare