indentation and timer

This commit is contained in:
fluxgen 2002-03-19 00:07:00 +00:00
parent 3ac8394996
commit 6c1f079fbd
2 changed files with 116 additions and 120 deletions

View file

@ -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();
} }
} }

View file

@ -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;
}; };