2002-11-10 12:50:18 +00:00
|
|
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
|
|
|
#ifndef __screen_hh
|
|
|
|
#define __screen_hh
|
|
|
|
|
|
|
|
/*! @file screen.hh
|
|
|
|
@brief OBScreen manages a single screen
|
|
|
|
*/
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
#include <X11/Xlib.h>
|
|
|
|
}
|
|
|
|
|
2003-01-05 01:40:38 +00:00
|
|
|
#include "client.hh"
|
2002-12-02 22:12:26 +00:00
|
|
|
#include "rootwindow.hh"
|
2002-11-10 12:50:18 +00:00
|
|
|
#include "otk/image.hh"
|
|
|
|
#include "otk/strut.hh"
|
|
|
|
#include "otk/rect.hh"
|
2002-11-11 10:05:06 +00:00
|
|
|
#include "otk/style.hh"
|
|
|
|
#include "otk/configuration.hh" // TEMPORARY
|
2002-11-10 12:50:18 +00:00
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace ob {
|
|
|
|
|
|
|
|
class OBClient;
|
2002-12-02 22:12:26 +00:00
|
|
|
class OBRootWindow;
|
2002-11-10 12:50:18 +00:00
|
|
|
|
|
|
|
//! Manages a single screen
|
|
|
|
/*!
|
|
|
|
*/
|
|
|
|
class OBScreen {
|
|
|
|
public:
|
|
|
|
//! Holds a list of otk::Strut objects
|
|
|
|
typedef std::list<otk::Strut*> StrutList;
|
|
|
|
|
|
|
|
static const unsigned long event_mask = ColormapChangeMask |
|
|
|
|
EnterWindowMask |
|
|
|
|
LeaveWindowMask |
|
|
|
|
PropertyChangeMask |
|
|
|
|
SubstructureNotifyMask |
|
|
|
|
SubstructureRedirectMask |
|
|
|
|
ButtonPressMask |
|
|
|
|
ButtonReleaseMask;
|
|
|
|
|
2003-01-03 18:21:28 +00:00
|
|
|
//! All managed clients on the screen (in order of being mapped)
|
2003-01-05 01:40:38 +00:00
|
|
|
OBClient::List clients;
|
2002-12-24 19:16:38 +00:00
|
|
|
|
2002-11-10 12:50:18 +00:00
|
|
|
private:
|
|
|
|
//! Was %Openbox able to manage the screen?
|
|
|
|
bool _managed;
|
|
|
|
|
|
|
|
//! The number of the screen on the X server
|
|
|
|
int _number;
|
|
|
|
|
|
|
|
//! Information about this screen
|
|
|
|
const otk::ScreenInfo *_info;
|
|
|
|
|
|
|
|
//! The Image Control used for rendering on the screen
|
|
|
|
otk::BImageControl *_image_control;
|
|
|
|
|
2002-11-11 10:05:06 +00:00
|
|
|
//! The style with which to render on the screen
|
|
|
|
otk::Style _style;
|
|
|
|
|
2002-12-25 22:02:34 +00:00
|
|
|
//! The screen's root window
|
2002-12-02 22:12:26 +00:00
|
|
|
OBRootWindow _root;
|
|
|
|
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Is the root colormap currently installed?
|
|
|
|
bool _root_cmap_installed;
|
|
|
|
|
|
|
|
//! Area usable for placement etc (total - struts)
|
|
|
|
otk::Rect _area;
|
|
|
|
|
2003-01-04 08:02:08 +00:00
|
|
|
//! Combined strut from all of the clients' struts
|
|
|
|
otk::Strut _strut;
|
2002-11-10 12:50:18 +00:00
|
|
|
|
2002-12-25 22:02:34 +00:00
|
|
|
//! An offscreen window which gets focus when nothing else has it
|
|
|
|
Window _focuswindow;
|
2003-01-03 18:21:28 +00:00
|
|
|
|
2003-01-04 01:21:04 +00:00
|
|
|
//! An offscreen window which shows that a NETWM compliant window manager is
|
|
|
|
//! running
|
|
|
|
Window _supportwindow;
|
|
|
|
|
2003-01-03 18:21:28 +00:00
|
|
|
//! A list of all managed clients on the screen, in their stacking order
|
2003-01-05 01:40:38 +00:00
|
|
|
OBClient::List _stacking;
|
2002-11-10 12:50:18 +00:00
|
|
|
|
|
|
|
//! Calculate the OBScreen::_area member
|
|
|
|
void calcArea();
|
2003-01-04 01:21:04 +00:00
|
|
|
//! Set the list of supported NETWM atoms on the root window
|
|
|
|
void setSupportedAtoms();
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Set the client list on the root window
|
|
|
|
/*!
|
|
|
|
Sets the _NET_CLIENT_LIST root window property.<br>
|
|
|
|
Also calls OBScreen::updateStackingList.
|
|
|
|
*/
|
|
|
|
void setClientList();
|
|
|
|
//! Set the client stacking list on the root window
|
|
|
|
/*!
|
|
|
|
Set the _NET_CLIENT_LIST_STACKING root window property.
|
|
|
|
*/
|
|
|
|
void setStackingList();
|
|
|
|
//! Set the work area hint on the root window
|
|
|
|
/*!
|
|
|
|
Set the _NET_WORKAREA root window property.
|
|
|
|
*/
|
|
|
|
void setWorkArea();
|
2003-01-03 18:21:28 +00:00
|
|
|
|
2002-11-10 12:50:18 +00:00
|
|
|
public:
|
2002-12-23 00:04:32 +00:00
|
|
|
#ifndef SWIG
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Constructs a new OBScreen object
|
2002-12-31 19:15:24 +00:00
|
|
|
OBScreen(int screen);
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Destroys the OBScreen object
|
|
|
|
virtual ~OBScreen();
|
2002-12-23 00:04:32 +00:00
|
|
|
#endif
|
2002-11-10 12:50:18 +00:00
|
|
|
|
2003-01-03 22:06:08 +00:00
|
|
|
inline int number() const { return _number; }
|
|
|
|
|
2002-11-11 10:41:44 +00:00
|
|
|
//! Returns if the screen was successfully managed
|
|
|
|
/*!
|
|
|
|
If this is false, then the screen should be deleted and should NOT be
|
|
|
|
used.
|
|
|
|
*/
|
|
|
|
inline bool managed() const { return _managed; }
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Returns the Image Control used for rendering on the screen
|
|
|
|
inline otk::BImageControl *imageControl() { return _image_control; }
|
|
|
|
//! Returns the area of the screen not reserved by applications' Struts
|
|
|
|
inline const otk::Rect &area() const { return _area; }
|
2002-11-11 10:26:08 +00:00
|
|
|
//! Returns the style in use on the screen
|
|
|
|
inline const otk::Style *style() const { return &_style; }
|
2002-12-25 22:02:34 +00:00
|
|
|
//! An offscreen window which gets focus when nothing else has it
|
|
|
|
inline Window focuswindow() const { return _focuswindow; }
|
2002-11-11 10:26:08 +00:00
|
|
|
|
2003-01-04 08:02:08 +00:00
|
|
|
//! Update's the screen's combined strut of all the clients.
|
|
|
|
/*!
|
|
|
|
Clients should call this whenever they change their strut.
|
|
|
|
*/
|
|
|
|
void updateStrut();
|
2002-11-11 10:05:06 +00:00
|
|
|
|
2002-11-11 10:35:59 +00:00
|
|
|
//! Manage any pre-existing windows on the screen
|
|
|
|
void manageExisting();
|
2002-11-11 10:26:08 +00:00
|
|
|
//! Manage a client window
|
|
|
|
/*!
|
|
|
|
This gives the window a frame, reparents it, selects events on it, etc.
|
|
|
|
*/
|
|
|
|
void manageWindow(Window window);
|
|
|
|
//! Unmanage a client
|
|
|
|
/*!
|
|
|
|
This removes the window's frame, reparents it to root, unselects events on
|
|
|
|
it, etc.
|
|
|
|
*/
|
|
|
|
void unmanageWindow(OBClient *client);
|
2003-01-03 18:21:28 +00:00
|
|
|
|
2003-01-03 18:25:04 +00:00
|
|
|
//! Raises/Lowers a client window above/below all others in its stacking
|
|
|
|
//! layer
|
|
|
|
void restack(bool raise, OBClient *client);
|
2002-11-10 12:50:18 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif// __screen_hh
|