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>
|
|
|
|
}
|
|
|
|
|
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 OBClient objects
|
2002-11-11 11:25:40 +00:00
|
|
|
typedef std::list<OBClient*> ClientList;
|
2002-11-10 12:50:18 +00:00
|
|
|
//! 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
|
|
|
enum StackLayer {
|
|
|
|
Layer_Icon, // 0 - iconified windows, in any order at all
|
|
|
|
Layer_Desktop, // 1 - desktop windows
|
|
|
|
Layer_Below, // 2 - normal windows w/ below
|
|
|
|
Layer_Normal, // 3 - normal windows
|
|
|
|
Layer_Above, // 4 - normal windows w/ above
|
|
|
|
Layer_Top, // 5 - always-on-top-windows (docks?)
|
|
|
|
Layer_Fullscreen, // 6 - fullscreeen windows
|
|
|
|
Layer_Internal, // 7 - openbox windows/menus
|
|
|
|
NUM_LAYERS
|
|
|
|
};
|
|
|
|
|
|
|
|
//! All managed clients on the screen (in order of being mapped)
|
2002-12-24 19:16:38 +00:00
|
|
|
ClientList clients;
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
//! Areas of the screen reserved by applications
|
|
|
|
StrutList _struts;
|
|
|
|
|
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
|
|
|
|
|
|
|
//! A list of all managed clients on the screen, in their stacking order
|
|
|
|
ClientList _stacking;
|
2002-11-10 12:50:18 +00:00
|
|
|
|
|
|
|
//! Calculate the OBScreen::_area member
|
|
|
|
void calcArea();
|
|
|
|
//! 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
|
|
|
|
2002-11-10 12:50:18 +00:00
|
|
|
//! Adds a window's strut to the screen's list of reserved spaces
|
|
|
|
void addStrut(otk::Strut *strut);
|
|
|
|
//! Removes a window's strut from the screen's list of reserved spaces
|
|
|
|
void removeStrut(otk::Strut *strut);
|
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
|