46#define GIZMO_MARGIN_OFFSET_SCALE 1.5f
48#define CIRCLE_RESOL 32
54 float matrix_final_no_offset[4][4];
55 float x_axis[3], y_axis[3];
60 float len_x_axis =
len_v3(x_axis);
61 float len_y_axis =
len_v3(y_axis);
76 margin[0] = (handle_size * scale_xy[0]);
77 margin[1] = (handle_size * scale_xy[1]);
87 const float margin[2],
89 const float line_width)
131 const int highlighted,
133 const float margin[2],
134 const float line_width,
136 const int draw_options)
143 switch (highlighted) {
313 const float rotate_pt[2] = {0.0f,
size[1] + margin[1]};
315 r_rotate.
xmin = rotate_pt[0] - margin[0] / 2.0f;
316 r_rotate.
xmax = rotate_pt[0] + margin[0] / 2.0f;
317 r_rotate.
ymin = rotate_pt[1] - margin[1] / 2.0f;
318 r_rotate.
ymax = rotate_pt[1] + margin[1] / 2.0f;
383 if (margin[0] == 0.0f && margin[1] == 0.0) {
386 else if (margin[0] == 0.0f || margin[1] == 0.0) {
395 for (
uint i = 0;
i < verts_len;
i++) {
407 immUniform1f(
"lineWidth", (line_width * 3.0f) *
U.pixelsize);
411 for (
uint i = 0;
i < verts_len;
i++) {
420 for (
uint i = 0;
i < verts_len;
i++) {
439 uint pos,
float x,
float y,
float rad_x,
float rad_y,
bool solid)
441 if (rad_x == 0 && rad_y == 0) {
448 if (rad_x == 0 || rad_y == 0) {
485 const float margin[2],
486 const float color[3],
487 const int transform_flag,
488 const int draw_options,
489 const float line_width)
530 const float rad[2] = {margin[0] / 2, margin[1] / 2};
547 const float margin[2],
548 const int transform_flag,
549 const int draw_options,
550 const float line_width)
586 const float rad[2] = {margin[0] / 2, margin[1] / 2};
587 const float center[2] = {0.0f, 0.0f};
603 return ELEM(highlighted,
611 const float margin[2],
612 const float color[3],
616 void (*circle_fn)(
uint, float, float, float, float, int) = (solid) ?
619 const int resolu = 12;
620 const float rad[2] = {margin[0] / 3, margin[1] / 3};
625 const float handle[2] = {
629 circle_fn(
pos, handle[0], handle[1], rad[0], rad[1], resolu);
635 const float margin[2],
636 const float color[3],
640 const float rad[2] = {margin[0] / 3, margin[1] / 3};
657 const int highlighted,
659 const float margin[2],
660 const float color[3],
668 switch (highlighted) {
671 const float rad[2] = {0.2f * margin[0], 0.4f *
size[1]};
678 const float rad[2] = {0.4f *
size[0], 0.2f * margin[1]};
692 const bool highlight,
698 float matrix_final[4][4];
704 const float size_real[2] = {dims[0] / 2.0f, dims[1] / 2.0f};
728 const float size[2] = {size_real[0] + margin[0] / 2, size_real[1] + margin[1] / 2};
737 int scale_parts[] = {
773 r.
xmin = -size_real[0];
774 r.
ymin = -size_real[1];
775 r.
xmax = size_real[0];
776 r.
ymax = size_real[1];
779 float color[4], black[3] = {0, 0, 0};
816 float color[4], black[3] = {0, 0, 0};
821 float outline_line_width = gz->
line_width + 3.0f;
845 black, size_real, margin, transform_flag, draw_options, outline_line_width);
847 color, size_real, margin, transform_flag, draw_options, gz->
line_width);
897 switch (highlight_part) {
923 float point_local[2];
926 const float size_real[2] = {dims[0] / 2.0f, dims[1] / 2.0f};
938 const float size[2] = {size_real[0] + margin[0] / 2, size_real[1] + margin[1] / 2};
946 r.
xmin = -margin[0] / 2;
947 r.
ymin = -margin[1] / 2;
948 r.
xmax = margin[0] / 2;
949 r.
ymax = margin[1] / 2;
1033 r_rotate.
xmin = r_rotate_pt[0] - margin[0] / 2.0f;
1034 r_rotate.
xmax = r_rotate_pt[0] + margin[0] / 2.0f;
1035 r_rotate.
ymin = r_rotate_pt[1] - margin[1] / 2.0f;
1036 r_rotate.
ymax = r_rotate_pt[1] + margin[1] / 2.0f;
1048struct RectTransformInteraction {
1049 float orig_mouse[2];
1050 float orig_matrix_offset[4][4];
1051 float orig_matrix_final_no_offset[4][4];
1053 bool use_temp_uniform;
1060 RectTransformInteraction *
data =
static_cast<RectTransformInteraction *
>(gz->
interaction_data);
1063 if (
data->use_temp_uniform) {
1067 return transform_flag;
1154 RectTransformInteraction *
data =
static_cast<RectTransformInteraction *
>(gz->
interaction_data);
1159 const bool use_temp_uniform = (
event->modifier &
KM_SHIFT) != 0;
1160 const bool changed =
data->use_temp_uniform != use_temp_uniform;
1161 data->use_temp_uniform = use_temp_uniform;
1162 if (use_temp_uniform) {
1174 float point_local[2];
1180 float matrix_back[4][4];
1197 if (gz_prop->
type !=
nullptr) {
1205 (point_local[0] -
data->orig_mouse[0]);
1207 (point_local[1] -
data->orig_mouse[1]);
1211#define MUL_V2_V3_M4_FINAL(test_co, mouse_co) \
1212 mul_v3_m4v3(test_co, data->orig_matrix_final_no_offset, blender::float3{UNPACK2(mouse_co), 0.0})
1216 if (
data->dial ==
nullptr) {
1229 float matrix_space_inv[4][4];
1230 float matrix_rotate[4][4];
1238 mul_m4_m4m4(matrix_rotate, matrix_rotate, matrix_space_inv);
1247#undef MUL_V2_V3_M4_FINAL
1263 float curr_mouse[2];
1283 bool constrain_axis[2] = {
false};
1286 float size_new[2], size_orig[2];
1287 for (
int i = 0;
i < 2;
i++) {
1289 size_new[
i] = size_orig[
i];
1290 if (constrain_axis[
i] ==
false) {
1292 const float delta_orig = curr_mouse[
i] -
data->orig_matrix_offset[3][
i] -
1293 pivot[
i] * size_orig[
i];
1294 const float delta_curr = point_local[
i] -
data->orig_matrix_offset[3][
i] -
1295 pivot[
i] * size_orig[
i];
1304 size_new[
i] = delta_curr / (
signf(delta_orig) * 0.5f * dims[
i] - pivot[
i]);
1308 float scale[2] = {1.0f, 1.0f};
1309 for (
int i = 0;
i < 2;
i++) {
1310 if (size_orig[
i] == 0) {
1311 size_orig[
i] = 1.0f;
1314 scale[
i] = size_new[
i] / size_orig[
i];
1318 if (constrain_axis[0] ==
false && constrain_axis[1] ==
false) {
1321 scale[1] = scale[0] =
len_v2(scale);
1324 scale[1] = scale[0] = (scale[1] + scale[0]) / 2.0f;
1327 else if (constrain_axis[0] ==
false) {
1328 scale[1] = scale[0];
1330 else if (constrain_axis[1] ==
false) {
1331 scale[0] = scale[1];
1339 float matrix_scale[4][4];
1349 if (gz_prop->
type !=
nullptr) {
1377 RectTransformInteraction *
data =
static_cast<RectTransformInteraction *
>(gz->
interaction_data);
1381 data->dial =
nullptr;
1392 if (gz_prop->
type !=
nullptr) {
1406 gzt->
idname =
"GIZMO_GT_cage_2d";
1426 {0,
nullptr, 0,
nullptr,
nullptr},
1433 {0,
nullptr, 0,
nullptr,
nullptr},
1438 {0,
nullptr, 0,
nullptr,
nullptr},
1440 static const float unit_v2[2] = {1.0f, 1.0f};
1446 rna_enum_draw_style,
1452 rna_enum_draw_options,
wmWindow * CTX_wm_window(const bContext *C)
ARegion * CTX_wm_region(const bContext *C)
void BLI_dial_free(Dial *dial)
Dial * BLI_dial_init(const float start_position[2], float threshold)
float BLI_dial_angle(Dial *dial, const float current_position[2])
MINLINE float signf(float f)
MINLINE int signum_i(float a)
MINLINE float safe_divide(float a, float b)
void mul_m4_m4m4(float R[4][4], const float A[4][4], const float B[4][4])
void mul_m3_v2(const float m[3][3], float r[2])
void mat4_to_loc_rot_size(float loc[3], float rot[3][3], float size[3], const float wmat[4][4])
void transform_pivot_set_m4(float mat[4][4], const float pivot[3])
void copy_m4_m4(float m1[4][4], const float m2[4][4])
bool invert_m4_m4(float inverse[4][4], const float mat[4][4])
void rotate_m4(float mat[4][4], char axis, float angle)
void mul_m4_m4_post(float R[4][4], const float B[4][4])
void mul_v3_mat3_m4v3(float r[3], const float mat[4][4], const float vec[3])
bool invert_m3(float mat[3][3])
void unit_m4(float m[4][4])
MINLINE float len_v2(const float v[2]) ATTR_WARN_UNUSED_RESULT
MINLINE void sub_v2_v2(float r[2], const float a[2])
MINLINE void mul_v2_v2(float r[2], const float a[2])
MINLINE void copy_v2_v2(float r[2], const float a[2])
MINLINE void mul_v3_fl(float r[3], float f)
MINLINE bool is_zero_v2(const float v[2]) ATTR_WARN_UNUSED_RESULT
MINLINE void copy_v3_v3(float r[3], const float a[3])
MINLINE void add_v2_v2(float r[2], const float a[2])
MINLINE void zero_v2(float r[2])
MINLINE void zero_v3(float r[3])
MINLINE float len_v3(const float a[3]) ATTR_WARN_UNUSED_RESULT
bool BLI_rctf_is_valid(const struct rctf *rect)
bool BLI_rctf_isect_pt_v(const struct rctf *rect, const float xy[2])
BLI_INLINE float BLI_rctf_cent_y(const struct rctf *rct)
BLI_INLINE float BLI_rctf_cent_x(const struct rctf *rct)
void BLI_rctf_sanitize(struct rctf *rect)
#define ARRAY_SET_ITEMS(...)
@ ED_GIZMO_CAGE_XFORM_FLAG_SCALE
@ ED_GIZMO_CAGE_XFORM_FLAG_TRANSLATE
@ ED_GIZMO_CAGE_XFORM_FLAG_ROTATE
@ ED_GIZMO_CAGE_XFORM_FLAG_SCALE_UNIFORM
@ ED_GIZMO_CAGE_XFORM_FLAG_SCALE_SIGNED
@ ED_GIZMO_CAGE2D_PART_SCALE_MIN_X_MAX_Y
@ ED_GIZMO_CAGE2D_PART_TRANSLATE
@ ED_GIZMO_CAGE2D_PART_ROTATE
@ ED_GIZMO_CAGE2D_PART_SCALE
@ ED_GIZMO_CAGE2D_PART_SCALE_MAX_Y
@ ED_GIZMO_CAGE2D_PART_SCALE_MAX_X_MAX_Y
@ ED_GIZMO_CAGE2D_PART_SCALE_MIN_X
@ ED_GIZMO_CAGE2D_PART_SCALE_MAX_X_MIN_Y
@ ED_GIZMO_CAGE2D_PART_SCALE_MAX_X
@ ED_GIZMO_CAGE2D_PART_SCALE_MIN_X_MIN_Y
@ ED_GIZMO_CAGE2D_PART_SCALE_MIN_Y
@ ED_GIZMO_CAGE2D_STYLE_BOX_TRANSFORM
@ ED_GIZMO_CAGE2D_STYLE_BOX
@ ED_GIZMO_CAGE2D_STYLE_CIRCLE
@ ED_GIZMO_CAGE_DRAW_FLAG_CORNER_HANDLES
@ ED_GIZMO_CAGE_DRAW_FLAG_XFORM_CENTER_HANDLE
void ED_region_tag_redraw_editor_overlays(ARegion *region)
#define GPU_matrix_mul(x)
bool GPU_select_load_id(unsigned int id)
@ GPU_SHADER_3D_POLYLINE_UNIFORM_COLOR
@ GPU_SHADER_3D_POINT_UNIFORM_SIZE_UNIFORM_COLOR_AA
@ GPU_SHADER_3D_UNIFORM_COLOR
@ GPU_SHADER_3D_FLAT_COLOR
@ GPU_SHADER_3D_POLYLINE_FLAT_COLOR
void GPU_blend(eGPUBlend blend)
void GPU_viewport_size_get_f(float coords[4])
static double angle(const Eigen::Vector3d &v1, const Eigen::Vector3d &v2)
Read Guarded memory(de)allocation.
eWM_GizmoFlagTweak
Gizmo tweak flag. Bit-flag passed to gizmo while tweaking.
@ WM_GIZMO_STATE_HIGHLIGHT
BMesh const char void * data
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
static void gizmo_calc_rect_view_margin(const wmGizmo *gz, float margin[2])
void ED_gizmotypes_cage_2d()
static void gizmo_constrain_from_scale_part(int part, bool r_constrain_axis[2])
static void GIZMO_GT_cage_2d(wmGizmoType *gzt)
#define GIZMO_MARGIN_OFFSET_SCALE
static void cage2d_draw_rect_edge_handles(const rctf *r, const int highlighted, const float size[2], const float margin[2], const float color[3], bool solid)
static int gizmo_cage2d_get_cursor(wmGizmo *gz)
static void cage2d_draw_box_interaction(const float color[4], const int highlighted, const float size[2], const float margin[2], const float line_width, const bool is_solid, const int draw_options)
static void cage2d_draw_box_corners(const rctf *r, const float margin[2], const float color[3], const float line_width)
static wmOperatorStatus gizmo_cage2d_invoke(bContext *C, wmGizmo *gz, const wmEvent *event)
static void cage2d_draw_rect_rotate_handle(const rctf *r, const float margin[2], const float color[3], bool solid)
static bool is_corner_highlighted(const int highlighted)
static void cage2d_draw_circle_wire(const float color[3], const float size[2], const float margin[2], const int transform_flag, const int draw_options, const float line_width)
static wmOperatorStatus gizmo_cage2d_modal(bContext *C, wmGizmo *gz, const wmEvent *event, eWM_GizmoFlagTweak)
static void cage2d_draw_rect_wire(const rctf *r, const float margin[2], const float color[3], const int transform_flag, const int draw_options, const float line_width)
static void gizmo_pivot_from_scale_part(int part, float r_pt[2])
static void gizmo_cage2d_draw(const bContext *, wmGizmo *gz)
static int gizmo_cage2d_test_select(bContext *C, wmGizmo *gz, const int mval[2])
static void gizmo_calc_rect_view_scale(const wmGizmo *gz, float scale[2])
static void gizmo_cage2d_draw_select(const bContext *, wmGizmo *gz, int select_id)
static void imm_draw_point_aspect_2d(uint pos, float x, float y, float rad_x, float rad_y, bool solid)
#define MUL_V2_V3_M4_FINAL(test_co, mouse_co)
static void gizmo_cage2d_setup(wmGizmo *gz)
static void cage2d_draw_rect_corner_handles(const rctf *r, const float margin[2], const float color[3], bool solid)
static void gizmo_cage2d_exit(bContext *C, wmGizmo *gz, const bool cancel)
static void gizmo_cage2d_draw_intern(wmGizmo *gz, const bool select, const bool highlight, const int select_id)
static int gizmo_cage2d_transform_flag_get(const wmGizmo *gz)
static void gizmo_cage2d_property_update(wmGizmo *gz, wmGizmoProperty *gz_prop)
void gizmo_color_get(const wmGizmo *gz, bool highlight, float r_color[4])
bool gizmo_window_project_2d(bContext *C, const wmGizmo *gz, const float mval[2], int axis, bool use_offset, float r_co[2])
struct @064345207361167251075330302113175271221317160336::@201157344026354305110036153026103256267276205234 attr_id
void * MEM_callocN(size_t len, const char *str)
VecBase< int32_t, 2 > int2
VecBase< float, 2 > float2
VecBase< float, 3 > float3
void RNA_float_get_array(PointerRNA *ptr, const char *name, float *values)
int RNA_enum_get(PointerRNA *ptr, const char *name)
PropertyRNA * RNA_def_float_vector(StructOrFunctionRNA *cont_, const char *identifier, const int len, const float *default_value, const float hardmin, const float hardmax, const char *ui_name, const char *ui_description, const float softmin, const float softmax)
PropertyRNA * RNA_def_enum(StructOrFunctionRNA *cont_, const char *identifier, const EnumPropertyItem *items, const int default_value, const char *ui_name, const char *ui_description)
PropertyRNA * RNA_def_enum_flag(StructOrFunctionRNA *cont_, const char *identifier, const EnumPropertyItem *items, const int default_value, const char *ui_name, const char *ui_description)
eWM_GizmoFlagGroupTypeFlag flag
const wmGizmoPropertyType * type
wmGizmoFnTestSelect test_select
wmGizmoFnCursorGet cursor_get
wmGizmoFnDrawSelect draw_select
wmGizmoFnPropertyUpdate property_update
wmGizmoGroup * parent_gzgroup
float matrix_offset[4][4]
void WM_event_add_mousemove(wmWindow *win)
void WM_gizmo_calc_matrix_final(const wmGizmo *gz, float r_mat[4][4])
void WM_gizmo_calc_matrix_final_no_offset(const wmGizmo *gz, float r_mat[4][4])
void WM_gizmo_target_property_float_get_array(const wmGizmo *gz, wmGizmoProperty *gz_prop, float *value)
int WM_gizmo_target_property_array_length(const wmGizmo *, wmGizmoProperty *gz_prop)
void WM_gizmotype_target_property_def(wmGizmoType *gzt, const char *idname, int data_type, int array_length)
void WM_gizmo_target_property_float_set_array(bContext *C, const wmGizmo *gz, wmGizmoProperty *gz_prop, const float *value)
wmGizmoProperty * WM_gizmo_target_property_find(wmGizmo *gz, const char *idname)
void WM_gizmotype_append(void(*gtfunc)(wmGizmoType *))