indentation and timer
This commit is contained in:
parent
3ac8394996
commit
6c1f079fbd
2 changed files with 116 additions and 120 deletions
45
src/Slit.cc
45
src/Slit.cc
|
@ -42,8 +42,7 @@
|
|||
#include <algorithm>
|
||||
|
||||
|
||||
Slit::Slit(BScreen *scr) {
|
||||
screen = scr;
|
||||
Slit::Slit(BScreen *scr):screen(scr), timer(this), slitmenu(this) {
|
||||
fluxbox = Fluxbox::instance();
|
||||
|
||||
on_top = screen->isSlitOnTop();
|
||||
|
@ -52,11 +51,9 @@ Slit::Slit(BScreen *scr) {
|
|||
display = screen->getBaseDisplay()->getXDisplay();
|
||||
frame.window = frame.pixmap = None;
|
||||
|
||||
timer = new BTimer(fluxbox, this);
|
||||
timer->setTimeout(fluxbox->getAutoRaiseDelay());
|
||||
timer->fireOnce(True);
|
||||
|
||||
slitmenu = new Slitmenu(this);
|
||||
timer.setTimeout(fluxbox->getAutoRaiseDelay());
|
||||
timer.fireOnce(True);
|
||||
|
||||
XSetWindowAttributes attrib;
|
||||
unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel |
|
||||
|
@ -86,10 +83,6 @@ Slit::Slit(BScreen *scr) {
|
|||
Slit::~Slit() {
|
||||
fluxbox->grab();
|
||||
|
||||
delete timer;
|
||||
|
||||
delete slitmenu;
|
||||
|
||||
screen->getImageControl()->removeImage(frame.pixmap);
|
||||
|
||||
fluxbox->removeSlitSearch(frame.window);
|
||||
|
@ -406,7 +399,7 @@ void Slit::reconfigure(void) {
|
|||
break;
|
||||
}
|
||||
|
||||
slitmenu->reconfigure();
|
||||
slitmenu.reconfigure();
|
||||
}
|
||||
|
||||
|
||||
|
@ -550,26 +543,26 @@ void Slit::buttonPressEvent(XButtonEvent *e) {
|
|||
} else if (e->button == Button2 && (! on_top)) {
|
||||
XLowerWindow(display, frame.window);
|
||||
} else if (e->button == Button3) {
|
||||
if (! slitmenu->isVisible()) {
|
||||
if (! slitmenu.isVisible()) {
|
||||
int x, y;
|
||||
|
||||
x = e->x_root - (slitmenu->getWidth() / 2);
|
||||
y = e->y_root - (slitmenu->getHeight() / 2);
|
||||
x = e->x_root - (slitmenu.getWidth() / 2);
|
||||
y = e->y_root - (slitmenu.getHeight() / 2);
|
||||
|
||||
if (x < 0)
|
||||
x = 0;
|
||||
else if (x + slitmenu->getWidth() > screen->getWidth())
|
||||
x = screen->getWidth() - slitmenu->getWidth();
|
||||
else if (x + slitmenu.getWidth() > screen->getWidth())
|
||||
x = screen->getWidth() - slitmenu.getWidth();
|
||||
|
||||
if (y < 0)
|
||||
y = 0;
|
||||
else if (y + slitmenu->getHeight() > screen->getHeight())
|
||||
y = screen->getHeight() - slitmenu->getHeight();
|
||||
else if (y + slitmenu.getHeight() > screen->getHeight())
|
||||
y = screen->getHeight() - slitmenu.getHeight();
|
||||
|
||||
slitmenu->move(x, y);
|
||||
slitmenu->show();
|
||||
slitmenu.move(x, y);
|
||||
slitmenu.show();
|
||||
} else
|
||||
slitmenu->hide();
|
||||
slitmenu.hide();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -579,9 +572,9 @@ void Slit::enterNotifyEvent(XCrossingEvent *) {
|
|||
return;
|
||||
|
||||
if (hidden) {
|
||||
if (! timer->isTiming()) timer->start();
|
||||
if (! timer.isTiming()) timer.start();
|
||||
} else {
|
||||
if (timer->isTiming()) timer->stop();
|
||||
if (timer.isTiming()) timer.stop();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -591,9 +584,9 @@ void Slit::leaveNotifyEvent(XCrossingEvent *) {
|
|||
return;
|
||||
|
||||
if (hidden) {
|
||||
if (timer->isTiming()) timer->stop();
|
||||
} else if (! slitmenu->isVisible()) {
|
||||
if (! timer->isTiming()) timer->start();
|
||||
if (timer.isTiming()) timer.stop();
|
||||
} else if (! slitmenu.isVisible()) {
|
||||
if (! timer.isTiming()) timer.start();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
93
src/Slit.hh
93
src/Slit.hh
|
@ -1,3 +1,6 @@
|
|||
// Slit.hh for Fluxbox
|
||||
// Copyright (c) 2002 Henrik Kinnunen (fluxgen@linuxmail.org)
|
||||
//
|
||||
// Slit.hh for Blackbox - an X11 Window manager
|
||||
// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
|
||||
//
|
||||
|
@ -73,7 +76,7 @@ protected:
|
|||
|
||||
|
||||
public:
|
||||
Slitmenu(Slit *);
|
||||
explicit Slitmenu(Slit *);
|
||||
virtual ~Slitmenu(void);
|
||||
|
||||
inline Basemenu *getDirectionmenu(void) { return directionmenu; }
|
||||
|
@ -84,62 +87,27 @@ public:
|
|||
|
||||
|
||||
class Slit : public TimeoutHandler {
|
||||
private:
|
||||
class SlitClient {
|
||||
public:
|
||||
Window window, client_window, icon_window;
|
||||
|
||||
int x, y;
|
||||
unsigned int width, height;
|
||||
};
|
||||
|
||||
Bool on_top, hidden, do_auto_hide;
|
||||
Display *display;
|
||||
|
||||
Fluxbox *fluxbox;
|
||||
BScreen *screen;
|
||||
BTimer *timer;
|
||||
|
||||
typedef std::list<SlitClient *> SlitClients;
|
||||
|
||||
SlitClients clientList;
|
||||
Slitmenu *slitmenu;
|
||||
|
||||
struct frame {
|
||||
Pixmap pixmap;
|
||||
Window window;
|
||||
|
||||
int x, y, x_hidden, y_hidden;
|
||||
unsigned int width, height;
|
||||
} frame;
|
||||
|
||||
friend class Slitmenu;
|
||||
friend class Slitmenu::Directionmenu;
|
||||
friend class Slitmenu::Placementmenu;
|
||||
|
||||
|
||||
public:
|
||||
Slit(BScreen *);
|
||||
explicit Slit(BScreen *);
|
||||
virtual ~Slit();
|
||||
|
||||
inline const Bool &isOnTop(void) const { return on_top; }
|
||||
inline const Bool &isHidden(void) const { return hidden; }
|
||||
inline const Bool &doAutoHide(void) const { return do_auto_hide; }
|
||||
inline const bool isOnTop(void) const { return on_top; }
|
||||
inline const bool isHidden(void) const { return hidden; }
|
||||
inline const bool doAutoHide(void) const { return do_auto_hide; }
|
||||
|
||||
inline Slitmenu *getMenu() { return slitmenu; }
|
||||
Slitmenu &getMenu() { return slitmenu; }
|
||||
|
||||
inline const Window &getWindowID() const { return frame.window; }
|
||||
|
||||
inline const int &getX(void) const
|
||||
inline const int getX(void) const
|
||||
{ return ((hidden) ? frame.x_hidden : frame.x); }
|
||||
inline const int &getY(void) const
|
||||
inline const int getY(void) const
|
||||
{ return ((hidden) ? frame.y_hidden : frame.y); }
|
||||
|
||||
inline const unsigned int &getWidth(void) const { return frame.width; }
|
||||
inline const unsigned int &getHeight(void) const { return frame.height; }
|
||||
inline const unsigned int getWidth(void) const { return frame.width; }
|
||||
inline const unsigned int getHeight(void) const { return frame.height; }
|
||||
|
||||
void addClient(Window);
|
||||
void removeClient(SlitClient *, bool = true);
|
||||
void removeClient(Window, bool = true);
|
||||
void reconfigure(void);
|
||||
void reposition(void);
|
||||
|
@ -155,6 +123,41 @@ public:
|
|||
enum { VERTICAL = 1, HORIZONTAL };
|
||||
enum { TOPLEFT = 1, CENTERLEFT, BOTTOMLEFT, TOPCENTER, BOTTOMCENTER,
|
||||
TOPRIGHT, CENTERRIGHT, BOTTOMRIGHT };
|
||||
|
||||
private:
|
||||
class SlitClient {
|
||||
public:
|
||||
Window window, client_window, icon_window;
|
||||
|
||||
int x, y;
|
||||
unsigned int width, height;
|
||||
};
|
||||
|
||||
void removeClient(SlitClient *, bool = true);
|
||||
|
||||
Bool on_top, hidden, do_auto_hide;
|
||||
Display *display;
|
||||
|
||||
Fluxbox *fluxbox;
|
||||
BScreen *screen;
|
||||
BTimer timer;
|
||||
|
||||
typedef std::list<SlitClient *> SlitClients;
|
||||
|
||||
SlitClients clientList;
|
||||
Slitmenu slitmenu;
|
||||
|
||||
struct frame {
|
||||
Pixmap pixmap;
|
||||
Window window;
|
||||
|
||||
int x, y, x_hidden, y_hidden;
|
||||
unsigned int width, height;
|
||||
} frame;
|
||||
|
||||
friend class Slitmenu;
|
||||
friend class Slitmenu::Directionmenu;
|
||||
friend class Slitmenu::Placementmenu;
|
||||
};
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue