svn merge -r 21041:21301 https://svn.blender.org/svnroot/bf-blender/branches/blender2...
[blender.git] / source / blender / editors / space_time / space_time.c
index 3c4152366ee5ece999a7cfa573f64da5b613e2a2..c4ca4d8522fafe151d14fb019e5015f6a57b677b 100644 (file)
@@ -38,6 +38,7 @@
 
 #include "BLI_blenlib.h"
 
+#include "BKE_context.h"
 #include "BKE_global.h"
 #include "BKE_screen.h"
 
@@ -64,7 +65,7 @@
 /* draws a current frame indicator for the TimeLine */
 static void time_draw_cfra_time(const bContext *C, SpaceTime *stime, ARegion *ar)
 {
-       Scene *scene= C->scene;
+       Scene *scene= CTX_data_scene(C);
        float vec[2];
        
        vec[0]= scene->r.cfra*scene->r.framelen;
@@ -84,15 +85,16 @@ static void time_draw_cfra_time(const bContext *C, SpaceTime *stime, ARegion *ar
 
 static void time_draw_sfra_efra(const bContext *C, SpaceTime *stime, ARegion *ar)
 {
-    View2D *v2d= UI_view2d_fromcontext(C);
+       View2D *v2d= UI_view2d_fromcontext(C);
+       Scene *scene= CTX_data_scene(C);
        
        /* draw darkened area outside of active timeline 
         * frame range used is preview range or scene range */
        UI_ThemeColorShade(TH_BACK, -25);
 
        if (PSFRA < PEFRA) {
-               glRectf(v2d->cur.xmin, v2d->cur.ymin, PSFRA, v2d->cur.ymax);
-               glRectf(PEFRA, v2d->cur.ymin, v2d->cur.xmax, v2d->cur.ymax);
+               glRectf(v2d->cur.xmin, v2d->cur.ymin, (float)PSFRA, v2d->cur.ymax);
+               glRectf((float)PEFRA, v2d->cur.ymin, v2d->cur.xmax, v2d->cur.ymax);
        }
        else {
                glRectf(v2d->cur.xmin, v2d->cur.ymin, v2d->cur.xmax, v2d->cur.ymax);
@@ -100,8 +102,8 @@ static void time_draw_sfra_efra(const bContext *C, SpaceTime *stime, ARegion *ar
 
        UI_ThemeColorShade(TH_BACK, -60);
        /* thin lines where the actual frames are */
-       fdrawline(PSFRA, v2d->cur.ymin, PSFRA, v2d->cur.ymax);
-       fdrawline(PEFRA, v2d->cur.ymin, PEFRA, v2d->cur.ymax);
+       fdrawline((float)PSFRA, v2d->cur.ymin, (float)PSFRA, v2d->cur.ymax);
+       fdrawline((float)PEFRA, v2d->cur.ymin, (float)PEFRA, v2d->cur.ymax);
 }
 
 /* add handlers, stuff you only do once or on area/region changes */
@@ -120,7 +122,7 @@ static void time_main_area_init(wmWindowManager *wm, ARegion *ar)
 static void time_main_area_draw(const bContext *C, ARegion *ar)
 {
        /* draw entirely, view changes should be handled here */
-       SpaceTime *stime= C->area->spacedata.first;
+       SpaceTime *stime= (SpaceTime*)CTX_wm_space_data(C);
        View2D *v2d= &ar->v2d;
        View2DGrid *grid;
        View2DScrollers *scrollers;
@@ -162,9 +164,10 @@ static void time_main_area_draw(const bContext *C, ARegion *ar)
 static void time_main_area_listener(ARegion *ar, wmNotifier *wmn)
 {
        /* context changes */
-       switch(wmn->type) {
+       switch(wmn->category) {
                
-               case WM_NOTE_MARKERS_CHANGED:
+               case NC_SCENE:
+                       /* any scene change for now */
                        ED_region_tag_redraw(ar);
                        break;
        }
@@ -200,11 +203,29 @@ static void time_header_area_draw(const bContext *C, ARegion *ar)
        UI_view2d_view_restore(C);
 }
 
+static void time_header_area_listener(ARegion *ar, wmNotifier *wmn)
+{
+       /* context changes */
+       switch(wmn->category) {
+               case NC_SCREEN:
+                       if(wmn->data==ND_ANIMPLAY)
+                               ED_region_tag_redraw(ar);
+                       break;
+               case NC_SCENE:
+                       switch (wmn->data) {
+                               case ND_FRAME:
+                               case ND_KEYINGSET:
+                                       ED_region_tag_redraw(ar);
+                               break;
+                       }
+       }
+}
 
 /* ******************** default callbacks for time space ***************** */
 
-static SpaceLink *time_new(void)
+static SpaceLink *time_new(const bContext *C)
 {
+       Scene *scene= CTX_data_scene(C);
        ARegion *ar;
        SpaceTime *stime;
 
@@ -294,7 +315,7 @@ void ED_spacetype_time(void)
        /* regions: main window */
        art= MEM_callocN(sizeof(ARegionType), "spacetype time region");
        art->regionid = RGN_TYPE_WINDOW;
-       art->keymapflag= ED_KEYMAP_VIEW2D|ED_KEYMAP_MARKERS;
+       art->keymapflag= ED_KEYMAP_VIEW2D|ED_KEYMAP_MARKERS|ED_KEYMAP_ANIMATION|ED_KEYMAP_FRAMES;
        
        art->init= time_main_area_init;
        art->draw= time_main_area_draw;
@@ -310,6 +331,7 @@ void ED_spacetype_time(void)
        
        art->init= time_header_area_init;
        art->draw= time_header_area_draw;
+       art->listener= time_header_area_listener;
        BLI_addhead(&st->regiontypes, art);
                
        BKE_spacetype_register(st);