Blender V4.3
BKE_curve.hh
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2001-2002 NaN Holding BV. All rights reserved.
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
5#pragma once
6
11#include <optional>
12
13#include "BLI_bounds_types.hh"
15#include "BLI_sys_types.h"
16
17#include "DNA_listBase.h"
18
19struct BezTriple;
20struct BezTriple;
21struct BMEditMesh;
22struct BPoint;
23struct Curve;
24struct Depsgraph;
25struct GHash;
26struct ListBase;
27struct Main;
28struct MDeformVert;
29struct Nurb;
30struct Object;
31struct rctf;
32struct TextBox;
33
35
36struct CurveCache {
40 /* This array contains the accumulative length of the curve segments.
41 * So you can see this as a "total distance traveled" along the curve.
42 * The first entry is the length between point 0 and 1 while the last is the
43 * total length of the curve.
44 *
45 * Used by #BKE_where_on_path. */
47};
48
49/* Definitions needed for shape keys */
55
70
71#define KNOTSU(nu) \
72 ((nu)->orderu + (nu)->pntsu + (((nu)->flagu & CU_NURB_CYCLIC) ? ((nu)->orderu - 1) : 0))
73#define KNOTSV(nu) \
74 ((nu)->orderv + (nu)->pntsv + (((nu)->flagv & CU_NURB_CYCLIC) ? ((nu)->orderv - 1) : 0))
75
76/* Non cyclic nurbs have 1 less segment */
77#define SEGMENTSU(nu) (((nu)->flagu & CU_NURB_CYCLIC) ? (nu)->pntsu : (nu)->pntsu - 1)
78#define SEGMENTSV(nu) (((nu)->flagv & CU_NURB_CYCLIC) ? (nu)->pntsv : (nu)->pntsv - 1)
79
80#define CU_DO_RADIUS(cu, nu) \
81 ((((cu)->flag & (CU_PATH_RADIUS | CU_3D)) || (cu)->bevobj || (cu)->extrude != 0.0f || \
82 (cu)->bevel_radius != 0.0f) ? \
83 1 : \
84 0)
85
86#define CU_IS_2D(cu) (((cu)->flag & CU_3D) == 0)
87
88/* not 3d and not unfilled */
89#define CU_DO_2DFILL(cu) (CU_IS_2D(cu) && (((cu)->flag & (CU_FRONT | CU_BACK)) != 0))
90
91/* ** Curve ** */
96void BKE_curve_init(Curve *cu, short curve_type);
97Curve *BKE_curve_add(Main *bmain, const char *name, int type);
98short BKE_curve_type_get(const Curve *cu);
101
104
105/* Basic vertex data functions. */
106
107std::optional<blender::Bounds<blender::float3>> BKE_curve_minmax(const Curve *cu, bool use_radius);
108bool BKE_curve_center_median(Curve *cu, float cent[3]);
110 Curve *cu, const float mat[4][4], bool do_keys, bool do_props, float unit_scale);
111void BKE_curve_transform(Curve *cu, const float mat[4][4], bool do_keys, bool do_props);
112void BKE_curve_translate(Curve *cu, const float offset[3], bool do_keys);
113void BKE_curve_material_index_remove(Curve *cu, int index);
114bool BKE_curve_material_index_used(const Curve *cu, int index);
117void BKE_curve_material_remap(Curve *cu, const unsigned int *remap, unsigned int remap_len);
118
119void BKE_curve_smooth_flag_set(Curve *cu, bool use_smooth);
120
126
127int BKE_curve_nurb_vert_index_get(const Nurb *nu, const void *vert);
128void BKE_curve_nurb_active_set(Curve *cu, const Nurb *nu);
137void BKE_curve_nurb_vert_active_set(Curve *cu, const Nurb *nu, const void *vert);
141bool BKE_curve_nurb_vert_active_get(Curve *cu, Nurb **r_nu, void **r_vert);
143
144float (*BKE_curve_nurbs_vert_coords_alloc(const ListBase *lb, int *r_vert_len))[3];
145void BKE_curve_nurbs_vert_coords_get(const ListBase *lb, float (*vert_coords)[3], int vert_len);
146
148 const float (*vert_coords)[3],
149 const float mat[4][4],
150 bool constrain_2d);
151
153 const float (*vert_coords)[3],
154 bool constrain_2d);
155
156float (*BKE_curve_nurbs_key_vert_coords_alloc(const ListBase *lb, float *key, int *r_vert_len))[3];
157void BKE_curve_nurbs_key_vert_tilts_apply(ListBase *lb, const float *key);
158
159void BKE_curve_editNurb_keyIndex_delCV(GHash *keyindex, const void *cv);
167
169void BKE_curve_bevelList_make(Object *ob, const ListBase *nurbs, bool for_render);
171
176 float q0, float q1, float q2, float q3, float *p, int it, int stride);
181 float q0, float q1, float q2, float q3, float *p, int it, int stride);
182
183void BKE_curve_rect_from_textbox(const Curve *cu, const TextBox *tb, rctf *r_rect);
184
189void BKE_curve_correct_bezpart(const float v1[2], float v2[2], float v3[2], const float v4[2]);
190
191/* ** Nurbs ** */
192
193bool BKE_nurbList_index_get_co(ListBase *nurb, int index, float r_co[3]);
194
195int BKE_nurbList_verts_count(const ListBase *nurb);
197
199void BKE_nurbList_duplicate(ListBase *lb1, const ListBase *lb2);
209void BKE_nurbList_handles_set(ListBase *editnurb, eNurbHandleTest_Mode handle_mode, char code);
210void BKE_nurbList_handles_recalculate(ListBase *editnurb, bool calc_length, uint8_t flag);
211
213void BKE_nurbList_flag_set(ListBase *editnurb, uint8_t flag, bool set);
218
219void BKE_nurb_free(Nurb *nu);
220Nurb *BKE_nurb_duplicate(const Nurb *nu);
224Nurb *BKE_nurb_copy(Nurb *src, int pntsu, int pntsv);
225
226void BKE_nurb_project_2d(Nurb *nu);
227float BKE_nurb_calc_length(const Nurb *nu, int resolution);
228
232void BKE_nurb_makeFaces(const Nurb *nu, float *coord_array, int rowstride, int resolu, int resolv);
238void BKE_nurb_makeCurve(const Nurb *nu,
239 float *coord_array,
240 float *tilt_array,
241 float *radius_array,
242 float *weight_array,
243 int resolu,
244 int stride);
245
249unsigned int BKE_curve_calc_coords_axis_len(unsigned int bezt_array_len,
250 unsigned int resolu,
251 bool is_cyclic,
252 bool use_cyclic_duplicate_endpoint);
259void BKE_curve_calc_coords_axis(const BezTriple *bezt_array,
260 unsigned int bezt_array_len,
261 unsigned int resolu,
262 bool is_cyclic,
263 bool use_cyclic_duplicate_endpoint,
264 /* array params */
265 unsigned int axis,
266 unsigned int stride,
267 float *r_points);
268
269void BKE_nurb_knot_calc_u(Nurb *nu);
270void BKE_nurb_knot_calc_v(Nurb *nu);
271
272/* nurb checks if they can be drawn, also clamp order func */
273bool BKE_nurb_check_valid_u(const Nurb *nu);
274bool BKE_nurb_check_valid_v(const Nurb *nu);
275bool BKE_nurb_check_valid_uv(const Nurb *nu);
276bool BKE_nurb_valid_message(int pnts,
277 short order,
278 short flag,
279 short type,
280 bool is_surf,
281 int dir,
282 char *message_dst,
283 size_t maxncpy);
284
287
292bool BKE_nurb_type_convert(Nurb *nu, short type, bool use_handles, const char **r_err_msg);
293
297void BKE_nurb_points_add(Nurb *nu, int number);
298void BKE_nurb_bezierPoints_add(Nurb *nu, int number);
299
300int BKE_nurb_index_from_uv(Nurb *nu, int u, int v);
301void BKE_nurb_index_to_uv(Nurb *nu, int index, int *r_u, int *r_v);
302
307
308void BKE_nurb_bezt_calc_normal(Nurb *nu, BezTriple *bezt, float r_normal[3]);
309void BKE_nurb_bezt_calc_plane(Nurb *nu, BezTriple *bezt, float r_plane[3]);
310
311void BKE_nurb_bpoint_calc_normal(Nurb *nu, BPoint *bp, float r_normal[3]);
312void BKE_nurb_bpoint_calc_plane(Nurb *nu, BPoint *bp, float r_plane[3]);
313
319 BezTriple *bezt, BezTriple *prev, BezTriple *next, bool is_fcurve, char smoothing);
328 BezTriple *prev,
330 eBezTriple_Flag__Alias handle_sel_flag,
331 bool is_fcurve,
332 char smoothing);
338
339void BKE_nurb_handle_smooth_fcurve(BezTriple *bezt, int total, bool cyclic);
340
343
349 const eBezTriple_Flag__Alias sel_flag,
350 const eNurbHandleTest_Mode handle_mode);
351
364 eBezTriple_Flag__Alias sel_flag,
365 const eNurbHandleTest_Mode handle_mode,
366 bool use_around_local);
367void BKE_nurb_handles_test(Nurb *nu, eNurbHandleTest_Mode handle_mode, bool use_around_local);
368
369/* **** Depsgraph evaluation **** */
370
371void BKE_curve_eval_geometry(Depsgraph *depsgraph, Curve *curve);
372
373/* Draw Cache */
374enum {
377};
378void BKE_curve_batch_cache_dirty_tag(Curve *cu, int mode);
380
381extern void (*BKE_curve_batch_cache_dirty_tag_cb)(Curve *cu, int mode);
382extern void (*BKE_curve_batch_cache_free_cb)(Curve *cu);
383
384/* -------------------------------------------------------------------- */
390unsigned int BKE_curve_decimate_bezt_array(BezTriple *bezt_array,
391 unsigned int bezt_array_len,
392 unsigned int resolu,
393 bool is_cyclic,
394 char flag_test,
395 char flag_set,
396 float error_sq_max,
397 unsigned int error_target_len);
398
400 unsigned int resolu,
401 float error_sq_max,
402 unsigned int error_target_len);
403
406/* -------------------------------------------------------------------- */
410void BKE_curve_deform_coords(const Object *ob_curve,
411 const Object *ob_target,
412 float (*vert_coords)[3],
413 int vert_coords_len,
414 const MDeformVert *dvert,
415 int defgrp_index,
416 short flag,
417 short defaxis);
418
420 const Object *ob_target,
421 float (*vert_coords)[3],
422 int vert_coords_len,
423 int defgrp_index,
424 short flag,
425 short defaxis,
426 const BMEditMesh *em_target);
427
434void BKE_curve_deform_co(const Object *ob_curve,
435 const Object *ob_target,
436 const float orco[3],
437 float vec[3],
438 int no_rot_axis,
439 float r_mat[3][3]);
440
443/* `curve_convert.cc` */
444
445/* Create a new curve from the given object at its current state. This only works for curve and
446 * text objects, otherwise NULL is returned.
447 *
448 * If apply_modifiers is true and the object is a curve one, then spline deform modifiers are
449 * applied on the control points of the splines.
450 */
451Curve *BKE_curve_new_from_object(Object *object, Depsgraph *depsgraph, bool apply_modifiers);
eNurbHandleTest_Mode
Definition BKE_curve.hh:56
@ NURB_HANDLE_TEST_EACH
Definition BKE_curve.hh:58
@ NURB_HANDLE_TEST_KNOT_OR_EACH
Definition BKE_curve.hh:63
@ NURB_HANDLE_TEST_KNOT_ONLY
Definition BKE_curve.hh:68
bool BKE_nurb_type_convert(Nurb *nu, short type, bool use_handles, const char **r_err_msg)
Definition curve.cc:4821
void BKE_nurb_handles_autocalc(Nurb *nu, uint8_t flag)
Definition curve.cc:4103
void BKE_nurb_handle_calc_simple_auto(Nurb *nu, BezTriple *bezt)
Definition curve.cc:3994
bool BKE_nurbList_flag_set_from_flag(ListBase *editnurb, uint8_t from_flag, uint8_t flag)
Definition curve.cc:4374
void BKE_nurbList_handles_set(ListBase *editnurb, eNurbHandleTest_Mode handle_mode, char code)
Definition curve.cc:4191
void BKE_nurb_handle_calc_simple(Nurb *nu, BezTriple *bezt)
Definition curve.cc:3985
void BKE_curve_batch_cache_dirty_tag(Curve *cu, int mode)
Definition curve.cc:5511
void BKE_nurb_index_to_uv(Nurb *nu, int index, int *r_u, int *r_v)
Definition curve.cc:911
void BKE_nurb_handles_calc(Nurb *nu)
Definition curve.cc:3955
const ListBase * BKE_curve_editNurbs_get_for_read(const Curve *cu)
Definition curve.cc:407
void BKE_curve_init(Curve *cu, short curve_type)
Definition curve.cc:347
void BKE_curve_translate(Curve *cu, const float offset[3], bool do_keys)
Definition curve.cc:5245
void BKE_curve_deform_coords(const Object *ob_curve, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, const MDeformVert *dvert, int defgrp_index, short flag, short defaxis)
void BKE_curve_editNurb_free(Curve *cu)
Definition curve.cc:337
bool BKE_curve_center_median(Curve *cu, float cent[3])
Definition curve.cc:5130
void BKE_nurb_makeFaces(const Nurb *nu, float *coord_array, int rowstride, int resolu, int resolv)
Definition curve.cc:1269
int eBezTriple_Flag__Alias
Definition BKE_curve.hh:34
void BKE_curve_correct_bezpart(const float v1[2], float v2[2], float v3[2], const float v4[2])
Definition curve.cc:5451
void BKE_nurb_project_2d(Nurb *nu)
Definition curve.cc:683
void BKE_curve_deform_co(const Object *ob_curve, const Object *ob_target, const float orco[3], float vec[3], int no_rot_axis, float r_mat[3][3])
void BKE_curve_texspace_ensure(Curve *cu)
Definition curve.cc:500
void BKE_nurb_bpoint_calc_plane(Nurb *nu, BPoint *bp, float r_plane[3])
Definition curve.cc:1081
void BKE_nurbList_handles_autocalc(ListBase *editnurb, uint8_t flag)
Definition curve.cc:4184
void BKE_curve_material_remap(Curve *cu, const unsigned int *remap, unsigned int remap_len)
Definition curve.cc:5385
void BKE_curve_decimate_nurb(Nurb *nu, unsigned int resolu, float error_sq_max, unsigned int error_target_len)
void BKE_nurb_free(Nurb *nu)
Definition curve.cc:569
void BKE_curve_type_test(Object *ob)
Definition curve.cc:454
void BKE_curve_bevelList_free(ListBase *bev)
Definition curve.cc:2510
ListBase * BKE_curve_nurbs_get(Curve *cu)
Definition curve.cc:4965
void BKE_curve_nurb_active_set(Curve *cu, const Nurb *nu)
Definition curve.cc:4983
void BKE_curve_texspace_calc(Curve *cu)
Definition curve.cc:466
Nurb * BKE_curve_nurb_active_get(Curve *cu)
Definition curve.cc:4995
const ListBase * BKE_curve_nurbs_get_for_read(const Curve *cu)
Definition curve.cc:4974
short BKE_nurb_bezt_handle_test_calc_flag(const BezTriple *bezt, const eBezTriple_Flag__Alias sel_flag, const eNurbHandleTest_Mode handle_mode)
Definition curve.cc:4013
bool BKE_nurb_check_valid_uv(const Nurb *nu)
Definition curve.cc:4789
void(* BKE_curve_batch_cache_free_cb)(Curve *cu)
Definition curve.cc:5509
Curve * BKE_curve_new_from_object(Object *object, Depsgraph *depsgraph, bool apply_modifiers)
void BKE_curve_batch_cache_free(Curve *cu)
Definition curve.cc:5517
void BKE_nurb_makeCurve(const Nurb *nu, float *coord_array, float *tilt_array, float *radius_array, float *weight_array, int resolu, int stride)
Definition curve.cc:1461
float BKE_nurb_calc_length(const Nurb *nu, int resolution)
Definition curve.cc:761
void BKE_curve_editNurb_keyIndex_free(GHash **keyindex)
Definition curve.cc:328
void BKE_nurbList_handles_recalculate(ListBase *editnurb, bool calc_length, uint8_t flag)
Definition curve.cc:4282
void BKE_curve_nurb_vert_active_set(Curve *cu, const Nurb *nu, const void *vert)
Definition curve.cc:5021
void BKE_nurb_knot_calc_u(Nurb *nu)
Definition curve.cc:1181
void BKE_nurb_handle_smooth_fcurve(BezTriple *bezt, int total, bool cyclic)
Definition curve.cc:3889
void BKE_nurb_handles_test(Nurb *nu, eNurbHandleTest_Mode handle_mode, bool use_around_local)
Definition curve.cc:4082
void BKE_curve_calc_coords_axis(const BezTriple *bezt_array, unsigned int bezt_array_len, unsigned int resolu, bool is_cyclic, bool use_cyclic_duplicate_endpoint, unsigned int axis, unsigned int stride, float *r_points)
Definition curve.cc:1607
void BKE_curve_nurbs_vert_coords_get(const ListBase *lb, float(*vert_coords)[3], int vert_len)
Definition curve.cc:4528
void BKE_curve_dimension_update(Curve *cu)
Definition curve.cc:437
void BKE_curve_nurbs_key_vert_tilts_apply(ListBase *lb, const float *key)
Definition curve.cc:4672
void BKE_nurbList_duplicate(ListBase *lb1, const ListBase *lb2)
Definition curve.cc:673
std::optional< blender::Bounds< blender::float3 > > BKE_curve_minmax(const Curve *cu, bool use_radius)
Definition curve.cc:5104
void * BKE_curve_vert_active_get(Curve *cu)
Definition curve.cc:5001
ListBase BKE_curve_bevel_make(const Curve *curve)
bool BKE_nurb_order_clamp_u(Nurb *nu)
Definition curve.cc:4801
unsigned int BKE_curve_calc_coords_axis_len(unsigned int bezt_array_len, unsigned int resolu, bool is_cyclic, bool use_cyclic_duplicate_endpoint)
Definition curve.cc:1597
void BKE_curve_forward_diff_bezier(float q0, float q1, float q2, float q3, float *p, int it, int stride)
Definition curve.cc:1663
void BKE_curve_smooth_flag_set(Curve *cu, bool use_smooth)
Definition curve.cc:5428
void BKE_nurbList_free(ListBase *lb)
Definition curve.cc:596
void BKE_curve_editfont_free(Curve *cu)
Definition curve.cc:295
ListBase * BKE_curve_editNurbs_get(Curve *cu)
Definition curve.cc:398
void BKE_curve_nurbs_vert_coords_apply(ListBase *lb, const float(*vert_coords)[3], bool constrain_2d)
Definition curve.cc:4602
void BKE_nurb_handle_calc(BezTriple *bezt, BezTriple *prev, BezTriple *next, bool is_fcurve, char smoothing)
Definition curve.cc:3938
bool BKE_nurb_check_valid_v(const Nurb *nu)
Definition curve.cc:4781
void BKE_curve_nurbs_vert_coords_apply_with_mat4(ListBase *lb, const float(*vert_coords)[3], const float mat[4][4], bool constrain_2d)
Definition curve.cc:4565
int BKE_nurbList_verts_count(const ListBase *nurb)
Definition curve.cc:535
void BKE_curve_material_index_remove(Curve *cu, int index)
Definition curve.cc:5291
int BKE_nurb_index_from_uv(Nurb *nu, int u, int v)
Definition curve.cc:889
void BKE_nurb_bezt_handle_test(BezTriple *bezt, eBezTriple_Flag__Alias sel_flag, const eNurbHandleTest_Mode handle_mode, bool use_around_local)
Definition curve.cc:4046
void BKE_curve_forward_diff_tangent_bezier(float q0, float q1, float q2, float q3, float *p, int it, int stride)
Definition curve.cc:1691
@ BKE_CURVE_BATCH_DIRTY_SELECT
Definition BKE_curve.hh:376
@ BKE_CURVE_BATCH_DIRTY_ALL
Definition BKE_curve.hh:375
void BKE_nurb_bezt_calc_normal(Nurb *nu, BezTriple *bezt, float r_normal[3])
Definition curve.cc:1006
void BKE_nurb_knot_calc_v(Nurb *nu)
Definition curve.cc:1186
short BKE_curve_type_get(const Curve *cu)
Definition curve.cc:416
Curve * BKE_curve_add(Main *bmain, const char *name, int type)
Definition curve.cc:386
void(* BKE_curve_batch_cache_dirty_tag_cb)(Curve *cu, int mode)
Definition curve.cc:5508
bool BKE_curve_material_index_used(const Curve *cu, int index)
Definition curve.cc:5312
void BKE_nurb_direction_switch(Nurb *nu)
Definition curve.cc:4405
void BKE_curve_nurb_vert_active_validate(Curve *cu)
Definition curve.cc:5065
void BKE_curve_material_index_clear(Curve *cu)
Definition curve.cc:5335
void BKE_curve_eval_geometry(Depsgraph *depsgraph, Curve *curve)
Definition curve.cc:5492
bool BKE_curve_nurb_vert_active_get(Curve *cu, Nurb **r_nu, void **r_vert)
Definition curve.cc:5038
BPoint * BKE_nurb_bpoint_get_prev(Nurb *nu, BPoint *bp)
Definition curve.cc:984
bool BKE_nurb_check_valid_u(const Nurb *nu)
Definition curve.cc:4773
void BKE_nurb_bezierPoints_add(Nurb *nu, int number)
Definition curve.cc:875
void BKE_curve_transform(Curve *cu, const float mat[4][4], bool do_keys, bool do_props)
Definition curve.cc:5239
BPoint * BKE_nurb_bpoint_get_next(Nurb *nu, BPoint *bp)
Definition curve.cc:941
void BKE_nurbList_flag_set(ListBase *editnurb, uint8_t flag, bool set)
Definition curve.cc:4339
BezTriple * BKE_nurb_bezt_get_next(Nurb *nu, BezTriple *bezt)
Definition curve.cc:920
void BKE_nurb_bpoint_calc_normal(Nurb *nu, BPoint *bp, float r_normal[3])
Definition curve.cc:1058
Nurb * BKE_nurb_duplicate(const Nurb *nu)
Definition curve.cc:608
bool BKE_nurb_order_clamp_v(Nurb *nu)
Definition curve.cc:4811
void BKE_curve_transform_ex(Curve *cu, const float mat[4][4], bool do_keys, bool do_props, float unit_scale)
Definition curve.cc:5167
unsigned int BKE_curve_decimate_bezt_array(BezTriple *bezt_array, unsigned int bezt_array_len, unsigned int resolu, bool is_cyclic, char flag_test, char flag_set, float error_sq_max, unsigned int error_target_len)
void BKE_curve_rect_from_textbox(const Curve *cu, const TextBox *tb, rctf *r_rect)
Definition curve.cc:5442
void BKE_curve_editNurb_keyIndex_delCV(GHash *keyindex, const void *cv)
Definition curve.cc:322
int BKE_nurbList_verts_count_without_handles(const ListBase *nurb)
Definition curve.cc:551
float(* BKE_curve_nurbs_key_vert_coords_alloc(const ListBase *lb, float *key, int *r_vert_len))[3]
Definition curve.cc:4638
bool BKE_nurbList_index_get_co(ListBase *nurb, int index, float r_co[3])
Definition curve.cc:509
Nurb * BKE_nurb_copy(Nurb *src, int pntsu, int pntsv)
Definition curve.cc:648
void BKE_curve_bevelList_make(Object *ob, const ListBase *nurbs, bool for_render)
Definition curve.cc:2528
int BKE_curve_nurb_vert_index_get(const Nurb *nu, const void *vert)
Definition curve.cc:5010
void BKE_nurb_handle_calc_ex(BezTriple *bezt, BezTriple *prev, BezTriple *next, eBezTriple_Flag__Alias handle_sel_flag, bool is_fcurve, char smoothing)
Definition curve.cc:3944
void BKE_nurb_bezt_calc_plane(Nurb *nu, BezTriple *bezt, float r_plane[3])
Definition curve.cc:1021
bool BKE_nurb_valid_message(int pnts, short order, short flag, short type, bool is_surf, int dir, char *message_dst, size_t maxncpy)
Definition curve.cc:4729
float(* BKE_curve_nurbs_vert_coords_alloc(const ListBase *lb, int *r_vert_len))[3]
Definition curve.cc:4555
BezTriple * BKE_nurb_bezt_get_prev(Nurb *nu, BezTriple *bezt)
Definition curve.cc:962
void BKE_curve_deform_coords_with_editmesh(const Object *ob_curve, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, int defgrp_index, short flag, short defaxis, const BMEditMesh *em_target)
bool BKE_curve_material_index_validate(Curve *cu)
Definition curve.cc:5352
void BKE_nurb_points_add(Nurb *nu, int number)
Definition curve.cc:862
These structs are the foundation for all linked lists in the library system.
ATTR_WARN_UNUSED_RESULT const BMVert * v2
ATTR_WARN_UNUSED_RESULT const BMVert * v
const Depsgraph * depsgraph
static bool is_cyclic(const Nurb *nu)
draw_view in_light_buf[] float
draw_view push_constant(Type::INT, "radiance_src") .push_constant(Type capture_info_buf storage_buf(1, Qualifier::READ, "ObjectBounds", "bounds_buf[]") .push_constant(Type draw_view int
static ulong * next
unsigned char uint8_t
Definition stdint.h:78
int key_index
Definition BKE_curve.hh:52
int vertex_index
Definition BKE_curve.hh:52
void * orig_cv
Definition BKE_curve.hh:51
bool switched
Definition BKE_curve.hh:53
ListBase bev
Definition BKE_curve.hh:38
ListBase disp
Definition BKE_curve.hh:37
ListBase deformed_nurbs
Definition BKE_curve.hh:39
const float * anim_path_accum_length
Definition BKE_curve.hh:46
uint8_t flag
Definition wm_window.cc:138