diff options
author | Ton Roosendaal <ton@blender.org> | 2009-02-18 17:13:06 +0300 |
---|---|---|
committer | Ton Roosendaal <ton@blender.org> | 2009-02-18 17:13:06 +0300 |
commit | 1a9e68bde5cfffda011297465474f5596d5bce84 (patch) | |
tree | d32239f4e2c5578befc25890cbdf854a613a2e38 /source/blender/editors/armature | |
parent | 1090b0c598712a8375e6189447b461ddd3d781b6 (diff) |
2.5
Patch from Arystan:
- bugfix in mouse select posemode
- Lkey 'select linked' for both pose as editmode armature.
Diffstat (limited to 'source/blender/editors/armature')
-rw-r--r-- | source/blender/editors/armature/armature_intern.h | 2 | ||||
-rw-r--r-- | source/blender/editors/armature/armature_ops.c | 6 | ||||
-rw-r--r-- | source/blender/editors/armature/editarmature.c | 94 |
3 files changed, 85 insertions, 17 deletions
diff --git a/source/blender/editors/armature/armature_intern.h b/source/blender/editors/armature/armature_intern.h index c8ca85fc08b..6ca92f35644 100644 --- a/source/blender/editors/armature/armature_intern.h +++ b/source/blender/editors/armature/armature_intern.h @@ -44,6 +44,7 @@ void ARMATURE_OT_parent_clear(struct wmOperatorType *ot); void ARMATURE_OT_de_select_all(struct wmOperatorType *ot); void ARMATURE_OT_selection_invert(struct wmOperatorType *ot); void ARMATURE_OT_select_hierarchy(struct wmOperatorType *ot); +void ARMATURE_OT_select_connected(struct wmOperatorType *ot); void POSE_OT_hide(struct wmOperatorType *ot); void POSE_OT_reveal(struct wmOperatorType *ot); @@ -54,6 +55,7 @@ void POSE_OT_de_select_all(struct wmOperatorType *ot); void POSE_OT_selection_invert(struct wmOperatorType *ot); void POSE_OT_select_parent(struct wmOperatorType *ot); void POSE_OT_select_hierarchy(struct wmOperatorType *ot); +void POSE_OT_select_connected(struct wmOperatorType *ot); #endif /* ED_ARMATURE_INTERN_H */ diff --git a/source/blender/editors/armature/armature_ops.c b/source/blender/editors/armature/armature_ops.c index 7902f932858..51d46bb70bf 100644 --- a/source/blender/editors/armature/armature_ops.c +++ b/source/blender/editors/armature/armature_ops.c @@ -123,6 +123,7 @@ void ED_operatortypes_armature(void) WM_operatortype_append(ARMATURE_OT_de_select_all); WM_operatortype_append(ARMATURE_OT_selection_invert); WM_operatortype_append(ARMATURE_OT_select_hierarchy); + WM_operatortype_append(ARMATURE_OT_select_connected); /* POSE */ WM_operatortype_append(POSE_OT_hide); @@ -137,6 +138,7 @@ void ED_operatortypes_armature(void) WM_operatortype_append(POSE_OT_select_parent); WM_operatortype_append(POSE_OT_select_hierarchy); + WM_operatortype_append(POSE_OT_select_connected); WM_operatortype_append(ARMATURE_OT_test); // XXX temp test for context iterators... to be removed } @@ -181,6 +183,8 @@ void ED_keymap_armature(wmWindowManager *wm) kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, KM_SHIFT, 0); RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD); RNA_boolean_set(kmi->ptr, "add_to_sel", 1); + + WM_keymap_add_item(keymap, "ARMATURE_OT_select_connected", LKEY, KM_PRESS, 0, 0); /* Pose ------------------------ */ /* only set in posemode, by space_view3d listener */ @@ -213,5 +217,7 @@ void ED_keymap_armature(wmWindowManager *wm) kmi= WM_keymap_add_item(keymap, "POSE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, KM_SHIFT, 0); RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD); RNA_boolean_set(kmi->ptr, "add_to_sel", 1); + + WM_keymap_add_item(keymap, "POSE_OT_select_connected", LKEY, KM_PRESS, 0, 0); } diff --git a/source/blender/editors/armature/editarmature.c b/source/blender/editors/armature/editarmature.c index ad0fa0c1241..1778ca8fa45 100644 --- a/source/blender/editors/armature/editarmature.c +++ b/source/blender/editors/armature/editarmature.c @@ -1137,7 +1137,8 @@ static void *get_bone_from_selectbuffer(Scene *scene, Base *base, unsigned int * /* used by posemode as well editmode */ /* only checks scene->basact! */ -static void *get_nearest_bone (bContext *C, short findunsel) +/* x and y are mouse coords (area space) */ +static void *get_nearest_bone (bContext *C, short findunsel, int x, int y) { ViewContext vc; rcti rect; @@ -1147,6 +1148,8 @@ static void *get_nearest_bone (bContext *C, short findunsel) view3d_set_viewcontext(C, &vc); // rect.xmin= ... mouseco! + rect.xmin= rect.xmax= x; + rect.ymin= rect.ymax= y; glInitNames(); hits= view3d_opengl_select(&vc, buffer, MAXPICKBUF, &rect); @@ -1293,19 +1296,29 @@ static void selectconnected_posebonechildren (Object *ob, Bone *bone) } /* within active object context */ -void selectconnected_posearmature(bContext *C) -{ - Object *ob= CTX_data_edit_object(C); +/* previously known as "selectconnected_posearmature" */ +static int pose_select_connected_invoke(bContext *C, wmOperator *op, wmEvent *event) +{ Bone *bone, *curBone, *next; - int shift= 0; // XXX + int shift= 0; // XXX in pose mode, Shift+L is bound to another command + // named "PoseLib Add Current Pose" + int x, y; + ARegion *ar; + Object *ob= CTX_data_edit_object(C); + ar= CTX_wm_region(C); + + x= event->x - ar->winrct.xmin; + y= event->y - ar->winrct.ymin; + + view3d_operator_needs_opengl(C); if (shift) - bone= get_nearest_bone(C, 0); + bone= get_nearest_bone(C, 0, x, y); else - bone = get_nearest_bone(C, 1); + bone= get_nearest_bone(C, 1, x, y); if (!bone) - return; + return OPERATOR_CANCELLED; /* Select parents */ for (curBone=bone; curBone; curBone=next){ @@ -1327,31 +1340,58 @@ void selectconnected_posearmature(bContext *C) selectconnected_posebonechildren (ob, curBone); } - // XXX this only counted the number of pose channels selected + // XXX this only counted the number of pose channels selected //countall(); // flushes selection! + WM_event_add_notifier(C, NC_OBJECT|ND_BONE_SELECT, ob); - BIF_undo_push("Select connected"); + return OPERATOR_FINISHED; +} +void POSE_OT_select_connected(wmOperatorType *ot) +{ + /* identifiers */ + ot->name= "Select Connected"; + ot->idname= "POSE_OT_select_connected"; + + /* api callbacks */ + ot->exec= NULL; + ot->invoke= pose_select_connected_invoke; + ot->poll= ED_operator_posemode; + + /* flags */ + ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; + + /* props */ } /* **************** END Posemode stuff ********************** */ /* **************** EditMode stuff ********************** */ /* called in space.c */ -void selectconnected_armature(bContext *C) +/* previously "selectconnected_armature" */ +static int armature_select_connected_invoke(bContext *C, wmOperator *op, wmEvent *event) { - Object *obedit= CTX_data_edit_object(C); - bArmature *arm= obedit->data; + bArmature *arm; EditBone *bone, *curBone, *next; int shift= 0; // XXX + int x, y; + ARegion *ar; + Object *obedit= CTX_data_edit_object(C); + arm= obedit->data; + ar= CTX_wm_region(C); + + x= event->x - ar->winrct.xmin; + y= event->y - ar->winrct.ymin; + + view3d_operator_needs_opengl(C); if (shift) - bone= get_nearest_bone(C, 0); + bone= get_nearest_bone(C, 0, x, y); else - bone= get_nearest_bone(C, 1); + bone= get_nearest_bone(C, 1, x, y); if (!bone) - return; + return OPERATOR_CANCELLED; /* Select parents */ for (curBone=bone; curBone; curBone=next){ @@ -1394,8 +1434,28 @@ void selectconnected_armature(bContext *C) armature_sync_selection(arm->edbo); - BIF_undo_push("Select connected"); + /* BIF_undo_push("Select connected"); */ + + WM_event_add_notifier(C, NC_OBJECT|ND_BONE_SELECT, obedit); + return OPERATOR_FINISHED; +} + +void ARMATURE_OT_select_connected(wmOperatorType *ot) +{ + /* identifiers */ + ot->name= "Select Connected"; + ot->idname= "ARMATURE_OT_select_connected"; + + /* api callbacks */ + ot->exec= NULL; + ot->invoke= armature_select_connected_invoke; + ot->poll= ED_operator_editarmature; + + /* flags */ + ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; + + /* props */ } /* does bones and points */ |