mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-08 07:45:00 +01:00
cleaner version of splash display changes
git-svn-id: svn://localhost/ardour2/branches/3.0@13004 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
parent
c300fa98af
commit
3dcbdc0fe6
4 changed files with 46 additions and 52 deletions
|
|
@ -794,6 +794,8 @@ If you still wish to quit, please use the\n\n\
|
||||||
*/
|
*/
|
||||||
save_ardour_state ();
|
save_ardour_state ();
|
||||||
|
|
||||||
|
loading_message (_("Please wait while Ardour cleans up..."));
|
||||||
|
|
||||||
if (_session) {
|
if (_session) {
|
||||||
// _session->set_deletion_in_progress ();
|
// _session->set_deletion_in_progress ();
|
||||||
_session->set_clean ();
|
_session->set_clean ();
|
||||||
|
|
@ -2401,11 +2403,11 @@ ARDOUR_UI::loading_message (const std::string& msg)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
show_splash ();
|
if (!splash) {
|
||||||
if (splash) {
|
show_splash ();
|
||||||
splash->message (msg);
|
|
||||||
flush_pending ();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
splash->message (msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @param quit_on_cancel true if exit() should be called if the user clicks `cancel' in the new session dialog */
|
/** @param quit_on_cancel true if exit() should be called if the user clicks `cancel' in the new session dialog */
|
||||||
|
|
@ -2830,34 +2832,9 @@ ARDOUR_UI::about_signal_response (int /*response*/)
|
||||||
hide_about();
|
hide_about();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
|
||||||
ARDOUR_UI::wakeup_from_splash_sleep (void* arg)
|
|
||||||
{
|
|
||||||
cerr << "idle after splash\n";
|
|
||||||
((ARDOUR_UI*)arg)->_wakeup_from_splash_sleep ();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
ARDOUR_UI::_wakeup_from_splash_sleep ()
|
|
||||||
{
|
|
||||||
splash_done_visible = true;
|
|
||||||
cerr << "Set sdv to " << splash_done_visible << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool
|
|
||||||
ARDOUR_UI::splash_visible (GdkEventAny*)
|
|
||||||
{
|
|
||||||
cerr << "Splash now mapped\n";
|
|
||||||
g_idle_add ((gboolean (*)(void*))ARDOUR_UI::wakeup_from_splash_sleep, this);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
ARDOUR_UI::show_splash ()
|
ARDOUR_UI::show_splash ()
|
||||||
{
|
{
|
||||||
cerr << "Show splash!\n";
|
|
||||||
|
|
||||||
if (splash == 0) {
|
if (splash == 0) {
|
||||||
try {
|
try {
|
||||||
splash = new Splash;
|
splash = new Splash;
|
||||||
|
|
@ -2866,24 +2843,7 @@ ARDOUR_UI::show_splash ()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool was_mapped = splash->is_mapped ();
|
splash->display ();
|
||||||
|
|
||||||
if (!was_mapped) {
|
|
||||||
splash_expose = splash->signal_map_event().connect (sigc::mem_fun (this, &ARDOUR_UI::splash_visible), false);
|
|
||||||
splash_done_visible = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
splash->pop_front ();
|
|
||||||
splash->present ();
|
|
||||||
|
|
||||||
if (!was_mapped) {
|
|
||||||
while (!splash_done_visible) {
|
|
||||||
cerr << "nested iteration. sdv = " << splash_done_visible << endl;
|
|
||||||
gtk_main_iteration ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cerr << "show splash done\n";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
||||||
|
|
@ -611,11 +611,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
|
||||||
|
|
||||||
About* about;
|
About* about;
|
||||||
Splash* splash;
|
Splash* splash;
|
||||||
bool splash_done_visible;
|
|
||||||
static bool wakeup_from_splash_sleep (void *);
|
|
||||||
void _wakeup_from_splash_sleep ();
|
|
||||||
bool splash_visible (GdkEventAny*);
|
|
||||||
sigc::connection splash_expose;
|
|
||||||
|
|
||||||
void pop_back_splash (Gtk::Window&);
|
void pop_back_splash (Gtk::Window&);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -85,6 +85,40 @@ Splash::~Splash ()
|
||||||
the_splash = 0;
|
the_splash = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
Splash::wakeup_from_splash_sleep ()
|
||||||
|
{
|
||||||
|
splash_done_visible = true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
Splash::splash_mapped (GdkEventAny*)
|
||||||
|
{
|
||||||
|
Glib::signal_idle().connect (sigc::mem_fun (this, &Splash::wakeup_from_splash_sleep));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
Splash::display ()
|
||||||
|
{
|
||||||
|
bool was_mapped = is_mapped ();
|
||||||
|
|
||||||
|
if (!was_mapped) {
|
||||||
|
signal_map_event().connect (sigc::mem_fun (this, &Splash::splash_mapped), false);
|
||||||
|
splash_done_visible = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
pop_front ();
|
||||||
|
present ();
|
||||||
|
|
||||||
|
if (!was_mapped) {
|
||||||
|
while (!splash_done_visible) {
|
||||||
|
gtk_main_iteration ();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
Splash::pop_back_for (Gtk::Window& win)
|
Splash::pop_back_for (Gtk::Window& win)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -38,6 +38,7 @@ class Splash : public Gtk::Window
|
||||||
|
|
||||||
static Splash* instance() { return the_splash; }
|
static Splash* instance() { return the_splash; }
|
||||||
|
|
||||||
|
void display ();
|
||||||
void pop_back_for (Gtk::Window&);
|
void pop_back_for (Gtk::Window&);
|
||||||
void pop_front ();
|
void pop_front ();
|
||||||
|
|
||||||
|
|
@ -56,6 +57,10 @@ class Splash : public Gtk::Window
|
||||||
|
|
||||||
void boot_message (std::string);
|
void boot_message (std::string);
|
||||||
PBD::ScopedConnection msg_connection;
|
PBD::ScopedConnection msg_connection;
|
||||||
|
|
||||||
|
bool splash_done_visible;
|
||||||
|
bool wakeup_from_splash_sleep ();
|
||||||
|
bool splash_mapped (GdkEventAny*);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* __ardour_gtk_splash_h__ */
|
#endif /* __ardour_gtk_splash_h__ */
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue