Revision: 49238
          
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=49238
Author:   nazgul
Date:     2012-07-26 09:50:27 +0000 (Thu, 26 Jul 2012)
Log Message:
-----------
Shortcuts to set solver frames: alt-1 for Keyframe A, alt-2 for keyframe B.

Modified Paths:
--------------
    trunk/blender/source/blender/editors/space_clip/clip_intern.h
    trunk/blender/source/blender/editors/space_clip/space_clip.c
    trunk/blender/source/blender/editors/space_clip/tracking_ops.c

Modified: trunk/blender/source/blender/editors/space_clip/clip_intern.h
===================================================================
--- trunk/blender/source/blender/editors/space_clip/clip_intern.h       
2012-07-26 09:35:52 UTC (rev 49237)
+++ trunk/blender/source/blender/editors/space_clip/clip_intern.h       
2012-07-26 09:50:27 UTC (rev 49238)
@@ -150,6 +150,8 @@
 void CLIP_OT_hide_tracks_clear(struct wmOperatorType *ot);
 void CLIP_OT_lock_tracks(struct wmOperatorType *ot);
 
+void CLIP_OT_set_solver_keyframe(struct wmOperatorType *ot);
+
 void CLIP_OT_set_origin(struct wmOperatorType *ot);
 void CLIP_OT_set_plane(struct wmOperatorType *ot);
 void CLIP_OT_set_axis(struct wmOperatorType *ot);

Modified: trunk/blender/source/blender/editors/space_clip/space_clip.c
===================================================================
--- trunk/blender/source/blender/editors/space_clip/space_clip.c        
2012-07-26 09:35:52 UTC (rev 49237)
+++ trunk/blender/source/blender/editors/space_clip/space_clip.c        
2012-07-26 09:50:27 UTC (rev 49238)
@@ -477,6 +477,8 @@
        WM_operatortype_append(CLIP_OT_hide_tracks_clear);
        WM_operatortype_append(CLIP_OT_lock_tracks);
 
+       WM_operatortype_append(CLIP_OT_set_solver_keyframe);
+
        /* orientation */
        WM_operatortype_append(CLIP_OT_set_origin);
        WM_operatortype_append(CLIP_OT_set_plane);
@@ -562,6 +564,12 @@
 
        WM_keymap_add_item(keymap, "CLIP_OT_solve_camera", SKEY, KM_PRESS, 
KM_SHIFT, 0);
 
+       kmi = WM_keymap_add_item(keymap, "CLIP_OT_set_solver_keyframe", ONEKEY, 
KM_PRESS, KM_ALT, 0);
+       RNA_enum_set(kmi->ptr, "keyframe", 0);
+
+       kmi = WM_keymap_add_item(keymap, "CLIP_OT_set_solver_keyframe", TWOKEY, 
KM_PRESS, KM_ALT, 0);
+       RNA_enum_set(kmi->ptr, "keyframe", 1);
+
        /* ******** Hotkeys avalaible for main region only ******** */
 
        keymap = WM_keymap_find(keyconf, "Clip Editor", SPACE_CLIP, 0);

Modified: trunk/blender/source/blender/editors/space_clip/tracking_ops.c
===================================================================
--- trunk/blender/source/blender/editors/space_clip/tracking_ops.c      
2012-07-26 09:35:52 UTC (rev 49237)
+++ trunk/blender/source/blender/editors/space_clip/tracking_ops.c      
2012-07-26 09:50:27 UTC (rev 49238)
@@ -2842,6 +2842,49 @@
        RNA_def_enum(ot->srna, "action", actions_items, 0, "Action", "Lock 
action to execute");
 }
 
+/********************** set keyframe operator *********************/
+
+static int set_solver_keyframe_exec(bContext *C, wmOperator *op)
+{
+       SpaceClip *sc = CTX_wm_space_clip(C);
+       MovieClip *clip = ED_space_clip_get_clip(sc);
+       MovieTracking *tracking = &clip->tracking;
+       MovieTrackingSettings *settings = &tracking->settings;
+       int keyframe = RNA_enum_get(op->ptr, "keyframe");
+       int framenr = BKE_movieclip_remap_scene_to_clip_frame(clip, 
sc->user.framenr);
+
+       if (keyframe == 0)
+               settings->keyframe1 = framenr;
+       else
+               settings->keyframe2 = framenr;
+
+       return OPERATOR_FINISHED;
+}
+
+void CLIP_OT_set_solver_keyframe(wmOperatorType *ot)
+{
+       static EnumPropertyItem keyframe_items[] = {
+               {0, "KEYFRAME_A", 0, "Keyframe A", ""},
+               {1, "KEYFRAME_B", 0, "Keyframe B", ""},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       /* identifiers */
+       ot->name = "Set Selver Keyframe";
+       ot->description = "Set keyframe used by solver";
+       ot->idname = "CLIP_OT_set_solver_keyframe";
+
+       /* api callbacks */
+       ot->exec = set_solver_keyframe_exec;
+       ot->poll = ED_space_clip_tracking_poll;
+
+       /* flags */
+       ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+
+       /* properties */
+       RNA_def_enum(ot->srna, "keyframe", keyframe_items, 0, "Keyframe", 
"keyframe to set");
+}
+
 /********************** track copy color operator *********************/
 
 static int track_copy_color_exec(bContext *C, wmOperator *UNUSED(op))

_______________________________________________
Bf-blender-cvs mailing list
[email protected]
http://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to