show desktop mode works!

This commit is contained in:
Dana Jansens 2003-02-10 16:56:03 +00:00
parent f305e7f18d
commit 265cf6c947
3 changed files with 40 additions and 9 deletions

View file

@ -764,12 +764,17 @@ void Client::setDesktop(unsigned int target)
void Client::showhide() void Client::showhide()
{ {
if (!_iconic && bool show;
(_desktop == openbox->screen(_screen)->desktop() || Screen *s = openbox->screen(_screen);
_desktop == 0xffffffff))
frame->show(); if (_iconic) show = false;
else else if (!(_desktop == s->desktop() ||
frame->hide(); _desktop == 0xffffffff)) show = false;
else if (normal() && s->showingDesktop()) show = false;
else show = true;
if (show) frame->show();
else frame->hide();
} }

View file

@ -44,6 +44,8 @@ Screen::Screen(int screen)
assert(screen >= 0); assert(screen < ScreenCount(**otk::display)); assert(screen >= 0); assert(screen < ScreenCount(**otk::display));
_info = otk::display->screenInfo(screen); _info = otk::display->screenInfo(screen);
_showing_desktop = false;
::running = false; ::running = false;
XErrorHandler old = XSetErrorHandler(::anotherWMRunning); XErrorHandler old = XSetErrorHandler(::anotherWMRunning);
XSelectInput(**otk::display, _info->rootWindow(), XSelectInput(**otk::display, _info->rootWindow(),
@ -397,13 +399,13 @@ void Screen::changeSupportedAtoms()
otk::Property::atoms.net_client_list_stacking, otk::Property::atoms.net_client_list_stacking,
otk::Property::atoms.net_desktop_names, otk::Property::atoms.net_desktop_names,
otk::Property::atoms.net_close_window, otk::Property::atoms.net_close_window,
otk::Property::atoms.net_desktop_layout,
otk::Property::atoms.net_showing_desktop,
otk::Property::atoms.net_wm_name, otk::Property::atoms.net_wm_name,
otk::Property::atoms.net_wm_visible_name, otk::Property::atoms.net_wm_visible_name,
otk::Property::atoms.net_wm_icon_name, otk::Property::atoms.net_wm_icon_name,
otk::Property::atoms.net_wm_visible_icon_name, otk::Property::atoms.net_wm_visible_icon_name,
/*
otk::Property::atoms.net_wm_desktop, otk::Property::atoms.net_wm_desktop,
*/
otk::Property::atoms.net_wm_strut, otk::Property::atoms.net_wm_strut,
otk::Property::atoms.net_wm_window_type, otk::Property::atoms.net_wm_window_type,
otk::Property::atoms.net_wm_window_type_desktop, otk::Property::atoms.net_wm_window_type_desktop,
@ -878,6 +880,15 @@ void Screen::installColormap(bool install) const
XUninstallColormap(**otk::display, _info->colormap()); XUninstallColormap(**otk::display, _info->colormap());
} }
void Screen::showDesktop(bool show)
{
if (show == _showing_desktop) return; // no change
_showing_desktop = show;
ClientList::iterator it, end = clients.end();
for (it = clients.begin(); it != end; ++it)
(*it)->showhide();
}
void Screen::propertyHandler(const XPropertyEvent &e) void Screen::propertyHandler(const XPropertyEvent &e)
{ {
@ -912,6 +923,8 @@ void Screen::clientMessageHandler(const XClientMessageEvent &e)
changeDesktop(e.data.l[0]); changeDesktop(e.data.l[0]);
} else if (e.message_type == otk::Property::atoms.net_number_of_desktops) { } else if (e.message_type == otk::Property::atoms.net_number_of_desktops) {
changeNumDesktops(e.data.l[0]); changeNumDesktops(e.data.l[0]);
} else if (e.message_type == otk::Property::atoms.net_showing_desktop) {
showDesktop(e.data.l[0] != 0);
} }
} }
@ -929,8 +942,11 @@ void Screen::mapRequestHandler(const XMapRequestEvent &e)
#ifdef DEBUG #ifdef DEBUG
printf("DEBUG: MAP REQUEST CAUGHT IN SCREEN. IGNORED.\n"); printf("DEBUG: MAP REQUEST CAUGHT IN SCREEN. IGNORED.\n");
#endif #endif
} else } else {
if (_showing_desktop)
showDesktop(false); // leave showing-the-desktop mode
manageWindow(e.window); manageWindow(e.window);
} }
}
} }

View file

@ -95,8 +95,12 @@ private:
//! The names of all desktops //! The names of all desktops
otk::Property::StringVect _desktop_names; otk::Property::StringVect _desktop_names;
//! The layout of the desktops as specified by an EWMH compliant pager
DesktopLayout _layout; DesktopLayout _layout;
//! True when the window manager is in 'showing desktop' mode
bool _showing_desktop;
//! Calculate the Screen::_area member //! Calculate the Screen::_area member
void calcArea(); void calcArea();
//! Set the list of supported NETWM atoms on the root window //! Set the list of supported NETWM atoms on the root window
@ -139,6 +143,10 @@ private:
*/ */
void changeNumDesktops(unsigned int num); void changeNumDesktops(unsigned int num);
//! Shows and focuses the desktop and hides all the client windows, or
//! returns to the normal state, showing client windows.
void showDesktop(bool show);
public: public:
#ifndef SWIG #ifndef SWIG
//! Constructs a new Screen object //! Constructs a new Screen object
@ -161,6 +169,8 @@ public:
inline unsigned int desktop() const { return _desktop; } inline unsigned int desktop() const { return _desktop; }
//! Returns the number of desktops //! Returns the number of desktops
inline unsigned int numDesktops() const { return _num_desktops; } inline unsigned int numDesktops() const { return _num_desktops; }
//! When true, the desktop is being shown and all clients are hidden
inline bool showingDesktop() const { return _showing_desktop; }
//! Returns the area of the screen not reserved by applications' Struts //! Returns the area of the screen not reserved by applications' Struts
/*! /*!