X-Git-Url: https://git.cinelerra-gg.org/git/?p=goodguy%2Fcinelerra.git;a=blobdiff_plain;f=cinelerra-5.1%2Fcinelerra%2Fmwindow.C;h=3f67230e63885819780485acc3f7acde9f09b8ab;hp=601f5c24e0fdfd7a01c26078bd35d01fbf25cd81;hb=b2dfd8318ea57bbe38e2c61ffd8cda30fb7465c3;hpb=e41864cf7931bfb86f68c5d35d4578dfe161d386 diff --git a/cinelerra-5.1/cinelerra/mwindow.C b/cinelerra-5.1/cinelerra/mwindow.C index 601f5c24..3f67230e 100644 --- a/cinelerra-5.1/cinelerra/mwindow.C +++ b/cinelerra-5.1/cinelerra/mwindow.C @@ -2007,6 +2007,7 @@ if(debug) printf("MWindow::load_filenames %d\n", __LINE__); break; } if( strcmp(cin_version, CINELERRA_VERSION) && + strcmp(cin_version, "Unify") && strcmp(cin_version, "5.1") ) { char string[BCTEXTLEN]; snprintf(string, sizeof(string), @@ -2861,32 +2862,67 @@ void MWindow::restore_windows() if( !session->show_vwindow ) { for( int i=0, n=vwindows.size(); igui->close(0); + if( !vwindow || !vwindow->is_running() ) continue; + vwindow->gui->lock_window("MWindow::restore_windows"); + vwindow->gui->close(1); + vwindow->gui->unlock_window(); } } else show_vwindow(); - if( !session->show_awindow ) - awindow->gui->close(0); - else + if( !session->show_awindow && !awindow->gui->is_hidden() ) { + awindow->gui->lock_window("MWindow::restore_windows"); + awindow->gui->close_event(); + awindow->gui->unlock_window(); + } + else if( session->show_awindow && awindow->gui->is_hidden() ) show_awindow(); - if( !session->show_cwindow ) - cwindow->gui->close(0); - else - show_cwindow(); + if( !session->show_cwindow && !cwindow->gui->is_hidden() ) { + cwindow->gui->lock_window("MWindow::restore_windows"); + cwindow->hide_window(); + cwindow->gui->unlock_window(); + } + else if( session->show_cwindow && cwindow->gui->is_hidden() ) + cwindow->show_window(); - if( !session->show_gwindow ) - gwindow->gui->close(0); - else + if( !session->show_gwindow && !gwindow->gui->is_hidden() ) { + gwindow->gui->lock_window("MWindow::restore_windows"); + gwindow->gui->close_event(); + gwindow->gui->unlock_window(); + } + else if( session->show_gwindow && gwindow->gui->is_hidden() ) show_gwindow(); - if( !session->show_lwindow ) - lwindow->gui->close(0); - else + if( !session->show_lwindow && !lwindow->gui->is_hidden() ) { + lwindow->gui->lock_window("MWindow::restore_windows"); + lwindow->gui->close_event(); + lwindow->gui->unlock_window(); + } + else if( session->show_lwindow && lwindow->gui->is_hidden() ) show_lwindow(); + + gui->focus(); +} + +void MWindow::save_layout(int no) +{ + char layout_path[BCTEXTLEN]; + snprintf(layout_path, sizeof(layout_path), "%s/" LAYOUT_FILE, + File::get_config_path(), no); + session->save_file(layout_path); +} + +void MWindow::load_layout(int no) +{ + char layout_path[BCTEXTLEN]; + snprintf(layout_path, sizeof(layout_path), "%s/" LAYOUT_FILE, + File::get_config_path(), no); + session->load_file(layout_path); + restore_windows(); + gui->default_positions(); + save_defaults(); } int MWindow::tile_windows(int window_config)