diff options
| author | Dana Jansens <danakj@orodu.net> | 2002-11-10 08:42:34 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2002-11-10 08:42:34 +0000 |
| commit | 6e2593cadc9a755d0e08facb7df0459a786e692b (patch) | |
| tree | a9e837b78d12fcecdf373d73efa68f542a04f244 | |
| parent | 0b17bd83c7d09ee364913f5e5f6b214f996b3a83 (diff) | |
handle events on all of the client's decor as for the client
| -rw-r--r-- | src/frame.hh | 10 | ||||
| -rw-r--r-- | src/xeventhandler.cc | 20 |
2 files changed, 30 insertions, 0 deletions
diff --git a/src/frame.hh b/src/frame.hh index 7814ed35..5e7ba927 100644 --- a/src/frame.hh +++ b/src/frame.hh @@ -104,6 +104,16 @@ public: //! Returns the frame's most-parent window, which is a child of the root //! window inline Window window() const { return _window; } + + inline Window titlebar() const { return _titlebar; } + inline Window label() const { return _label; } + inline Window buttonIconify() const { return _button_iconify; } + inline Window buttonMax() const { return _button_max; } + inline Window buttonStick() const { return _button_stick; } + inline Window buttonClose() const { return _button_close; } + inline Window handle() const { return _handle; } + inline Window gripLeft() const { return _grip_left; } + inline Window gripRight() const { return _grip_right; } }; } diff --git a/src/xeventhandler.cc b/src/xeventhandler.cc index 6cdc87a5..3225fb46 100644 --- a/src/xeventhandler.cc +++ b/src/xeventhandler.cc @@ -156,6 +156,16 @@ void OBXEventHandler::manageWindow(int screen, Window window) // create the OBClient class, which gets all of the hints on the window Openbox::instance->addClient(window, client = new OBClient(screen, window)); + // add all the client's decoration windows as event handlers for the client + Openbox::instance->addClient(client->frame->titlebar(), client); + Openbox::instance->addClient(client->frame->buttonIconify(), client); + Openbox::instance->addClient(client->frame->buttonMax(), client); + Openbox::instance->addClient(client->frame->buttonStick(), client); + Openbox::instance->addClient(client->frame->buttonClose(), client); + Openbox::instance->addClient(client->frame->label(), client); + Openbox::instance->addClient(client->frame->handle(), client); + Openbox::instance->addClient(client->frame->gripLeft(), client); + Openbox::instance->addClient(client->frame->gripRight(), client); // we dont want a border on the client XSetWindowBorderWidth(otk::OBDisplay::display, window, 0); @@ -201,6 +211,16 @@ void OBXEventHandler::unmanageWindow(OBClient *client) // remove the client class from the search list Openbox::instance->removeClient(client->window()); + // remove the frame's decor elements as event handlers for the client + Openbox::instance->removeClient(frame->titlebar()); + Openbox::instance->removeClient(frame->buttonIconify()); + Openbox::instance->removeClient(frame->buttonMax()); + Openbox::instance->removeClient(frame->buttonStick()); + Openbox::instance->removeClient(frame->buttonClose()); + Openbox::instance->removeClient(frame->label()); + Openbox::instance->removeClient(frame->handle()); + Openbox::instance->removeClient(frame->gripLeft()); + Openbox::instance->removeClient(frame->gripRight()); delete client->frame; client->frame = 0; |
