Merge branch 'master' into blender2.8
[blender.git] / source / blender / editors / space_clip / space_clip.c
index 58930fa..f022bb7 100644 (file)
@@ -51,6 +51,7 @@
 
 #include "IMB_imbuf_types.h"
 
+#include "ED_anim_api.h" /* for timeline cursor drawing */
 #include "ED_mask.h"
 #include "ED_space_api.h"
 #include "ED_screen.h"
@@ -60,7 +61,8 @@
 
 #include "IMB_imbuf.h"
 
-#include "BIF_gl.h"
+#include "GPU_glew.h"
+#include "GPU_matrix.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
 
 #include "clip_intern.h"  /* own include */
 
-static void init_preview_region(const bContext *C, ARegion *ar)
+static void init_preview_region(const Scene *scene, const ScrArea *sa, const SpaceClip *sc, ARegion *ar)
 {
-       Scene *scene = CTX_data_scene(C);
-       ScrArea *sa = CTX_wm_area(C);
-       SpaceClip *sc = CTX_wm_space_clip(C);
-
        ar->regiontype = RGN_TYPE_PREVIEW;
        ar->alignment = RGN_ALIGN_TOP;
        ar->flag |= RGN_FLAG_HIDDEN;
@@ -137,15 +135,17 @@ static void init_preview_region(const bContext *C, ARegion *ar)
 
 static void reinit_preview_region(const bContext *C, ARegion *ar)
 {
+       Scene *scene = CTX_data_scene(C);
+       ScrArea *sa = CTX_wm_area(C);
        SpaceClip *sc = CTX_wm_space_clip(C);
 
        if (sc->view == SC_VIEW_DOPESHEET) {
                if ((ar->v2d.flag & V2D_VIEWSYNC_AREA_VERTICAL) == 0)
-                       init_preview_region(C, ar);
+                       init_preview_region(scene, sa, sc, ar);
        }
        else {
                if (ar->v2d.flag & V2D_VIEWSYNC_AREA_VERTICAL)
-                       init_preview_region(C, ar);
+                       init_preview_region(scene, sa, sc, ar);
        }
 }
 
@@ -167,7 +167,7 @@ static ARegion *ED_clip_has_preview_region(const bContext *C, ScrArea *sa)
        arnew = MEM_callocN(sizeof(ARegion), "clip preview region");
 
        BLI_insertlinkbefore(&sa->regionbase, ar, arnew);
-       init_preview_region(C, arnew);
+       init_preview_region(CTX_data_scene(C), sa, CTX_wm_space_clip(C), arnew);
 
        return arnew;
 }
@@ -227,7 +227,7 @@ static void clip_scopes_check_gpencil_change(ScrArea *sa)
 
 /* ******************** default callbacks for clip space ***************** */
 
-static SpaceLink *clip_new(const bContext *C)
+static SpaceLink *clip_new(const ScrArea *sa, const Scene *scene)
 {
        ARegion *ar;
        SpaceClip *sc;
@@ -246,7 +246,7 @@ static SpaceLink *clip_new(const bContext *C)
 
        BLI_addtail(&sc->regionbase, ar);
        ar->regiontype = RGN_TYPE_HEADER;
-       ar->alignment = RGN_ALIGN_BOTTOM;
+       ar->alignment = RGN_ALIGN_TOP;
 
        /* tools view */
        ar = MEM_callocN(sizeof(ARegion), "tools for clip");
@@ -255,13 +255,6 @@ static SpaceLink *clip_new(const bContext *C)
        ar->regiontype = RGN_TYPE_TOOLS;
        ar->alignment = RGN_ALIGN_LEFT;
 
-       /* tool properties */
-       ar = MEM_callocN(sizeof(ARegion), "tool properties for clip");
-
-       BLI_addtail(&sc->regionbase, ar);
-       ar->regiontype = RGN_TYPE_TOOL_PROPS;
-       ar->alignment = RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV;
-
        /* properties view */
        ar = MEM_callocN(sizeof(ARegion), "properties for clip");
 
@@ -283,7 +276,7 @@ static SpaceLink *clip_new(const bContext *C)
        ar = MEM_callocN(sizeof(ARegion), "preview for clip");
 
        BLI_addtail(&sc->regionbase, ar);
-       init_preview_region(C, ar);
+       init_preview_region(scene, sa, sc, ar);
 
        /* main region */
        ar = MEM_callocN(sizeof(ARegion), "main region for clip");
@@ -329,7 +322,8 @@ static SpaceLink *clip_duplicate(SpaceLink *sl)
        return (SpaceLink *)scn;
 }
 
-static void clip_listener(bScreen *UNUSED(sc), ScrArea *sa, wmNotifier *wmn)
+static void clip_listener(bScreen *UNUSED(sc), ScrArea *sa, wmNotifier *wmn, Scene *UNUSED(scene),
+                          WorkSpace *UNUSED(workspace))
 {
        /* context changes */
        switch (wmn->category) {
@@ -887,12 +881,11 @@ static void clip_refresh(const bContext *C, ScrArea *sa)
        SpaceClip *sc = (SpaceClip *)sa->spacedata.first;
        ARegion *ar_main = BKE_area_find_region_type(sa, RGN_TYPE_WINDOW);
        ARegion *ar_tools = BKE_area_find_region_type(sa, RGN_TYPE_TOOLS);
-       ARegion *ar_tool_props = BKE_area_find_region_type(sa, RGN_TYPE_TOOL_PROPS);
        ARegion *ar_preview = ED_clip_has_preview_region(C, sa);
        ARegion *ar_properties = ED_clip_has_properties_region(sa);
        ARegion *ar_channels = ED_clip_has_channels_region(sa);
        bool main_visible = false, preview_visible = false, tools_visible = false;
-       bool tool_props_visible = false, properties_visible = false, channels_visible = false;
+       bool properties_visible = false, channels_visible = false;
        bool view_changed = false;
 
        switch (sc->view) {
@@ -900,7 +893,6 @@ static void clip_refresh(const bContext *C, ScrArea *sa)
                        main_visible = true;
                        preview_visible = false;
                        tools_visible = true;
-                       tool_props_visible = true;
                        properties_visible = true;
                        channels_visible = false;
                        break;
@@ -908,7 +900,6 @@ static void clip_refresh(const bContext *C, ScrArea *sa)
                        main_visible = false;
                        preview_visible = true;
                        tools_visible = false;
-                       tool_props_visible = false;
                        properties_visible = false;
                        channels_visible = false;
 
@@ -918,7 +909,6 @@ static void clip_refresh(const bContext *C, ScrArea *sa)
                        main_visible = false;
                        preview_visible = true;
                        tools_visible = false;
-                       tool_props_visible = false;
                        properties_visible = false;
                        channels_visible = true;
 
@@ -999,30 +989,6 @@ static void clip_refresh(const bContext *C, ScrArea *sa)
                }
        }
 
-       if (tool_props_visible) {
-               if (ar_tool_props && (ar_tool_props->flag & RGN_FLAG_HIDDEN)) {
-                       ar_tool_props->flag &= ~RGN_FLAG_HIDDEN;
-                       ar_tool_props->v2d.flag &= ~V2D_IS_INITIALISED;
-                       view_changed = true;
-               }
-               if (ar_tool_props && (ar_tool_props->alignment != (RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV))) {
-                       ar_tool_props->alignment = RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV;
-                       view_changed = true;
-               }
-       }
-       else {
-               if (ar_tool_props && !(ar_tool_props->flag & RGN_FLAG_HIDDEN)) {
-                       ar_tool_props->flag |= RGN_FLAG_HIDDEN;
-                       ar_tool_props->v2d.flag &= ~V2D_IS_INITIALISED;
-                       WM_event_remove_handlers((bContext *)C, &ar_tool_props->handlers);
-                       view_changed = true;
-               }
-               if (ar_tool_props && ar_tool_props->alignment != RGN_ALIGN_NONE) {
-                       ar_tool_props->alignment = RGN_ALIGN_NONE;
-                       view_changed = true;
-               }
-       }
-
        if (preview_visible) {
                if (ar_preview && (ar_preview->flag & RGN_FLAG_HIDDEN)) {
                        ar_preview->flag &= ~RGN_FLAG_HIDDEN;
@@ -1214,13 +1180,13 @@ static void clip_main_region_draw(const bContext *C, ARegion *ar)
        show_cursor |= sc->around == V3D_AROUND_CURSOR;
 
        if (show_cursor) {
-               glPushMatrix();
-               glTranslatef(x, y, 0);
-               glScalef(zoomx, zoomy, 0);
-               glMultMatrixf(sc->stabmat);
-               glScalef(width, height, 0);
+               gpuPushMatrix();
+               gpuTranslate2f(x, y);
+               gpuScale2f(zoomx, zoomy);
+               gpuMultMatrix(sc->stabmat);
+               gpuScale2f(width, height);
                ED_image_draw_cursor(ar, sc->cursor);
-               glPopMatrix();
+               gpuPopMatrix();
        }
 
        clip_draw_cache_and_notes(C, sc, ar);
@@ -1239,7 +1205,9 @@ static void clip_main_region_draw(const bContext *C, ARegion *ar)
        }
 }
 
-static void clip_main_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar, wmNotifier *wmn)
+static void clip_main_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar,
+        wmNotifier *wmn, const Scene *UNUSED(scene))
 {
        /* context changes */
        switch (wmn->category) {
@@ -1278,6 +1246,7 @@ static void graph_region_draw(const bContext *C, ARegion *ar)
        SpaceClip *sc = CTX_wm_space_clip(C);
        Scene *scene = CTX_data_scene(C);
        short unitx, unity;
+       short cfra_flag = 0;
 
        if (sc->flag & SC_LOCK_TIMECURSOR)
                ED_clip_graph_center_current_frame(scene, ar);
@@ -1291,6 +1260,10 @@ static void graph_region_draw(const bContext *C, ARegion *ar)
        /* data... */
        clip_draw_graph(sc, ar, scene);
 
+       /* current frame indicator line */
+       if (sc->flag & SC_SHOW_SECONDS) cfra_flag |= DRAWCFRA_UNIT_SECONDS;
+       ANIM_draw_cfra(C, v2d, cfra_flag);
+
        /* reset view matrix */
        UI_view2d_view_restore(C);
 
@@ -1300,6 +1273,11 @@ static void graph_region_draw(const bContext *C, ARegion *ar)
        scrollers = UI_view2d_scrollers_calc(C, v2d, unitx, V2D_GRID_NOCLAMP, unity, V2D_GRID_NOCLAMP);
        UI_view2d_scrollers_draw(C, v2d, scrollers);
        UI_view2d_scrollers_free(scrollers);
+
+       /* currnt frame indicator */
+       if (sc->flag & SC_SHOW_SECONDS) cfra_flag |= DRAWCFRA_UNIT_SECONDS;
+       UI_view2d_view_orthoSpecial(ar, v2d, 1);
+       ANIM_draw_cfra_number(C, v2d, cfra_flag);
 }
 
 static void dopesheet_region_draw(const bContext *C, ARegion *ar)
@@ -1310,7 +1288,7 @@ static void dopesheet_region_draw(const bContext *C, ARegion *ar)
        View2D *v2d = &ar->v2d;
        View2DGrid *grid;
        View2DScrollers *scrollers;
-       short unit = 0;
+       short unit = 0, cfra_flag = 0;
 
        if (clip)
                BKE_tracking_dopesheet_update(&clip->tracking);
@@ -1331,6 +1309,10 @@ static void dopesheet_region_draw(const bContext *C, ARegion *ar)
        /* data... */
        clip_draw_dopesheet_main(sc, ar, scene);
 
+       /* current frame indicator line */
+       if (sc->flag & SC_SHOW_SECONDS) cfra_flag |= DRAWCFRA_UNIT_SECONDS;
+       ANIM_draw_cfra(C, v2d, cfra_flag);
+
        /* reset view matrix */
        UI_view2d_view_restore(C);
 
@@ -1338,6 +1320,10 @@ static void dopesheet_region_draw(const bContext *C, ARegion *ar)
        scrollers = UI_view2d_scrollers_calc(C, v2d, unit, V2D_GRID_CLAMP, V2D_ARG_DUMMY, V2D_ARG_DUMMY);
        UI_view2d_scrollers_draw(C, v2d, scrollers);
        UI_view2d_scrollers_free(scrollers);
+
+       /* currnt frame number indicator */
+       UI_view2d_view_orthoSpecial(ar, v2d, 1);
+       ANIM_draw_cfra_number(C, v2d, cfra_flag);
 }
 
 static void clip_preview_region_draw(const bContext *C, ARegion *ar)
@@ -1350,7 +1336,9 @@ static void clip_preview_region_draw(const bContext *C, ARegion *ar)
                dopesheet_region_draw(C, ar);
 }
 
-static void clip_preview_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *UNUSED(ar), wmNotifier *UNUSED(wmn))
+static void clip_preview_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *UNUSED(ar),
+        wmNotifier *UNUSED(wmn), const Scene *UNUSED(scene))
 {
 }
 
@@ -1391,7 +1379,9 @@ static void clip_channels_region_draw(const bContext *C, ARegion *ar)
        UI_view2d_view_restore(C);
 }
 
-static void clip_channels_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *UNUSED(ar), wmNotifier *UNUSED(wmn))
+static void clip_channels_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *UNUSED(ar),
+        wmNotifier *UNUSED(wmn), const Scene *UNUSED(scene))
 {
 }
 
@@ -1408,7 +1398,9 @@ static void clip_header_region_draw(const bContext *C, ARegion *ar)
        ED_region_header(C, ar);
 }
 
-static void clip_header_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar, wmNotifier *wmn)
+static void clip_header_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar,
+        wmNotifier *wmn, const Scene *UNUSED(scene))
 {
        /* context changes */
        switch (wmn->category) {
@@ -1448,7 +1440,9 @@ static void clip_tools_region_draw(const bContext *C, ARegion *ar)
 
 /****************** tool properties region ******************/
 
-static void clip_props_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar, wmNotifier *wmn)
+static void clip_props_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar,
+        wmNotifier *wmn, const Scene *UNUSED(scene))
 {
        /* context changes */
        switch (wmn->category) {
@@ -1493,7 +1487,9 @@ static void clip_properties_region_draw(const bContext *C, ARegion *ar)
        ED_region_panels(C, ar, NULL, -1, true);
 }
 
-static void clip_properties_region_listener(bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar, wmNotifier *wmn)
+static void clip_properties_region_listener(
+        bScreen *UNUSED(sc), ScrArea *UNUSED(sa), ARegion *ar,
+        wmNotifier *wmn, const Scene *UNUSED(scene))
 {
        /* context changes */
        switch (wmn->category) {
@@ -1593,19 +1589,6 @@ void ED_spacetype_clip(void)
 
        BLI_addhead(&st->regiontypes, art);
 
-       /* tool properties */
-       art = MEM_callocN(sizeof(ARegionType), "spacetype clip tool properties region");
-       art->regionid = RGN_TYPE_TOOL_PROPS;
-       art->prefsizex = 0;
-       art->prefsizey = 120;
-       art->keymapflag = ED_KEYMAP_FRAMES | ED_KEYMAP_UI;
-       art->listener = clip_props_region_listener;
-       art->init = clip_tools_region_init;
-       art->draw = clip_tools_region_draw;
-       ED_clip_tool_props_register(art);
-
-       BLI_addhead(&st->regiontypes, art);
-
        /* regions: header */
        art = MEM_callocN(sizeof(ARegionType), "spacetype clip region");
        art->regionid = RGN_TYPE_HEADER;