implement moveWindowUp/Down/Left/Right

This commit is contained in:
Dana Jansens 2002-07-20 18:16:52 +00:00
parent a16ae87339
commit f7a41999bf
5 changed files with 145 additions and 4 deletions

View file

@ -42,10 +42,10 @@ public:
close, //done close, //done
toggleshade, //done toggleshade, //done
toggleomnipresent, //done toggleomnipresent, //done
moveWindowUp, moveWindowUp, //done
moveWindowDown, moveWindowDown, //done
moveWindowLeft, moveWindowLeft, //done
moveWindowRight, moveWindowRight, //done
toggleMaximizeFull, toggleMaximizeFull,
toggleMaximizeVertical, toggleMaximizeVertical,

View file

@ -118,6 +118,22 @@ epist::epist(char **argv, char *dpy_name, char *rc_file)
XKeysymToKeycode(getXDisplay(), XKeysymToKeycode(getXDisplay(),
XStringToKeysym("Down")), XStringToKeysym("Down")),
Mod1Mask)); Mod1Mask));
_actions.push_back(Action(Action::moveWindowUp,
XKeysymToKeycode(getXDisplay(),
XStringToKeysym("Up")),
Mod1Mask | ControlMask, 1));
_actions.push_back(Action(Action::moveWindowDown,
XKeysymToKeycode(getXDisplay(),
XStringToKeysym("Down")),
Mod1Mask | ControlMask, 1));
_actions.push_back(Action(Action::moveWindowLeft,
XKeysymToKeycode(getXDisplay(),
XStringToKeysym("Left")),
Mod1Mask | ControlMask, 1));
_actions.push_back(Action(Action::moveWindowRight,
XKeysymToKeycode(getXDisplay(),
XStringToKeysym("Right")),
Mod1Mask | ControlMask, 1));
_actions.push_back(Action(Action::iconify, _actions.push_back(Action(Action::iconify,
XKeysymToKeycode(getXDisplay(), XKeysymToKeycode(getXDisplay(),
XStringToKeysym("I")), XStringToKeysym("I")),

View file

@ -245,6 +245,22 @@ void screen::handleKeypress(const XEvent &e) {
window->sendTo(0xffffffff); window->sendTo(0xffffffff);
return; return;
case Action::moveWindowUp:
window->move(0, -it->number());
return;
case Action::moveWindowDown:
window->move(0, it->number());
return;
case Action::moveWindowLeft:
window->move(-it->number(), 0);
return;
case Action::moveWindowRight:
window->move(it->number(), 0);
return;
case Action::toggleshade: case Action::toggleshade:
window->shade(! window->shaded()); window->shade(! window->shaded());
return; return;

View file

@ -141,7 +141,106 @@ void XWindow::processEvent(const XEvent &e) {
break; break;
} }
} }
void XWindow::findFramePosition(int &x, int &y) const {
Window win = _window, parent, root, last = None;
Window *children = 0;
unsigned int nchildren;
int gravity, top, bottom, left, right;
XWindowAttributes wattr;
XSizeHints size;
long ret;
unsigned int cwidth, cheight;
// get the location, size and gravity of the client window
if (! XGetWindowAttributes(_epist->getXDisplay(), _window, &wattr)) return;
cwidth = wattr.width;
cheight = wattr.height;
if (! XGetWMNormalHints(_epist->getXDisplay(), _window, &size, &ret)) return;
if (size.flags & PWinGravity)
gravity = size.win_gravity;
else
gravity = NorthWestGravity;
while (XQueryTree(_epist->getXDisplay(), win, &root, &parent, &children,
&nchildren)) {
if (children && nchildren > 0)
XFree(children); // don't care about the children
if (! parent) // no parent!?
return;
// if the parent window is the root window, stop here
if (parent == root)
break;
last = win;
win = parent;
}
if (! (XTranslateCoordinates(_epist->getXDisplay(), last, win, 0, 0,
&left, &top, &parent) &&
XGetWindowAttributes(_epist->getXDisplay(), win, &wattr)))
return;
right = wattr.width - cwidth - left;
bottom = wattr.height - cheight - top;
left += wattr.border_width;
right += wattr.border_width;
top += wattr.border_width;
bottom += wattr.border_width;
// find the client's location
x = wattr.x + left;
y = wattr.y + top;
// this makes things work. why? i don't know. but you need them.
right -= 2;
bottom -= 2;
// find the frame's reference position based on the window's gravity
switch (gravity) {
case NorthWestGravity:
x -= left;
y -= top;
break;
case NorthGravity:
x += (left + right) / 2;
y -= top;
break;
case NorthEastGravity:
x += right;
y -= top;
case WestGravity:
x -= left;
y += (top + bottom) / 2;
break;
case CenterGravity:
x += (left + right) / 2;
y += (top + bottom) / 2;
break;
case EastGravity:
x += right;
y += (top + bottom) / 2;
case SouthWestGravity:
x -= left;
y += bottom;
break;
case SouthGravity:
x += (left + right) / 2;
y += bottom;
break;
case SouthEastGravity:
x += right;
y += bottom;
break;
default:
break;
}
}
void XWindow::shade(const bool sh) const { void XWindow::shade(const bool sh) const {
_xatom->sendClientMessage(_screen->rootWindow(), XAtom::net_wm_state, _xatom->sendClientMessage(_screen->rootWindow(), XAtom::net_wm_state,
@ -183,3 +282,10 @@ void XWindow::sendTo(unsigned int dest) const {
_xatom->sendClientMessage(_screen->rootWindow(), XAtom::net_wm_desktop, _xatom->sendClientMessage(_screen->rootWindow(), XAtom::net_wm_desktop,
_window, dest); _window, dest);
} }
void XWindow::move(int x, int y) const {
int fx, fy;
findFramePosition(fx, fy);
XMoveWindow(_epist->getXDisplay(), _window, fx + x, fy + y);
}

View file

@ -62,6 +62,8 @@ private:
void updateTitle(); void updateTitle();
void updateClass(); void updateClass();
void findFramePosition(int &x, int &y) const;
public: public:
XWindow(epist *epist, screen *screen, Window window); XWindow(epist *epist, screen *screen, Window window);
virtual ~XWindow(); virtual ~XWindow();
@ -87,6 +89,7 @@ public:
void iconify() const; void iconify() const;
void focus() const; void focus() const;
void sendTo(unsigned int dest) const; void sendTo(unsigned int dest) const;
void move(int x, int y) const;
bool operator == (const XWindow &w) const { return w._window == _window; } bool operator == (const XWindow &w) const { return w._window == _window; }
bool operator == (const Window &w) const { return w == _window; } bool operator == (const Window &w) const { return w == _window; }