namespace Gtkmm2ext {
-class VisibilityTracker {
+class VisibilityTracker : public virtual sigc::trackable {
public:
VisibilityTracker (Gtk::Window&);
virtual ~VisibilityTracker() {}
bool not_visible() const;
bool partially_visible() const;
+ Gtk::Window& window () const { return _window; }
+
private:
- Gtk::Window& window;
+ Gtk::Window& _window;
GdkVisibilityState _visibility;
bool handle_visibility_notify_event (GdkEventVisibility*);
};
using namespace Gtkmm2ext;
VisibilityTracker::VisibilityTracker (Gtk::Window& win)
- : window (win)
+ : _window (win)
, _visibility (GdkVisibilityState (0))
{
- window.add_events (Gdk::VISIBILITY_NOTIFY_MASK);
- window.signal_visibility_notify_event().connect (sigc::mem_fun (*this, &VisibilityTracker::handle_visibility_notify_event));
+ _window.add_events (Gdk::VISIBILITY_NOTIFY_MASK);
+ _window.signal_visibility_notify_event().connect (sigc::mem_fun (*this, &VisibilityTracker::handle_visibility_notify_event));
}
bool
VisibilityTracker::cycle_visibility ()
{
if (fully_visible ()) {
- window.hide ();
+ _window.hide ();
} else {
- window.present ();
+ _window.present ();
}
}
bool
VisibilityTracker::fully_visible () const
{
- return window.is_mapped() && (_visibility == GDK_VISIBILITY_UNOBSCURED);
+ return _window.is_mapped() && (_visibility == GDK_VISIBILITY_UNOBSCURED);
}
bool
VisibilityTracker::not_visible () const
{
- return !window.is_mapped() || (_visibility == GDK_VISIBILITY_FULLY_OBSCURED);
+ return !_window.is_mapped() || (_visibility == GDK_VISIBILITY_FULLY_OBSCURED);
}
bool
VisibilityTracker::partially_visible () const
{
- return window.is_mapped() && (_visibility == GDK_VISIBILITY_PARTIAL);
+ return _window.is_mapped() && ((_visibility == GDK_VISIBILITY_PARTIAL) || (_visibility == GDK_VISIBILITY_UNOBSCURED));
}