dblclk label folder item is goto, fix no-drag trns if not drawn, amp up pane divider...
[goodguy/cinelerra.git] / cinelerra-5.1 / cinelerra / localsession.C
index c8cd9041a8019711706d96e4f8418870b757e92b..8293824c9ee97daa714c95a517ca60d1eb9a4084 100644 (file)
@@ -24,6 +24,7 @@
 #include "clip.h"
 #include "bchash.h"
 #include "edl.h"
+#include "edlsession.h"
 #include "filesystem.h"
 #include "filexml.h"
 #include "floatauto.h"
@@ -75,6 +76,7 @@ LocalSession::LocalSession(EDL *edl)
        zoom_atrack = 0;
        zoom_vtrack = 0;
        x_pane = y_pane = -1;
+       gang_tracks = GANG_NONE;
 
        for(int i = 0; i < TOTAL_PANES; i++) {
                view_start[i] = 0;
@@ -100,6 +102,7 @@ LocalSession::LocalSession(EDL *edl)
        red_max = green_max = blue_max = 0;
        use_max = 0;
        solo_track_id = -1;
+       gang_tracks = GANG_NONE;
 }
 
 LocalSession::~LocalSession()
@@ -141,6 +144,7 @@ void LocalSession::copy_from(LocalSession *that)
        blue_max = that->blue_max;
        use_max = that->use_max;
        solo_track_id = that->solo_track_id;
+       gang_tracks = that->gang_tracks;
 
        for (int i = 0; i < AUTOGROUPTYPE_COUNT; i++) {
                automation_mins[i] = that->automation_mins[i];
@@ -195,6 +199,8 @@ void LocalSession::save_xml(FileXML *file, double start)
        file->tag.set_property("GREEN_MAX", green_max);
        file->tag.set_property("BLUE_MAX", blue_max);
        file->tag.set_property("USE_MAX", use_max);
+       file->tag.set_property("GANG_TRACKS", gang_tracks);
+
 
        for (int i = 0; i < AUTOGROUPTYPE_COUNT; i++) {
                if (!Automation::autogrouptypes_fixedrange[i]) {
@@ -233,6 +239,7 @@ void LocalSession::synchronize_params(LocalSession *that)
        blue_max = that->blue_max;
        if( solo_track_id < 0 || that->solo_track_id < 0 )
                solo_track_id = that->solo_track_id;
+       gang_tracks = that->gang_tracks;
 }
 
 
@@ -292,7 +299,7 @@ void LocalSession::load_xml(FileXML *file, unsigned long load_flags)
                green_max = file->tag.get_property("GREEN_MAX", green_max);
                blue_max = file->tag.get_property("BLUE_MAX", blue_max);
                use_max = file->tag.get_property("USE_MAX", use_max);
-
+               gang_tracks = file->tag.get_property("GANG_TRACKS", gang_tracks);
                for (int i = 0; i < AUTOGROUPTYPE_COUNT; i++) {
                        if (!Automation::autogrouptypes_fixedrange[i]) {
                                automation_mins[i] = file->tag.get_property(xml_autogrouptypes_titlesmin[i],automation_mins[i]);
@@ -347,9 +354,9 @@ int LocalSession::load_defaults(BC_Hash *defaults)
 //     track_start = defaults->get("TRACK_START", 0);
 //     view_start = defaults->get("VIEW_START", 0);
        zoom_sample = defaults->get("ZOOM_SAMPLE", DEFAULT_ZOOM_TIME);
-       zoom_y = defaults->get("ZOOMY", 64);
+       zoom_y = defaults->get("ZOOMY", DEFAULT_ZOOM_TRACK);
        int64_t zoom_track = defaults->get("ZOOM_TRACK", 0);
-       if( zoom_track == 0 ) zoom_track = 64;
+       if( zoom_track == 0 ) zoom_track = DEFAULT_ZOOM_TRACK;
        zoom_atrack = defaults->get("ZOOM_ATRACK", zoom_track);
        zoom_vtrack = defaults->get("ZOOM_VTRACK", zoom_track);
        red = defaults->get("RED", 0.0);
@@ -359,6 +366,7 @@ int LocalSession::load_defaults(BC_Hash *defaults)
        green_max = defaults->get("GREEN_MAX", 0.0);
        blue_max = defaults->get("BLUE_MAX", 0.0);
        use_max = defaults->get("USE_MAX", 0);
+       gang_tracks = defaults->get("GANG_TRACKS", GANG_NONE);
 
        for (int i = 0; i < AUTOGROUPTYPE_COUNT; i++) {
                if (!Automation::autogrouptypes_fixedrange[i]) {
@@ -396,6 +404,7 @@ int LocalSession::save_defaults(BC_Hash *defaults)
        defaults->update("GREEN_MAX", green_max);
        defaults->update("BLUE_MAX", blue_max);
        defaults->update("USE_MAX", use_max);
+       defaults->update("GANG_TRACKS", gang_tracks);
 
        for (int i = 0; i < AUTOGROUPTYPE_COUNT; i++) {
                if (!Automation::autogrouptypes_fixedrange[i]) {
@@ -511,9 +520,12 @@ void LocalSession::reset_view_limits()
 {
        automation_mins[AUTOGROUPTYPE_ZOOM] = 0.005;
        automation_maxs[AUTOGROUPTYPE_ZOOM] = 5.000;
-       automation_mins[AUTOGROUPTYPE_X] = -100;
-       automation_maxs[AUTOGROUPTYPE_X] = 100;
-       automation_mins[AUTOGROUPTYPE_Y] = -100;
-       automation_maxs[AUTOGROUPTYPE_Y] = 100;
+       int out_w = edl->session->output_w;
+       automation_mins[AUTOGROUPTYPE_X] = -out_w;
+       automation_maxs[AUTOGROUPTYPE_X] = out_w;
+       int out_h = edl->session->output_h;
+       automation_mins[AUTOGROUPTYPE_Y] = -out_h;
+       automation_maxs[AUTOGROUPTYPE_Y] = out_h;
+
 }