indentation and timer
This commit is contained in:
parent
3ac8394996
commit
6c1f079fbd
2 changed files with 116 additions and 120 deletions
47
src/Slit.cc
47
src/Slit.cc
|
@ -42,8 +42,7 @@
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
|
|
||||||
Slit::Slit(BScreen *scr) {
|
Slit::Slit(BScreen *scr):screen(scr), timer(this), slitmenu(this) {
|
||||||
screen = scr;
|
|
||||||
fluxbox = Fluxbox::instance();
|
fluxbox = Fluxbox::instance();
|
||||||
|
|
||||||
on_top = screen->isSlitOnTop();
|
on_top = screen->isSlitOnTop();
|
||||||
|
@ -52,11 +51,9 @@ Slit::Slit(BScreen *scr) {
|
||||||
display = screen->getBaseDisplay()->getXDisplay();
|
display = screen->getBaseDisplay()->getXDisplay();
|
||||||
frame.window = frame.pixmap = None;
|
frame.window = frame.pixmap = None;
|
||||||
|
|
||||||
timer = new BTimer(fluxbox, this);
|
|
||||||
timer->setTimeout(fluxbox->getAutoRaiseDelay());
|
timer.setTimeout(fluxbox->getAutoRaiseDelay());
|
||||||
timer->fireOnce(True);
|
timer.fireOnce(True);
|
||||||
|
|
||||||
slitmenu = new Slitmenu(this);
|
|
||||||
|
|
||||||
XSetWindowAttributes attrib;
|
XSetWindowAttributes attrib;
|
||||||
unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel |
|
unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel |
|
||||||
|
@ -86,10 +83,6 @@ Slit::Slit(BScreen *scr) {
|
||||||
Slit::~Slit() {
|
Slit::~Slit() {
|
||||||
fluxbox->grab();
|
fluxbox->grab();
|
||||||
|
|
||||||
delete timer;
|
|
||||||
|
|
||||||
delete slitmenu;
|
|
||||||
|
|
||||||
screen->getImageControl()->removeImage(frame.pixmap);
|
screen->getImageControl()->removeImage(frame.pixmap);
|
||||||
|
|
||||||
fluxbox->removeSlitSearch(frame.window);
|
fluxbox->removeSlitSearch(frame.window);
|
||||||
|
@ -406,7 +399,7 @@ void Slit::reconfigure(void) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
slitmenu->reconfigure();
|
slitmenu.reconfigure();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -550,26 +543,26 @@ void Slit::buttonPressEvent(XButtonEvent *e) {
|
||||||
} else if (e->button == Button2 && (! on_top)) {
|
} else if (e->button == Button2 && (! on_top)) {
|
||||||
XLowerWindow(display, frame.window);
|
XLowerWindow(display, frame.window);
|
||||||
} else if (e->button == Button3) {
|
} else if (e->button == Button3) {
|
||||||
if (! slitmenu->isVisible()) {
|
if (! slitmenu.isVisible()) {
|
||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
x = e->x_root - (slitmenu->getWidth() / 2);
|
x = e->x_root - (slitmenu.getWidth() / 2);
|
||||||
y = e->y_root - (slitmenu->getHeight() / 2);
|
y = e->y_root - (slitmenu.getHeight() / 2);
|
||||||
|
|
||||||
if (x < 0)
|
if (x < 0)
|
||||||
x = 0;
|
x = 0;
|
||||||
else if (x + slitmenu->getWidth() > screen->getWidth())
|
else if (x + slitmenu.getWidth() > screen->getWidth())
|
||||||
x = screen->getWidth() - slitmenu->getWidth();
|
x = screen->getWidth() - slitmenu.getWidth();
|
||||||
|
|
||||||
if (y < 0)
|
if (y < 0)
|
||||||
y = 0;
|
y = 0;
|
||||||
else if (y + slitmenu->getHeight() > screen->getHeight())
|
else if (y + slitmenu.getHeight() > screen->getHeight())
|
||||||
y = screen->getHeight() - slitmenu->getHeight();
|
y = screen->getHeight() - slitmenu.getHeight();
|
||||||
|
|
||||||
slitmenu->move(x, y);
|
slitmenu.move(x, y);
|
||||||
slitmenu->show();
|
slitmenu.show();
|
||||||
} else
|
} else
|
||||||
slitmenu->hide();
|
slitmenu.hide();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -579,9 +572,9 @@ void Slit::enterNotifyEvent(XCrossingEvent *) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (hidden) {
|
if (hidden) {
|
||||||
if (! timer->isTiming()) timer->start();
|
if (! timer.isTiming()) timer.start();
|
||||||
} else {
|
} else {
|
||||||
if (timer->isTiming()) timer->stop();
|
if (timer.isTiming()) timer.stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -591,9 +584,9 @@ void Slit::leaveNotifyEvent(XCrossingEvent *) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (hidden) {
|
if (hidden) {
|
||||||
if (timer->isTiming()) timer->stop();
|
if (timer.isTiming()) timer.stop();
|
||||||
} else if (! slitmenu->isVisible()) {
|
} else if (! slitmenu.isVisible()) {
|
||||||
if (! timer->isTiming()) timer->start();
|
if (! timer.isTiming()) timer.start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
189
src/Slit.hh
189
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
|
// Slit.hh for Blackbox - an X11 Window manager
|
||||||
// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
|
// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
|
||||||
//
|
//
|
||||||
|
@ -18,9 +21,9 @@
|
||||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
// 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
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
// DEALINGS IN THE SOFTWARE.
|
// DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SLIT_HH
|
#ifndef SLIT_HH
|
||||||
#define SLIT_HH
|
#define SLIT_HH
|
||||||
|
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
#include <X11/Xutil.h>
|
#include <X11/Xutil.h>
|
||||||
|
@ -35,126 +38,126 @@ class Slitmenu;
|
||||||
|
|
||||||
class Slitmenu : public Basemenu {
|
class Slitmenu : public Basemenu {
|
||||||
private:
|
private:
|
||||||
class Directionmenu : public Basemenu {
|
class Directionmenu : public Basemenu {
|
||||||
private:
|
private:
|
||||||
Slitmenu *slitmenu;
|
Slitmenu *slitmenu;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void itemSelected(int, int);
|
virtual void itemSelected(int, int);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Directionmenu(Slitmenu *);
|
Directionmenu(Slitmenu *);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Placementmenu : public Basemenu {
|
class Placementmenu : public Basemenu {
|
||||||
private:
|
private:
|
||||||
Slitmenu *slitmenu;
|
Slitmenu *slitmenu;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void itemSelected(int, int);
|
virtual void itemSelected(int, int);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Placementmenu(Slitmenu *);
|
Placementmenu(Slitmenu *);
|
||||||
};
|
};
|
||||||
|
|
||||||
Directionmenu *directionmenu;
|
Directionmenu *directionmenu;
|
||||||
Placementmenu *placementmenu;
|
Placementmenu *placementmenu;
|
||||||
|
|
||||||
Slit *slit;
|
Slit *slit;
|
||||||
|
|
||||||
friend class Directionmenu;
|
friend class Directionmenu;
|
||||||
friend class Placementmenu;
|
friend class Placementmenu;
|
||||||
friend class Slit;
|
friend class Slit;
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void itemSelected(int, int);
|
virtual void itemSelected(int, int);
|
||||||
virtual void internal_hide(void);
|
virtual void internal_hide(void);
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Slitmenu(Slit *);
|
explicit Slitmenu(Slit *);
|
||||||
virtual ~Slitmenu(void);
|
virtual ~Slitmenu(void);
|
||||||
|
|
||||||
inline Basemenu *getDirectionmenu(void) { return directionmenu; }
|
inline Basemenu *getDirectionmenu(void) { return directionmenu; }
|
||||||
inline Basemenu *getPlacementmenu(void) { return placementmenu; }
|
inline Basemenu *getPlacementmenu(void) { return placementmenu; }
|
||||||
|
|
||||||
void reconfigure(void);
|
void reconfigure(void);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class Slit : public TimeoutHandler {
|
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:
|
public:
|
||||||
Slit(BScreen *);
|
explicit Slit(BScreen *);
|
||||||
virtual ~Slit();
|
virtual ~Slit();
|
||||||
|
|
||||||
inline const Bool &isOnTop(void) const { return on_top; }
|
inline const bool isOnTop(void) const { return on_top; }
|
||||||
inline const Bool &isHidden(void) const { return hidden; }
|
inline const bool isHidden(void) const { return hidden; }
|
||||||
inline const Bool &doAutoHide(void) const { return do_auto_hide; }
|
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 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); }
|
{ 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); }
|
{ return ((hidden) ? frame.y_hidden : frame.y); }
|
||||||
|
|
||||||
inline const unsigned int &getWidth(void) const { return frame.width; }
|
inline const unsigned int getWidth(void) const { return frame.width; }
|
||||||
inline const unsigned int &getHeight(void) const { return frame.height; }
|
inline const unsigned int getHeight(void) const { return frame.height; }
|
||||||
|
|
||||||
void addClient(Window);
|
void addClient(Window);
|
||||||
void removeClient(SlitClient *, bool = true);
|
void removeClient(Window, bool = true);
|
||||||
void removeClient(Window, bool = true);
|
void reconfigure(void);
|
||||||
void reconfigure(void);
|
void reposition(void);
|
||||||
void reposition(void);
|
void shutdown(void);
|
||||||
void shutdown(void);
|
|
||||||
|
|
||||||
void buttonPressEvent(XButtonEvent *);
|
void buttonPressEvent(XButtonEvent *);
|
||||||
void enterNotifyEvent(XCrossingEvent *);
|
void enterNotifyEvent(XCrossingEvent *);
|
||||||
void leaveNotifyEvent(XCrossingEvent *);
|
void leaveNotifyEvent(XCrossingEvent *);
|
||||||
void configureRequestEvent(XConfigureRequestEvent *);
|
void configureRequestEvent(XConfigureRequestEvent *);
|
||||||
|
|
||||||
virtual void timeout(void);
|
virtual void timeout(void);
|
||||||
|
|
||||||
enum { VERTICAL = 1, HORIZONTAL };
|
enum { VERTICAL = 1, HORIZONTAL };
|
||||||
enum { TOPLEFT = 1, CENTERLEFT, BOTTOMLEFT, TOPCENTER, BOTTOMCENTER,
|
enum { TOPLEFT = 1, CENTERLEFT, BOTTOMLEFT, TOPCENTER, BOTTOMCENTER,
|
||||||
TOPRIGHT, CENTERRIGHT, BOTTOMRIGHT };
|
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