ardour/libs/gtkmm2ext/visibility_tracker.cc
Paul Davis d48dd0ccd5 defer creating a visibility tracker for a window until the window is mapped
Without this, the visibility tracker will report that the window is not visible at startup, and
this overrides the XML _visible property which denotes that the window should be made visible
2018-09-23 13:48:19 -04:00

92 lines
2.6 KiB
C++

/*
Copyright (C) 2013 Paul Davis
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <iostream>
#include <gtkmm/window.h>
#include "gtkmm2ext/visibility_tracker.h"
using namespace Gtkmm2ext;
bool VisibilityTracker::_use_window_manager_visibility = true;
VisibilityTracker::VisibilityTracker (Gtk::Window& win)
: _window (win)
, _visibility (GDK_VISIBILITY_FULLY_OBSCURED)
{
std::cerr << " vis tracker for " << _window.get_title() << " created\n";
_window.add_events (Gdk::VISIBILITY_NOTIFY_MASK);
_window.signal_visibility_notify_event().connect (sigc::mem_fun (*this, &VisibilityTracker::handle_visibility_notify_event));
}
void
VisibilityTracker::set_use_window_manager_visibility (bool yn)
{
_use_window_manager_visibility = yn;
}
bool
VisibilityTracker::handle_visibility_notify_event (GdkEventVisibility* ev)
{
std::cerr << _window.get_title() << " VISIBILITY CHANGE " << " from " << _visibility;
_visibility = ev->state;
std::cerr << " to " << _visibility << std::endl;
return false;
}
void
VisibilityTracker::cycle_visibility ()
{
if (fully_visible ()) {
_window.hide ();
} else {
_window.present ();
}
}
bool
VisibilityTracker::fully_visible () const
{
if (_use_window_manager_visibility) {
return _window.is_mapped() && (_visibility == GDK_VISIBILITY_UNOBSCURED);
} else {
return _window.is_mapped();
}
}
bool
VisibilityTracker::not_visible () const
{
if (_use_window_manager_visibility) {
return !_window.is_mapped() || (_visibility == GDK_VISIBILITY_FULLY_OBSCURED);
} else {
return !_window.is_mapped();
}
}
bool
VisibilityTracker::partially_visible () const
{
if (_use_window_manager_visibility) {
std::cerr << _window.get_title() << " pvis from vis = " << _visibility << " mapped " << _window.is_mapped() << std::endl;
return _window.is_mapped() && ((_visibility == GDK_VISIBILITY_PARTIAL) || (_visibility == GDK_VISIBILITY_UNOBSCURED));
} else {
std::cerr << _window.get_title() << " pvis from mapped " << _window.is_mapped() << std::endl;
return _window.is_mapped();
}
}