Blender
V3.3
|
#include "DNA_curveprofile_types.h"
Go to the source code of this file.
Enumerations | |
enum | { PROF_UPDATE_NONE = 0 , PROF_UPDATE_REMOVE_DOUBLES = (1 << 0) , PROF_UPDATE_CLIP = (1 << 1) } |
anonymous enum |
Enumerator | |
---|---|
PROF_UPDATE_NONE | |
PROF_UPDATE_REMOVE_DOUBLES | |
PROF_UPDATE_CLIP |
Definition at line 127 of file BKE_curveprofile.h.
struct CurveProfile* BKE_curveprofile_add | ( | eCurveProfilePresets | preset | ) |
Returns a pointer to a newly allocated curve profile, using the given preset.
Definition at line 31 of file curveprofile.cc.
References BKE_curveprofile_reset(), BKE_curveprofile_set_defaults(), BKE_curveprofile_update(), and CurveProfile::preset.
Referenced by blo_do_versions_280(), blo_update_defaults_scene(), initData(), and scene_init_data().
void BKE_curveprofile_blend_read | ( | struct BlendDataReader * | reader, |
struct CurveProfile * | profile | ||
) |
Expects that the curve profile itself has been read already.
Definition at line 88 of file curveprofile.cc.
References BKE_curveprofile_init(), BLO_read_data_address, CurveProfile::path, CurveProfile::path_len, CurveProfilePoint::profile, CurveProfile::segments, CurveProfile::segments_len, and CurveProfile::table.
Referenced by blendRead(), curve_blend_read_data(), and scene_blend_read_data().
void BKE_curveprofile_blend_write | ( | struct BlendWriter * | writer, |
const struct CurveProfile * | profile | ||
) |
Definition at line 82 of file curveprofile.cc.
References BLO_write_struct, BLO_write_struct_array, CurveProfile::path, and CurveProfile::path_len.
Referenced by blendWrite(), curve_blend_write(), and scene_blend_write().
struct CurveProfile* BKE_curveprofile_copy | ( | const struct CurveProfile * | profile | ) |
Referenced by BKE_toolsettings_copy(), copyData(), and curve_copy_data().
void BKE_curveprofile_copy_data | ( | struct CurveProfile * | target, |
const struct CurveProfile * | profile | ||
) |
Referenced by ui_but_copy_CurveProfile(), and ui_but_paste_CurveProfile().
void BKE_curveprofile_evaluate_length_portion | ( | const struct CurveProfile * | profile, |
float | length_portion, | ||
float * | x_out, | ||
float * | y_out | ||
) |
Does a single evaluation along the profile's path. Travels down (length_portion * path) length and returns the position at that point. Where length portion is the fraction of the total path length where we want the location.
length_portion | The portion (0 to 1) of the path's full length to sample at. |
void BKE_curveprofile_free | ( | struct CurveProfile * | profile | ) |
Definition at line 50 of file curveprofile.cc.
References BKE_curveprofile_free_data(), and MEM_freeN.
Referenced by BKE_toolsettings_free(), curve_free_data(), and freeData().
void BKE_curveprofile_free_data | ( | struct CurveProfile * | profile | ) |
Definition at line 43 of file curveprofile.cc.
References MEM_SAFE_FREE, CurveProfile::path, CurveProfile::segments, and CurveProfile::table.
Referenced by BKE_curveprofile_free(), ui_but_clipboard_free(), ui_but_copy_CurveProfile(), and ui_but_paste_CurveProfile().
void BKE_curveprofile_init | ( | struct CurveProfile * | profile, |
short | segments_len | ||
) |
Refreshes the higher resolution table sampled from the input points. A call to this or BKE_curveprofile_update is needed before evaluation functions that use the table. Also sets the number of segments used for the display preview of the locations of the sampled points.
Definition at line 822 of file curveprofile.cc.
References BKE_curveprofile_update(), CurveProfile::flag, PROF_DIRTY_PRESET, PROF_UPDATE_NONE, and CurveProfile::segments_len.
Referenced by BKE_curveprofile_blend_read(), and set_profile_spacing().
struct CurveProfilePoint* BKE_curveprofile_insert | ( | struct CurveProfile * | profile, |
float | x, | ||
float | y | ||
) |
Adds a new point at the specified location. The choice for which points to place the new vertex between is made by checking which control point line segment is closest to the new point and placing the new vertex in between that segment's points.
Definition at line 264 of file curveprofile.cc.
References dist_squared_to_line_segment_v2(), blender::math::distance(), CurveProfilePoint::flag, CurveProfilePoint::h1, CurveProfilePoint::h2, HD_AUTO, HD_VECT, MEM_freeN, MEM_mallocN, CurveProfile::path, CurveProfile::path_len, point_init(), PROF_SELECT, PROF_TABLE_MAX, CurveProfilePoint::profile, x, CurveProfilePoint::x, y, and CurveProfilePoint::y.
Referenced by ui_do_but_CURVEPROFILE().
bool BKE_curveprofile_move_handle | ( | struct CurveProfilePoint * | point, |
bool | handle_1, | ||
bool | snap, | ||
const float | delta[2] | ||
) |
Move a point's handle, accounting for the alignment of handles with the HD_ALIGN type.
handle_1 | Whether to move the 1st or 2nd control point. |
delta | The relative change in the handle's position. |
Definition at line 108 of file curveprofile.cc.
References copy_v2_v2(), ELEM, equals_v2v2(), HD_ALIGN, HD_FREE, if(), point, and snap().
Referenced by BKE_curveprofile_selected_handle_set(), and ui_numedit_but_CURVEPROFILE().
bool BKE_curveprofile_move_point | ( | struct CurveProfile * | profile, |
struct CurveProfilePoint * | point, | ||
bool | snap, | ||
const float | delta[2] | ||
) |
Moves a control point, accounting for clipping and snapping, and moving free handles.
snap | Whether to snap the point to the grid |
delta | The relative change of the point's location. |
Definition at line 148 of file curveprofile.cc.
References CurveProfile::clip_rect, ELEM, CurveProfile::flag, HD_ALIGN, HD_FREE, max_ff(), min_ff(), CurveProfile::path, CurveProfile::path_len, point, PROF_USE_CLIP, snap(), rctf::xmax, rctf::xmin, rctf::ymax, and rctf::ymin.
Referenced by ui_numedit_but_CURVEPROFILE().
void BKE_curveprofile_remove_by_flag | ( | struct CurveProfile * | profile, |
short | flag | ||
) |
Removes every point in the widget with the supplied flag set, except for the first and last.
flag | CurveProfilePoint.flag. |
Definition at line 225 of file curveprofile.cc.
References CurveProfilePoint::flag, CurveProfile::flag, MEM_freeN, MEM_mallocN, CurveProfile::path, and CurveProfile::path_len.
Referenced by CurveProfile_buttons_delete(), and ui_do_but_CURVEPROFILE().
bool BKE_curveprofile_remove_point | ( | struct CurveProfile * | profile, |
struct CurveProfilePoint * | point | ||
) |
Removes a specific point from the path of control points.
Definition at line 195 of file curveprofile.cc.
References BLI_assert, MEM_freeN, MEM_mallocN, CurveProfile::path, CurveProfile::path_len, and point.
Referenced by BKE_curveprofile_update().
void BKE_curveprofile_reset | ( | struct CurveProfile * | profile | ) |
Resets the profile to the current preset.
Definition at line 422 of file curveprofile.cc.
References curveprofile_build_steps(), curveprofile_build_supports(), CurveProfile::flag, HD_AUTO, HD_VECT, MEM_callocN, MEM_SAFE_FREE, CurveProfile::path, CurveProfile::path_len, point_init(), CurveProfile::preset, PROF_DIRTY_PRESET, PROF_PRESET_CORNICE, PROF_PRESET_CROWN, PROF_PRESET_LINE, PROF_PRESET_STEPS, PROF_PRESET_SUPPORTS, CurveProfilePoint::profile, CurveProfile::segments_len, and CurveProfile::table.
Referenced by BKE_curveprofile_add(), CurveProfile_buttons_reset(), CurveProfile_presets_dofunc(), and CurveProfile_tools_dofunc().
void BKE_curveprofile_reset_view | ( | struct CurveProfile * | profile | ) |
Reset the view to the clipping rectangle.
Definition at line 417 of file curveprofile.cc.
References CurveProfile::clip_rect, and CurveProfile::view_rect.
Referenced by CurveProfile_tools_dofunc().
void BKE_curveprofile_reverse | ( | struct CurveProfile * | profile | ) |
Flips the profile across the diagonal so that its orientation is reversed.
Definition at line 341 of file curveprofile.cc.
References BLI_assert, ELEM, CurveProfilePoint::h1, CurveProfilePoint::h1_loc, CurveProfilePoint::h2, CurveProfilePoint::h2_loc, HD_ALIGN, HD_FREE, MEM_freeN, MEM_mallocN, mirror_point(), CurveProfile::path, CurveProfile::path_len, and CurveProfilePoint::profile.
Referenced by CurveProfile_buttons_reverse().
void BKE_curveprofile_selected_handle_set | ( | struct CurveProfile * | profile, |
int | type_1, | ||
int | type_2 | ||
) |
Sets the handle type of the selected control points.
type_1,type_2 | Handle type for the first handle. HD_VECT, HD_AUTO, HD_FREE, or HD_ALIGN. |
Definition at line 319 of file curveprofile.cc.
References BKE_curveprofile_move_handle(), ELEM, CurveProfilePoint::flag, CurveProfilePoint::h1, CurveProfilePoint::h2, HD_ALIGN, CurveProfile::path, CurveProfile::path_len, PROF_H1_SELECT, PROF_H2_SELECT, and PROF_SELECT.
void BKE_curveprofile_set_defaults | ( | struct CurveProfile * | profile | ) |
Sets the default settings and clip range for the profile widget. Does not generate either table.
Definition at line 802 of file curveprofile.cc.
References BLI_rctf_init(), CurveProfile::changed_timestamp, CurveProfile::clip_rect, CurveProfile::flag, MEM_callocN, CurveProfile::path, CurveProfile::path_len, PROF_USE_CLIP, CurveProfilePoint::profile, CurveProfile::view_rect, CurveProfilePoint::x, and CurveProfilePoint::y.
Referenced by BKE_curveprofile_add().
int BKE_curveprofile_table_size | ( | const struct CurveProfile * | profile | ) |
Referenced by ui_do_but_CURVEPROFILE(), and ui_draw_but_CURVEPROFILE().
void BKE_curveprofile_update | ( | struct CurveProfile * | profile, |
int | update_flags | ||
) |
Should be called after the widget is changed. Does profile and remove double checks and more importantly, recreates the display / evaluation and segments tables.
update_flags | Bit-field with fields defined in header file. Controls removing doubles and clipping. |
Definition at line 965 of file curveprofile.cc.
References BKE_curveprofile_remove_point(), BLI_assert, BLI_rctf_size_x(), BLI_rctf_size_y(), CurveProfile::changed_timestamp, clamp_f(), CurveProfile::clip_rect, curveprofile_make_segments_table(), curveprofile_make_table(), CurveProfile::flag, len_squared_v2v2(), CurveProfile::path, CurveProfile::path_len, pow2f(), PROF_UPDATE_CLIP, PROF_UPDATE_REMOVE_DOUBLES, PROF_USE_CLIP, CurveProfile::segments_len, CurveProfile::view_rect, x, CurveProfilePoint::x, rctf::xmax, rctf::xmin, y, CurveProfilePoint::y, rctf::ymax, and rctf::ymin.
Referenced by BKE_curveprofile_add(), BKE_curveprofile_init(), CurveProfile_buttons_delete(), CurveProfile_buttons_reset(), CurveProfile_buttons_reverse(), CurveProfile_buttons_update(), CurveProfile_clipping_toggle(), CurveProfile_presets_dofunc(), CurveProfile_tools_dofunc(), ui_do_but_CURVEPROFILE(), ui_draw_but_CURVEPROFILE(), and ui_numedit_but_CURVEPROFILE().