2002-04-11 03:20:38 +00:00
|
|
|
// Slit.cc for Openbox
|
|
|
|
// Copyright (c) 2001 Sean 'Shaleh' Perry <shaleh@debian.org>
|
|
|
|
// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
|
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
// copy of this software and associated documentation files (the "Software"),
|
|
|
|
// to deal in the Software without restriction, including without limitation
|
|
|
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
// and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
// Software is furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
// DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
// stupid macros needed to access some functions in version 2 of the GNU C
|
|
|
|
// library
|
|
|
|
#ifndef _GNU_SOURCE
|
|
|
|
#define _GNU_SOURCE
|
|
|
|
#endif // _GNU_SOURCE
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "../config.h"
|
|
|
|
#endif // HAVE_CONFIG_H
|
|
|
|
|
|
|
|
#ifdef SLIT
|
|
|
|
|
|
|
|
#include <X11/keysym.h>
|
|
|
|
|
|
|
|
#include "i18n.h"
|
|
|
|
#include "openbox.h"
|
|
|
|
#include "Image.h"
|
|
|
|
#include "Screen.h"
|
|
|
|
#include "Slit.h"
|
|
|
|
#include "Toolbar.h"
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
#include <string>
|
|
|
|
#include <strstream>
|
|
|
|
|
|
|
|
Slit::Slit(BScreen &scr, Resource &conf) : screen(scr),
|
|
|
|
openbox(scr.getOpenbox()), config(conf)
|
|
|
|
{
|
|
|
|
// default values
|
|
|
|
m_placement = CenterRight;
|
|
|
|
m_direction = Vertical;
|
|
|
|
m_ontop = false;
|
|
|
|
m_hidden = m_autohide = false;
|
2002-04-17 23:07:11 +00:00
|
|
|
load();
|
2002-04-16 23:50:53 +00:00
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
display = screen.getBaseDisplay().getXDisplay();
|
2002-04-11 03:20:38 +00:00
|
|
|
frame.window = frame.pixmap = None;
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
timer = new BTimer(openbox, *this);
|
|
|
|
timer->setTimeout(openbox.getAutoRaiseDelay());
|
2002-04-11 03:20:38 +00:00
|
|
|
timer->fireOnce(True);
|
|
|
|
|
|
|
|
clientList = new LinkedList<SlitClient>;
|
|
|
|
|
2002-04-14 11:37:22 +00:00
|
|
|
slitmenu = new Slitmenu(*this);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
XSetWindowAttributes attrib;
|
|
|
|
unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel |
|
|
|
|
CWColormap | CWOverrideRedirect | CWEventMask;
|
|
|
|
attrib.background_pixmap = None;
|
|
|
|
attrib.background_pixel = attrib.border_pixel =
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.getBorderColor()->getPixel();
|
|
|
|
attrib.colormap = screen.getColormap();
|
2002-04-11 03:20:38 +00:00
|
|
|
attrib.override_redirect = True;
|
|
|
|
attrib.event_mask = SubstructureRedirectMask | ButtonPressMask |
|
|
|
|
EnterWindowMask | LeaveWindowMask;
|
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area = Rect(0, 0, 1, 1);
|
|
|
|
|
2002-04-11 03:20:38 +00:00
|
|
|
frame.window =
|
2002-04-14 19:30:38 +00:00
|
|
|
XCreateWindow(display, screen.getRootWindow(),
|
|
|
|
frame.area.x(), frame.area.y(),
|
|
|
|
frame.area.w(), frame.area.h(), screen.getBorderWidth(),
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.getDepth(), InputOutput, screen.getVisual(),
|
2002-04-11 03:20:38 +00:00
|
|
|
create_mask, &attrib);
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.saveSlitSearch(frame.window, this);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
reconfigure();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Slit::~Slit() {
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.grab();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
if (timer->isTiming()) timer->stop();
|
|
|
|
delete timer;
|
|
|
|
|
|
|
|
delete clientList;
|
|
|
|
delete slitmenu;
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.getImageControl()->removeImage(frame.pixmap);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.removeSlitSearch(frame.window);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
XDestroyWindow(display, frame.window);
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.ungrab();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::addClient(Window w) {
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.grab();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
if (openbox.validateWindow(w)) {
|
2002-04-11 03:20:38 +00:00
|
|
|
SlitClient *client = new SlitClient;
|
|
|
|
client->client_window = w;
|
|
|
|
|
|
|
|
XWMHints *wmhints = XGetWMHints(display, w);
|
|
|
|
|
|
|
|
if (wmhints) {
|
|
|
|
if ((wmhints->flags & IconWindowHint) &&
|
|
|
|
(wmhints->icon_window != None)) {
|
2002-04-14 18:48:32 +00:00
|
|
|
XMoveWindow(display, client->client_window, screen.size().w() + 10,
|
|
|
|
screen.size().h() + 10);
|
2002-04-11 03:20:38 +00:00
|
|
|
XMapWindow(display, client->client_window);
|
|
|
|
|
|
|
|
client->icon_window = wmhints->icon_window;
|
|
|
|
client->window = client->icon_window;
|
|
|
|
} else {
|
|
|
|
client->icon_window = None;
|
|
|
|
client->window = client->client_window;
|
|
|
|
}
|
|
|
|
|
|
|
|
XFree(wmhints);
|
|
|
|
} else {
|
|
|
|
client->icon_window = None;
|
|
|
|
client->window = client->client_window;
|
|
|
|
}
|
|
|
|
|
|
|
|
XWindowAttributes attrib;
|
|
|
|
if (XGetWindowAttributes(display, client->window, &attrib)) {
|
|
|
|
client->width = attrib.width;
|
|
|
|
client->height = attrib.height;
|
|
|
|
} else {
|
|
|
|
client->width = client->height = 64;
|
|
|
|
}
|
|
|
|
|
|
|
|
XSetWindowBorderWidth(display, client->window, 0);
|
|
|
|
|
|
|
|
XSelectInput(display, frame.window, NoEventMask);
|
|
|
|
XSelectInput(display, client->window, NoEventMask);
|
|
|
|
|
|
|
|
XReparentWindow(display, client->window, frame.window, 0, 0);
|
|
|
|
XMapRaised(display, client->window);
|
|
|
|
XChangeSaveSet(display, client->window, SetModeInsert);
|
|
|
|
|
|
|
|
XSelectInput(display, frame.window, SubstructureRedirectMask |
|
|
|
|
ButtonPressMask | EnterWindowMask | LeaveWindowMask);
|
|
|
|
XSelectInput(display, client->window, StructureNotifyMask |
|
|
|
|
SubstructureNotifyMask | EnterWindowMask);
|
|
|
|
XFlush(display);
|
|
|
|
|
|
|
|
clientList->insert(client);
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.saveSlitSearch(client->client_window, this);
|
|
|
|
openbox.saveSlitSearch(client->icon_window, this);
|
2002-04-11 03:20:38 +00:00
|
|
|
reconfigure();
|
|
|
|
}
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.ungrab();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::removeClient(SlitClient *client, Bool remap) {
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.removeSlitSearch(client->client_window);
|
|
|
|
openbox.removeSlitSearch(client->icon_window);
|
2002-04-11 03:20:38 +00:00
|
|
|
clientList->remove(client);
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.removeNetizen(client->window);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
if (remap && openbox.validateWindow(client->window)) {
|
2002-04-11 03:20:38 +00:00
|
|
|
XSelectInput(display, frame.window, NoEventMask);
|
|
|
|
XSelectInput(display, client->window, NoEventMask);
|
2002-04-14 13:58:17 +00:00
|
|
|
XReparentWindow(display, client->window, screen.getRootWindow(),
|
2002-04-11 03:20:38 +00:00
|
|
|
client->x, client->y);
|
|
|
|
XChangeSaveSet(display, client->window, SetModeDelete);
|
|
|
|
XSelectInput(display, frame.window, SubstructureRedirectMask |
|
|
|
|
ButtonPressMask | EnterWindowMask | LeaveWindowMask);
|
|
|
|
XFlush(display);
|
|
|
|
}
|
|
|
|
|
|
|
|
delete client;
|
|
|
|
client = (SlitClient *) 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::removeClient(Window w, Bool remap) {
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.grab();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
Bool reconf = False;
|
|
|
|
|
|
|
|
LinkedListIterator<SlitClient> it(clientList);
|
|
|
|
for (SlitClient *tmp = it.current(); tmp; it++, tmp = it.current()) {
|
|
|
|
if (tmp->window == w) {
|
|
|
|
removeClient(tmp, remap);
|
|
|
|
reconf = True;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (reconf) reconfigure();
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.ungrab();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
void Slit::setOnTop(bool b) {
|
|
|
|
m_ontop = b;
|
|
|
|
ostrstream s;
|
|
|
|
s << "session.screen" << screen.getScreenNumber() << ".slit.onTop" << ends;
|
|
|
|
config.setValue(s.str(), m_ontop ? "True" : "False");
|
2002-04-19 06:51:08 +00:00
|
|
|
s.rdbuf()->freeze(0);
|
2002-04-16 23:50:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Slit::setAutoHide(bool b) {
|
|
|
|
m_autohide = b;
|
|
|
|
ostrstream s;
|
|
|
|
s << "session.screen" << screen.getScreenNumber() << ".slit.autoHide" << ends;
|
|
|
|
config.setValue(s.str(), m_autohide ? "True" : "False");
|
2002-04-19 06:51:08 +00:00
|
|
|
s.rdbuf()->freeze(0);
|
2002-04-16 23:50:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Slit::setPlacement(int p) {
|
|
|
|
m_placement = p;
|
|
|
|
ostrstream s;
|
|
|
|
s << "session.screen" << screen.getScreenNumber() << ".slit.placement" <<
|
|
|
|
ends;
|
|
|
|
const char *placement;
|
|
|
|
switch (m_placement) {
|
|
|
|
case TopLeft: placement = "TopLeft"; break;
|
|
|
|
case CenterLeft: placement = "CenterLeft"; break;
|
|
|
|
case BottomLeft: placement = "BottomLeft"; break;
|
|
|
|
case TopCenter: placement = "TopCenter"; break;
|
|
|
|
case BottomCenter: placement = "BottomCenter"; break;
|
|
|
|
case TopRight: placement = "TopRight"; break;
|
|
|
|
case BottomRight: placement = "BottomRight"; break;
|
|
|
|
case CenterRight: default: placement = "CenterRight"; break;
|
|
|
|
}
|
|
|
|
config.setValue(s.str(), placement);
|
2002-04-19 06:51:08 +00:00
|
|
|
s.rdbuf()->freeze(0);
|
2002-04-16 23:50:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Slit::setDirection(int d) {
|
|
|
|
m_direction = d;
|
|
|
|
ostrstream s;
|
|
|
|
s << "session.screen" << screen.getScreenNumber() << ".slit.direction" <<
|
|
|
|
ends;
|
|
|
|
config.setValue(s.str(),
|
|
|
|
m_direction == Horizontal ? "Horizontal" : "Vertical");
|
2002-04-19 06:51:08 +00:00
|
|
|
s.rdbuf()->freeze(0);
|
2002-04-16 23:50:53 +00:00
|
|
|
}
|
|
|
|
|
2002-04-17 08:30:55 +00:00
|
|
|
void Slit::save() {
|
|
|
|
setOnTop(m_ontop);
|
|
|
|
setAutoHide(m_autohide);
|
|
|
|
setPlacement(m_placement);
|
|
|
|
setDirection(m_direction);
|
|
|
|
}
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
void Slit::load() {
|
|
|
|
std::ostrstream rscreen, rname, rclass;
|
|
|
|
std::string s;
|
|
|
|
bool b;
|
|
|
|
rscreen << "session.screen" << screen.getScreenNumber() << '.' << ends;
|
|
|
|
|
|
|
|
rname << rscreen.str() << "slit.placement" << ends;
|
|
|
|
rclass << rscreen.str() << "Slit.Placement" << ends;
|
|
|
|
if (config.getValue(rname.str(), rclass.str(), s)) {
|
|
|
|
if (0 == strncasecmp(s.c_str(), "TopLeft", s.length()))
|
|
|
|
m_placement = TopLeft;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "CenterLeft", s.length()))
|
|
|
|
m_placement = CenterLeft;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "BottomLeft", s.length()))
|
|
|
|
m_placement = BottomLeft;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "TopCenter", s.length()))
|
|
|
|
m_placement = TopCenter;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "BottomCenter", s.length()))
|
|
|
|
m_placement = BottomCenter;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "TopRight", s.length()))
|
|
|
|
m_placement = TopRight;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "BottomRight", s.length()))
|
|
|
|
m_placement = BottomRight;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "CenterRight", s.length()))
|
|
|
|
m_placement = CenterRight;
|
|
|
|
}
|
|
|
|
|
|
|
|
rname.seekp(0); rclass.seekp(0);
|
|
|
|
rname << rscreen.str() << "slit.direction" << ends;
|
|
|
|
rclass << rscreen.str() << "Slit.Direction" << ends;
|
|
|
|
if (config.getValue(rname.str(), rclass.str(), s)) {
|
|
|
|
if (0 == strncasecmp(s.c_str(), "Horizontal", s.length()))
|
|
|
|
m_direction = Horizontal;
|
|
|
|
else if (0 == strncasecmp(s.c_str(), "Vertical", s.length()))
|
|
|
|
m_direction = Vertical;
|
|
|
|
}
|
|
|
|
|
|
|
|
rname.seekp(0); rclass.seekp(0);
|
|
|
|
rname << rscreen.str() << "slit.onTop" << ends;
|
|
|
|
rclass << rscreen.str() << "Slit.OnTop" << ends;
|
|
|
|
if (config.getValue(rname.str(), rclass.str(), b))
|
|
|
|
m_ontop = b;
|
|
|
|
|
|
|
|
rname.seekp(0); rclass.seekp(0);
|
|
|
|
rname << rscreen.str() << "slit.autoHide" << ends;
|
|
|
|
rclass << rscreen.str() << "Slit.AutoHide" << ends;
|
|
|
|
if (config.getValue(rname.str(), rclass.str(), b))
|
|
|
|
m_hidden = m_autohide = b;
|
2002-04-19 06:51:08 +00:00
|
|
|
rscreen.rdbuf()->freeze(0);
|
|
|
|
rname.rdbuf()->freeze(0);
|
|
|
|
rclass.rdbuf()->freeze(0);
|
2002-04-16 23:50:53 +00:00
|
|
|
}
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
void Slit::reconfigure(void) {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setSize(0, 0);
|
2002-04-11 03:20:38 +00:00
|
|
|
LinkedListIterator<SlitClient> it(clientList);
|
|
|
|
SlitClient *client;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
switch (m_direction) {
|
2002-04-11 03:20:38 +00:00
|
|
|
case Vertical:
|
|
|
|
for (client = it.current(); client; it++, client = it.current()) {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setH(frame.area.h() + client->height + screen.getBevelWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.w() < client->width)
|
|
|
|
frame.area.setW(client->width);
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.w() < 1)
|
|
|
|
frame.area.setW(1);
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setW(frame.area.w() + (screen.getBevelWidth() * 2));
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.h() < 1)
|
|
|
|
frame.area.setH(1);
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setH(frame.area.h() + screen.getBevelWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Horizontal:
|
|
|
|
for (client = it.current(); client; it++, client = it.current()) {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setW(frame.area.w() + client->width + screen.getBevelWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.h() < client->height)
|
|
|
|
frame.area.setH(client->height);
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.w() < 1)
|
|
|
|
frame.area.setW(1);
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setW(frame.area.w() + screen.getBevelWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.h() < 1)
|
|
|
|
frame.area.setH(1);
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setH(frame.area.h() + (screen.getBevelWidth() * 2));
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
reposition();
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
XSetWindowBorderWidth(display ,frame.window, screen.getBorderWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
XSetWindowBorder(display, frame.window,
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.getBorderColor()->getPixel());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
if (! clientList->count())
|
|
|
|
XUnmapWindow(display, frame.window);
|
|
|
|
else
|
|
|
|
XMapWindow(display, frame.window);
|
|
|
|
|
|
|
|
Pixmap tmp = frame.pixmap;
|
2002-04-14 13:58:17 +00:00
|
|
|
BImageControl *image_ctrl = screen.getImageControl();
|
|
|
|
BTexture *texture = &(screen.getToolbarStyle()->toolbar);
|
2002-04-11 03:20:38 +00:00
|
|
|
if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
|
|
|
|
frame.pixmap = None;
|
|
|
|
XSetWindowBackground(display, frame.window,
|
|
|
|
texture->getColor()->getPixel());
|
|
|
|
} else {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.pixmap = image_ctrl->renderImage(frame.area.w(), frame.area.h(),
|
2002-04-11 03:20:38 +00:00
|
|
|
texture);
|
|
|
|
XSetWindowBackgroundPixmap(display, frame.window, frame.pixmap);
|
|
|
|
}
|
|
|
|
if (tmp) image_ctrl->removeImage(tmp);
|
|
|
|
XClearWindow(display, frame.window);
|
|
|
|
|
|
|
|
int x, y;
|
|
|
|
it.reset();
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
switch (m_direction) {
|
2002-04-11 03:20:38 +00:00
|
|
|
case Vertical:
|
|
|
|
x = 0;
|
2002-04-14 13:58:17 +00:00
|
|
|
y = screen.getBevelWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
for (client = it.current(); client; it++, client = it.current()) {
|
2002-04-14 19:30:38 +00:00
|
|
|
x = (frame.area.w() - client->width) / 2;
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
XMoveResizeWindow(display, client->window, x, y,
|
|
|
|
client->width, client->height);
|
|
|
|
XMapWindow(display, client->window);
|
|
|
|
|
|
|
|
// for ICCCM compliance
|
|
|
|
client->x = x;
|
|
|
|
client->y = y;
|
|
|
|
|
|
|
|
XEvent event;
|
|
|
|
event.type = ConfigureNotify;
|
|
|
|
|
|
|
|
event.xconfigure.display = display;
|
|
|
|
event.xconfigure.event = client->window;
|
|
|
|
event.xconfigure.window = client->window;
|
|
|
|
event.xconfigure.x = x;
|
|
|
|
event.xconfigure.y = y;
|
|
|
|
event.xconfigure.width = client->width;
|
|
|
|
event.xconfigure.height = client->height;
|
|
|
|
event.xconfigure.border_width = 0;
|
|
|
|
event.xconfigure.above = frame.window;
|
|
|
|
event.xconfigure.override_redirect = False;
|
|
|
|
|
|
|
|
XSendEvent(display, client->window, False, StructureNotifyMask, &event);
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
y += client->height + screen.getBevelWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Horizontal:
|
2002-04-14 13:58:17 +00:00
|
|
|
x = screen.getBevelWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
y = 0;
|
|
|
|
|
|
|
|
for (client = it.current(); client; it++, client = it.current()) {
|
2002-04-14 19:30:38 +00:00
|
|
|
y = (frame.area.h() - client->height) / 2;
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
XMoveResizeWindow(display, client->window, x, y,
|
|
|
|
client->width, client->height);
|
|
|
|
XMapWindow(display, client->window);
|
|
|
|
|
|
|
|
// for ICCCM compliance
|
|
|
|
client->x = x;
|
|
|
|
client->y = y;
|
|
|
|
|
|
|
|
XEvent event;
|
|
|
|
event.type = ConfigureNotify;
|
|
|
|
|
|
|
|
event.xconfigure.display = display;
|
|
|
|
event.xconfigure.event = client->window;
|
|
|
|
event.xconfigure.window = client->window;
|
|
|
|
event.xconfigure.x = x;
|
|
|
|
event.xconfigure.y = y;
|
|
|
|
event.xconfigure.width = client->width;
|
|
|
|
event.xconfigure.height = client->height;
|
|
|
|
event.xconfigure.border_width = 0;
|
|
|
|
event.xconfigure.above = frame.window;
|
|
|
|
event.xconfigure.override_redirect = False;
|
|
|
|
|
|
|
|
XSendEvent(display, client->window, False, StructureNotifyMask, &event);
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
x += client->width + screen.getBevelWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
slitmenu->reconfigure();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::reposition(void) {
|
|
|
|
// place the slit in the appropriate place
|
2002-04-16 23:50:53 +00:00
|
|
|
switch (m_placement) {
|
2002-04-11 03:20:38 +00:00
|
|
|
case TopLeft:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(0, 0);
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical) {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden = Point(screen.getBevelWidth() - screen.getBorderWidth()
|
|
|
|
- frame.area.w(), 0);
|
2002-04-11 03:20:38 +00:00
|
|
|
} else {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden = Point(0, screen.getBevelWidth() - screen.getBorderWidth()
|
|
|
|
- frame.area.h());
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CenterLeft:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(0, (screen.size().h() - frame.area.h()) / 2);
|
|
|
|
frame.hidden = Point(screen.getBevelWidth() - screen.getBorderWidth()
|
|
|
|
- frame.area.w(), frame.area.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case BottomLeft:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(0, screen.size().h() - frame.area.h()
|
|
|
|
- (screen.getBorderWidth() * 2));
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical)
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden = Point(screen.getBevelWidth() - screen.getBorderWidth()
|
|
|
|
- frame.area.w(), frame.area.y());
|
|
|
|
else
|
|
|
|
frame.hidden = Point(0, screen.size().h() - screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TopCenter:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin((screen.size().w() - frame.area.w()) / 2, 0);
|
|
|
|
frame.hidden = Point(frame.area.x(), screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth() - frame.area.h());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case BottomCenter:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin((screen.size().w() - frame.area.w()) / 2,
|
|
|
|
screen.size().h() - frame.area.h()
|
|
|
|
- (screen.getBorderWidth() * 2));
|
|
|
|
frame.hidden = Point(frame.area.x(), screen.size().h()
|
|
|
|
- screen.getBevelWidth() - screen.getBorderWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TopRight:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(screen.size().w() - frame.area.w()
|
|
|
|
- (screen.getBorderWidth() * 2), 0);
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical)
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden = Point(screen.size().w() - screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth(), 0);
|
|
|
|
else
|
|
|
|
frame.hidden = Point(frame.area.x(), screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth() - frame.area.h());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case CenterRight:
|
|
|
|
default:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(screen.size().w() - frame.area.w()
|
|
|
|
- (screen.getBorderWidth() * 2),
|
|
|
|
(screen.size().h() - frame.area.h()) / 2);
|
|
|
|
frame.hidden = Point(screen.size().w() - screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth(), frame.area.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case BottomRight:
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setOrigin(screen.size().w() - frame.area.w()
|
|
|
|
- (screen.getBorderWidth() * 2),
|
|
|
|
screen.size().h() - frame.area.h()
|
|
|
|
- (screen.getBorderWidth() * 2));
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical)
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden = Point(screen.size().w() - screen.getBevelWidth()
|
|
|
|
- screen.getBorderWidth(), frame.area.y());
|
|
|
|
else
|
2002-04-16 23:50:53 +00:00
|
|
|
frame.hidden = Point(frame.area.x(), screen.size().h() -
|
|
|
|
screen.getBevelWidth() - screen.getBorderWidth());
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
Toolbar *tbar = screen.getToolbar();
|
2002-04-14 19:30:38 +00:00
|
|
|
int sw = frame.area.w() + (screen.getBorderWidth() * 2),
|
|
|
|
sh = frame.area.h() + (screen.getBorderWidth() * 2),
|
2002-04-14 13:58:17 +00:00
|
|
|
tw = tbar->getWidth() + screen.getBorderWidth(),
|
|
|
|
th = tbar->getHeight() + screen.getBorderWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (tbar->getX() < frame.area.x() + sw &&
|
|
|
|
tbar->getX() + tw > frame.area.x() &&
|
|
|
|
tbar->getY() < frame.area.y() + sh &&
|
|
|
|
tbar->getY() + th > frame.area.y()) {
|
2002-04-14 19:30:38 +00:00
|
|
|
if (frame.area.y() < th) {
|
|
|
|
frame.area.setY(frame.area.y() + tbar->getExposedHeight());
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical)
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden.setY(frame.hidden.y() + tbar->getExposedHeight());
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden.setY(frame.area.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
} else {
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.area.setY(frame.area.y() - tbar->getExposedHeight());
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_direction == Vertical)
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden.setY(frame.area.y() - tbar->getExposedHeight());
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
frame.hidden.setY(frame.area.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_hidden)
|
2002-04-14 19:30:38 +00:00
|
|
|
XMoveResizeWindow(display, frame.window, frame.hidden.x(),
|
|
|
|
frame.hidden.y(), frame.area.w(), frame.area.h());
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
XMoveResizeWindow(display, frame.window, frame.area.x(),
|
|
|
|
frame.area.y(), frame.area.w(), frame.area.h());
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::shutdown(void) {
|
|
|
|
while (clientList->count())
|
|
|
|
removeClient(clientList->first());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::buttonPressEvent(XButtonEvent *e) {
|
|
|
|
if (e->window != frame.window) return;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (e->button == Button1 && !m_ontop) {
|
2002-04-11 03:20:38 +00:00
|
|
|
Window w[1] = { frame.window };
|
2002-04-14 13:58:17 +00:00
|
|
|
screen.raiseWindows(w, 1);
|
2002-04-16 23:50:53 +00:00
|
|
|
} else if (e->button == Button2 && !m_ontop) {
|
2002-04-11 03:20:38 +00:00
|
|
|
XLowerWindow(display, frame.window);
|
|
|
|
} else if (e->button == Button3) {
|
|
|
|
if (! slitmenu->isVisible()) {
|
|
|
|
int x, y;
|
|
|
|
|
|
|
|
x = e->x_root - (slitmenu->getWidth() / 2);
|
|
|
|
y = e->y_root - (slitmenu->getHeight() / 2);
|
|
|
|
|
|
|
|
if (x < 0)
|
|
|
|
x = 0;
|
2002-04-14 18:48:32 +00:00
|
|
|
else if (x + slitmenu->getWidth() > screen.size().w())
|
|
|
|
x = screen.size().w() - slitmenu->getWidth();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
if (y < 0)
|
|
|
|
y = 0;
|
2002-04-14 18:48:32 +00:00
|
|
|
else if (y + slitmenu->getHeight() > screen.size().h())
|
|
|
|
y = screen.size().h() - slitmenu->getHeight();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
slitmenu->move(x, y);
|
|
|
|
slitmenu->show();
|
|
|
|
} else {
|
|
|
|
slitmenu->hide();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::enterNotifyEvent(XCrossingEvent *) {
|
2002-04-16 23:50:53 +00:00
|
|
|
if (!m_autohide)
|
2002-04-11 03:20:38 +00:00
|
|
|
return;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_hidden) {
|
2002-04-11 03:20:38 +00:00
|
|
|
if (! timer->isTiming()) timer->start();
|
|
|
|
} else {
|
|
|
|
if (timer->isTiming()) timer->stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::leaveNotifyEvent(XCrossingEvent *) {
|
2002-04-16 23:50:53 +00:00
|
|
|
if (!m_autohide)
|
2002-04-11 03:20:38 +00:00
|
|
|
return;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (m_hidden) {
|
2002-04-11 03:20:38 +00:00
|
|
|
if (timer->isTiming()) timer->stop();
|
|
|
|
} else if (! slitmenu->isVisible()) {
|
2002-04-16 23:50:53 +00:00
|
|
|
if (!timer->isTiming()) timer->start();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::configureRequestEvent(XConfigureRequestEvent *e) {
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.grab();
|
2002-04-11 03:20:38 +00:00
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
if (openbox.validateWindow(e->window)) {
|
2002-04-11 03:20:38 +00:00
|
|
|
Bool reconf = False;
|
|
|
|
XWindowChanges xwc;
|
|
|
|
|
|
|
|
xwc.x = e->x;
|
|
|
|
xwc.y = e->y;
|
|
|
|
xwc.width = e->width;
|
|
|
|
xwc.height = e->height;
|
|
|
|
xwc.border_width = 0;
|
|
|
|
xwc.sibling = e->above;
|
|
|
|
xwc.stack_mode = e->detail;
|
|
|
|
|
|
|
|
XConfigureWindow(display, e->window, e->value_mask, &xwc);
|
|
|
|
|
|
|
|
LinkedListIterator<SlitClient> it(clientList);
|
|
|
|
SlitClient *client = it.current();
|
|
|
|
for (; client; it++, client = it.current())
|
|
|
|
if (client->window == e->window)
|
|
|
|
if (client->width != ((unsigned) e->width) ||
|
|
|
|
client->height != ((unsigned) e->height)) {
|
|
|
|
client->width = (unsigned) e->width;
|
|
|
|
client->height = (unsigned) e->height;
|
|
|
|
|
|
|
|
reconf = True;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (reconf) reconfigure();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
openbox.ungrab();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slit::timeout(void) {
|
2002-04-16 23:50:53 +00:00
|
|
|
m_hidden = !m_hidden;
|
|
|
|
if (m_hidden)
|
2002-04-14 19:30:38 +00:00
|
|
|
XMoveWindow(display, frame.window, frame.hidden.x(), frame.hidden.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
else
|
2002-04-14 19:30:38 +00:00
|
|
|
XMoveWindow(display, frame.window, frame.area.x(), frame.area.y());
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-04-14 13:58:17 +00:00
|
|
|
Slitmenu::Slitmenu(Slit &sl) : Basemenu(sl.screen), slit(sl) {
|
2002-04-11 03:20:38 +00:00
|
|
|
setLabel(i18n->getMessage(SlitSet, SlitSlitTitle, "Slit"));
|
|
|
|
setInternalMenu();
|
|
|
|
|
2002-04-14 11:37:22 +00:00
|
|
|
directionmenu = new Directionmenu(*this);
|
|
|
|
placementmenu = new Placementmenu(*this);
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonDirectionTitle, "Direction"),
|
|
|
|
directionmenu);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementTitle, "Placement"),
|
|
|
|
placementmenu);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonAlwaysOnTop, "Always on top"), 1);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonAutoHide, "Auto hide"), 2);
|
|
|
|
|
|
|
|
update();
|
|
|
|
|
2002-04-17 23:07:11 +00:00
|
|
|
setValues();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Slitmenu::setValues() {
|
|
|
|
setItemSelected(2, slit.onTop());
|
|
|
|
setItemSelected(3, slit.autoHide());
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Slitmenu::~Slitmenu(void) {
|
|
|
|
delete directionmenu;
|
|
|
|
delete placementmenu;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slitmenu::itemSelected(int button, int index) {
|
|
|
|
if (button != 1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
BasemenuItem *item = find(index);
|
|
|
|
if (! item) return;
|
|
|
|
|
|
|
|
switch (item->function()) {
|
|
|
|
case 1: { // always on top
|
2002-04-16 23:50:53 +00:00
|
|
|
bool change = ((slit.onTop()) ? false : true);
|
|
|
|
slit.setOnTop(change);
|
2002-04-11 03:20:38 +00:00
|
|
|
setItemSelected(2, change);
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
if (slit.onTop()) slit.screen.raiseWindows((Window *) 0, 0);
|
2002-04-11 03:20:38 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case 2: { // auto hide
|
2002-04-16 23:50:53 +00:00
|
|
|
Bool change = ((slit.autoHide()) ? false : true);
|
|
|
|
slit.setAutoHide(change);
|
2002-04-11 03:20:38 +00:00
|
|
|
setItemSelected(3, change);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} // switch
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slitmenu::internal_hide(void) {
|
|
|
|
Basemenu::internal_hide();
|
2002-04-16 23:50:53 +00:00
|
|
|
if (slit.autoHide())
|
2002-04-14 11:37:22 +00:00
|
|
|
slit.timeout();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slitmenu::reconfigure(void) {
|
2002-04-17 23:07:11 +00:00
|
|
|
setValues();
|
2002-04-11 03:20:38 +00:00
|
|
|
directionmenu->reconfigure();
|
|
|
|
placementmenu->reconfigure();
|
|
|
|
|
|
|
|
Basemenu::reconfigure();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-04-14 11:37:22 +00:00
|
|
|
Slitmenu::Directionmenu::Directionmenu(Slitmenu &sm)
|
2002-04-14 13:58:17 +00:00
|
|
|
: Basemenu(sm.slit.screen), slitmenu(sm) {
|
2002-04-11 03:20:38 +00:00
|
|
|
setLabel(i18n->getMessage(SlitSet, SlitSlitDirection, "Slit Direction"));
|
|
|
|
setInternalMenu();
|
|
|
|
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonDirectionHoriz, "Horizontal"),
|
|
|
|
Slit::Horizontal);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonDirectionVert, "Vertical"),
|
|
|
|
Slit::Vertical);
|
|
|
|
|
|
|
|
update();
|
|
|
|
|
2002-04-17 23:07:11 +00:00
|
|
|
setValues();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slitmenu::Directionmenu::setValues() {
|
|
|
|
if (slitmenu.slit.direction() == Slit::Horizontal)
|
2002-04-11 03:20:38 +00:00
|
|
|
setItemSelected(0, True);
|
|
|
|
else
|
|
|
|
setItemSelected(1, True);
|
|
|
|
}
|
|
|
|
|
2002-04-17 23:07:11 +00:00
|
|
|
void Slitmenu::Directionmenu::reconfigure() {
|
|
|
|
setValues();
|
|
|
|
}
|
|
|
|
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
void Slitmenu::Directionmenu::itemSelected(int button, int index) {
|
|
|
|
if (button != 1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
BasemenuItem *item = find(index);
|
|
|
|
if (! item) return;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
slitmenu.slit.setDirection(item->function());
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
if (item->function() == Slit::Horizontal) {
|
|
|
|
setItemSelected(0, True);
|
|
|
|
setItemSelected(1, False);
|
|
|
|
} else {
|
|
|
|
setItemSelected(0, False);
|
|
|
|
setItemSelected(1, True);
|
|
|
|
}
|
|
|
|
|
|
|
|
hide();
|
2002-04-14 11:37:22 +00:00
|
|
|
slitmenu.slit.reconfigure();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-04-14 11:37:22 +00:00
|
|
|
Slitmenu::Placementmenu::Placementmenu(Slitmenu &sm)
|
2002-04-14 13:58:17 +00:00
|
|
|
: Basemenu(sm.slit.screen), slitmenu(sm) {
|
2002-04-11 03:20:38 +00:00
|
|
|
|
|
|
|
setLabel(i18n->getMessage(SlitSet, SlitSlitPlacement, "Slit Placement"));
|
|
|
|
setMinimumSublevels(3);
|
|
|
|
setInternalMenu();
|
|
|
|
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementTopLeft, "Top Left"),
|
|
|
|
Slit::TopLeft);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementCenterLeft, "Center Left"),
|
|
|
|
Slit::CenterLeft);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementBottomLeft, "Bottom Left"),
|
|
|
|
Slit::BottomLeft);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementTopCenter, "Top Center"),
|
|
|
|
Slit::TopCenter);
|
|
|
|
insert("");
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementBottomCenter,
|
|
|
|
"Bottom Center"),
|
|
|
|
Slit::BottomCenter);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementTopRight, "Top Right"),
|
|
|
|
Slit::TopRight);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementCenterRight,
|
|
|
|
"Center Right"),
|
|
|
|
Slit::CenterRight);
|
|
|
|
insert(i18n->getMessage(CommonSet, CommonPlacementBottomRight,
|
|
|
|
"Bottom Right"),
|
|
|
|
Slit::BottomRight);
|
|
|
|
|
|
|
|
update();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Slitmenu::Placementmenu::itemSelected(int button, int index) {
|
|
|
|
if (button != 1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
BasemenuItem *item = find(index);
|
|
|
|
if (! (item && item->function())) return;
|
|
|
|
|
2002-04-16 23:50:53 +00:00
|
|
|
slitmenu.slit.setPlacement(item->function());
|
2002-04-11 03:20:38 +00:00
|
|
|
hide();
|
2002-04-14 11:37:22 +00:00
|
|
|
slitmenu.slit.reconfigure();
|
2002-04-11 03:20:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // SLIT
|