[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [18927] branches/blender2.5/blender/source /blender/editors/armature: First operator done as a test and to get to know the ropes.
Roland Hess
me at harkyman.com
Wed Feb 11 17:17:34 CET 2009
Revision: 18927
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=18927
Author: harkyman
Date: 2009-02-11 17:17:34 +0100 (Wed, 11 Feb 2009)
Log Message:
-----------
First operator done as a test and to get to know the ropes. "Select Parent" in pose mode. Had to move the command to Shift-P, as naked P is taken up by some crazy person's script command.
Modified Paths:
--------------
branches/blender2.5/blender/source/blender/editors/armature/armature_intern.h
branches/blender2.5/blender/source/blender/editors/armature/armature_ops.c
branches/blender2.5/blender/source/blender/editors/armature/editarmature.c
Modified: branches/blender2.5/blender/source/blender/editors/armature/armature_intern.h
===================================================================
--- branches/blender2.5/blender/source/blender/editors/armature/armature_intern.h 2009-02-11 14:56:35 UTC (rev 18926)
+++ branches/blender2.5/blender/source/blender/editors/armature/armature_intern.h 2009-02-11 16:17:34 UTC (rev 18927)
@@ -49,6 +49,7 @@
void POSE_OT_loc_clear(struct wmOperatorType *ot);
void POSE_OT_scale_clear(struct wmOperatorType *ot);
void POSE_OT_de_select_all(struct wmOperatorType *ot);
+void POSE_OT_select_parent(struct wmOperatorType *ot);
#endif /* ED_ARMATURE_INTERN_H */
Modified: branches/blender2.5/blender/source/blender/editors/armature/armature_ops.c
===================================================================
--- branches/blender2.5/blender/source/blender/editors/armature/armature_ops.c 2009-02-11 14:56:35 UTC (rev 18926)
+++ branches/blender2.5/blender/source/blender/editors/armature/armature_ops.c 2009-02-11 16:17:34 UTC (rev 18927)
@@ -129,6 +129,8 @@
WM_operatortype_append(POSE_OT_scale_clear);
WM_operatortype_append(POSE_OT_de_select_all);
+
+ WM_operatortype_append(POSE_OT_select_parent);
WM_operatortype_append(ARMATURE_OT_test); // XXX temp test for context iterators... to be removed
}
@@ -172,5 +174,7 @@
WM_keymap_add_item(keymap, "POSE_OT_scale_clear", SKEY, KM_PRESS, KM_ALT, 0);
WM_keymap_add_item(keymap, "POSE_OT_de_select_all", AKEY, KM_PRESS, 0, 0);
+
+ WM_keymap_add_item(keymap, "POSE_OT_select_parent", PKEY, KM_PRESS, KM_SHIFT, 0);
}
Modified: branches/blender2.5/blender/source/blender/editors/armature/editarmature.c
===================================================================
--- branches/blender2.5/blender/source/blender/editors/armature/editarmature.c 2009-02-11 14:56:35 UTC (rev 18926)
+++ branches/blender2.5/blender/source/blender/editors/armature/editarmature.c 2009-02-11 16:17:34 UTC (rev 18927)
@@ -4421,6 +4421,43 @@
ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO;
}
+
+static int pose_select_parent_exec(bContext *C, wmOperator *op)
+{
+ Object *ob= CTX_data_active_object(C);
+ bArmature *arm= ob->data;
+ bPoseChannel *pchan,*parent;
+
+ /* Determine if there is an active bone */
+ pchan=CTX_data_active_pchan(C);
+ if (pchan) {
+ parent=pchan->parent;
+ if ((parent) && !(parent->bone->flag & BONE_HIDDEN_P)) {
+ parent->bone->flag |= BONE_SELECTED;
+ parent->bone->flag |= BONE_ACTIVE;
+ pchan->bone->flag &= ~BONE_ACTIVE;
+ }
+ }
+
+ WM_event_add_notifier(C, NC_OBJECT|ND_BONE_SELECT, NULL);
+
+ return OPERATOR_FINISHED;
+}
+
+void POSE_OT_select_parent(wmOperatorType *ot)
+{
+ /* identifiers */
+ ot->name= "select parent bone";
+ ot->idname= "POSE_OT_select_parent";
+
+ /* api callbacks */
+ ot->exec= pose_select_parent_exec;
+ ot->poll= ED_operator_posemode;
+
+ /* flags */
+ ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO;
+
+}
/* ************* hide/unhide pose bones ******************* */
static int hide_selected_pose_bone(Object *ob, Bone *bone, void *ptr)
More information about the Bf-blender-cvs
mailing list