diff options
author | Germano Cavalcante <germano.costa@ig.com.br> | 2022-08-08 18:37:53 +0300 |
---|---|---|
committer | Germano Cavalcante <germano.costa@ig.com.br> | 2022-08-08 18:37:53 +0300 |
commit | 1e57ddf6eadcb4327f2689fb34f07fc5bf72331c (patch) | |
tree | 07d91ef8df7eefb9a0adfccc2a7ad50a0f9b6160 /source | |
parent | 8d080013f561f0084d8d937c9855c41be63170a4 (diff) | |
parent | b3fc8206be422a7d0155f0282c2493887e441dd3 (diff) |
Merge branch 'blender-v3.3-release'
Diffstat (limited to 'source')
5 files changed, 23 insertions, 109 deletions
diff --git a/source/blender/editors/transform/transform.c b/source/blender/editors/transform/transform.c index bb1776e2756..8dcbf07b776 100644 --- a/source/blender/editors/transform/transform.c +++ b/source/blender/editors/transform/transform.c @@ -641,48 +641,10 @@ static bool transform_modal_item_poll(const wmOperator *op, int value) } case TFM_MODAL_TRANSLATE: case TFM_MODAL_ROTATE: - case TFM_MODAL_RESIZE: - case TFM_MODAL_VERT_EDGE_SLIDE: - case TFM_MODAL_TRACKBALL: { + case TFM_MODAL_RESIZE: { if (!transform_mode_is_changeable(t->mode)) { return false; } - if (value == TFM_MODAL_TRANSLATE && t->mode == TFM_TRANSLATION) { - return false; - } - if (value == TFM_MODAL_ROTATE && t->mode == TFM_ROTATION) { - return false; - } - if (value == TFM_MODAL_RESIZE && t->mode == TFM_RESIZE) { - return false; - } - if (value == TFM_MODAL_VERT_EDGE_SLIDE && - (t->data_type != &TransConvertType_Mesh || - /* WORKAROUND: Avoid repeated keys in status bar. - * - * Previously, `Vert/Edge Slide` and `Move` were triggered by the same modal key. - * But now, to fix T100129, `Vert/Edge Slide` has its own modal key. - * However by default it uses the same key as `Move` (G). - * So, to avoid displaying the same key twice (G and G), only display this modal key - * during the `Move` operation. - * - * Ideally we should check if it really uses the same key. */ - t->mode != TFM_TRANSLATION)) { - return false; - } - if (value == TFM_MODAL_TRACKBALL && - /* WORKAROUND: Avoid repeated keys in status bar. - * - * Previously, `Trackball` and `Rotate` were triggered by the same modal key. - * But now, to fix T100129, `Trackball` has its own modal key. - * However by default it uses the same key as `Rotate` (R). - * So, to avoid displaying the same key twice (R and R), only display this modal key - * during the `Rotate` operation. - * - * Ideally we should check if it really uses the same key. */ - t->mode != TFM_ROTATION) { - return false; - } break; } } @@ -729,9 +691,7 @@ wmKeyMap *transform_modal_keymap(wmKeyConfig *keyconf) "Toggle Direction for Node Auto-Offset", ""}, {TFM_MODAL_TRANSLATE, "TRANSLATE", 0, "Move", ""}, - {TFM_MODAL_VERT_EDGE_SLIDE, "VERT_EDGE_SLIDE", 0, "Vert/Edge Slide", ""}, {TFM_MODAL_ROTATE, "ROTATE", 0, "Rotate", ""}, - {TFM_MODAL_TRACKBALL, "TRACKBALL", 0, "TrackBall", ""}, {TFM_MODAL_RESIZE, "RESIZE", 0, "Resize", ""}, {TFM_MODAL_AUTOCONSTRAINT, "AUTOCONSTRAIN", 0, "Automatic Constraint", ""}, {TFM_MODAL_AUTOCONSTRAINTPLANE, "AUTOCONSTRAINPLANE", 0, "Automatic Constraint Plane", ""}, @@ -974,15 +934,8 @@ int transformEvent(TransInfo *t, const wmEvent *event) handled = true; break; case TFM_MODAL_TRANSLATE: - case TFM_MODAL_VERT_EDGE_SLIDE: /* only switch when... */ - if (!transform_mode_is_changeable(t->mode)) { - break; - } - if (event->val == TFM_MODAL_VERT_EDGE_SLIDE) { - if (ELEM(t->mode, TFM_VERT_SLIDE, TFM_EDGE_SLIDE)) { - break; - } + if (t->mode == TFM_TRANSLATION) { if ((t->obedit_type == OB_MESH) && (t->spacetype == SPACE_VIEW3D)) { restoreTransObjects(t); resetTransModal(t); @@ -1008,11 +961,15 @@ int transformEvent(TransInfo *t, const wmEvent *event) t->redraw |= TREDRAW_HARD; handled = true; } - } - else { - if (t->mode == TFM_TRANSLATION) { - break; + else if (t->options & (CTX_MOVIECLIP | CTX_MASK)) { + restoreTransObjects(t); + + t->flag ^= T_ALT_TRANSFORM; + t->redraw |= TREDRAW_HARD; + handled = true; } + } + else if (transform_mode_is_changeable(t->mode)) { restoreTransObjects(t); resetTransModal(t); resetTransRestrictions(t); @@ -1023,33 +980,23 @@ int transformEvent(TransInfo *t, const wmEvent *event) } break; case TFM_MODAL_ROTATE: - case TFM_MODAL_TRACKBALL: /* only switch when... */ - if (!transform_mode_is_changeable(t->mode)) { - break; - } - if (event->val == TFM_MODAL_TRACKBALL) { - if (t->mode == TFM_TRACKBALL) { - break; - } - } - else if (t->mode == TFM_ROTATION) { - break; - } if (!(t->options & CTX_TEXTURE_SPACE) && !(t->options & (CTX_MOVIECLIP | CTX_MASK))) { - restoreTransObjects(t); - resetTransModal(t); - resetTransRestrictions(t); + if (transform_mode_is_changeable(t->mode)) { + restoreTransObjects(t); + resetTransModal(t); + resetTransRestrictions(t); - if (event->val == TFM_MODAL_TRACKBALL) { - transform_mode_init(t, NULL, TFM_TRACKBALL); - } - else { - transform_mode_init(t, NULL, TFM_ROTATION); + if (t->mode == TFM_ROTATION) { + transform_mode_init(t, NULL, TFM_TRACKBALL); + } + else { + transform_mode_init(t, NULL, TFM_ROTATION); + } + initSnapping(t, NULL); /* need to reinit after mode change */ + t->redraw |= TREDRAW_HARD; + handled = true; } - initSnapping(t, NULL); /* need to reinit after mode change */ - t->redraw |= TREDRAW_HARD; - handled = true; } break; case TFM_MODAL_RESIZE: diff --git a/source/blender/editors/transform/transform.h b/source/blender/editors/transform/transform.h index fee6acfbfa7..fc59787e1ec 100644 --- a/source/blender/editors/transform/transform.h +++ b/source/blender/editors/transform/transform.h @@ -253,9 +253,6 @@ enum { TFM_MODAL_AUTOCONSTRAINTPLANE = 29, TFM_MODAL_PRECISION = 30, - - TFM_MODAL_VERT_EDGE_SLIDE = 31, - TFM_MODAL_TRACKBALL = 32, }; /** \} */ diff --git a/source/blender/editors/transform/transform_mode_resize.c b/source/blender/editors/transform/transform_mode_resize.c index fc569f5cf67..70599c3577c 100644 --- a/source/blender/editors/transform/transform_mode_resize.c +++ b/source/blender/editors/transform/transform_mode_resize.c @@ -282,7 +282,6 @@ void initResize(TransInfo *t, float mouse_dir_constraint[3]) { t->mode = TFM_RESIZE; t->transform = applyResize; - t->handleEvent = NULL; t->tsnap.applySnap = ApplySnapResize; t->tsnap.distance = ResizeBetween; diff --git a/source/blender/editors/transform/transform_mode_rotate.c b/source/blender/editors/transform/transform_mode_rotate.c index ece9fe8855f..a7207b36578 100644 --- a/source/blender/editors/transform/transform_mode_rotate.c +++ b/source/blender/editors/transform/transform_mode_rotate.c @@ -351,7 +351,6 @@ void initRotation(TransInfo *t) t->mode = TFM_ROTATION; t->transform = applyRotation; - t->handleEvent = NULL; t->transform_matrix = applyRotationMatrix; t->tsnap.applySnap = ApplySnapRotation; t->tsnap.distance = RotationBetween; diff --git a/source/blender/editors/transform/transform_mode_translate.c b/source/blender/editors/transform/transform_mode_translate.c index 32c2e5e3bb0..8f6ec7bd98f 100644 --- a/source/blender/editors/transform/transform_mode_translate.c +++ b/source/blender/editors/transform/transform_mode_translate.c @@ -56,8 +56,6 @@ struct TranslateCustomData { struct { enum eTranslateRotateMode rotate_mode; } prev; - - const wmKeyMapItem *move_kmi; }; /** \} */ @@ -172,27 +170,6 @@ static void transdata_elem_translate_fn(void *__restrict iter_data_v, /** \} */ /* -------------------------------------------------------------------- */ -/** \name Events to Move Clip and Mask - * \{ */ - -static eRedrawFlag translate_handleEvent(struct TransInfo *t, const wmEvent *event) -{ - BLI_assert(t->options & (CTX_MOVIECLIP | CTX_MASK)); - struct TranslateCustomData *custom_data = t->custom.mode.data; - const wmKeyMapItem *kmi = custom_data->move_kmi; - if (kmi && event->type == kmi->type && event->val == kmi->val) { - /* Toggles the handle offset effect. */ - restoreTransObjects(t); - - t->flag ^= T_ALT_TRANSFORM; - return TREDRAW_HARD; - } - return TREDRAW_NOTHING; -} - -/** \} */ - -/* -------------------------------------------------------------------- */ /** \name Transform (Translation) * \{ */ @@ -637,11 +614,6 @@ void initTranslation(TransInfo *t) custom_data->prev.rotate_mode = TRANSLATE_ROTATE_OFF; t->custom.mode.data = custom_data; t->custom.mode.use_free = true; - - if (t->keymap && (t->options & (CTX_MOVIECLIP | CTX_MASK))) { - custom_data->move_kmi = WM_modalkeymap_find_propvalue(t->keymap, TFM_MODAL_TRANSLATE); - t->handleEvent = translate_handleEvent; - } } /** \} */ |