diff options
| author | Dana Jansens <danakj@orodu.net> | 2007-06-22 18:47:30 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2007-06-22 18:47:30 +0000 |
| commit | 976add593801af58ae6c5e39fd70e1738878bf93 (patch) | |
| tree | 166012a1cda46958ffc17bec025135769fb44b27 /openbox/action.c | |
| parent | 7e6f7fb45466bf6672e295ab155a9697c294410c (diff) | |
add the resize action
Diffstat (limited to 'openbox/action.c')
| -rw-r--r-- | openbox/action.c | 162 |
1 files changed, 0 insertions, 162 deletions
diff --git a/openbox/action.c b/openbox/action.c index 1a174d85..61c29721 100644 --- a/openbox/action.c +++ b/openbox/action.c @@ -438,11 +438,6 @@ ActionString actionstrings[] = setup_client_action }, { - "resize", - action_resize, - setup_action_resize - }, - { "toggledockautohide", action_toggle_dockautohide, NULL @@ -643,35 +638,6 @@ ObAction *action_parse(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node, if ((n = parse_find_node("dialog", node->xmlChildrenNode))) act->data.sendtodir.inter.any.interactive = parse_bool(doc, n); - } else if (act->func == action_resize) { - if ((n = parse_find_node("edge", node->xmlChildrenNode))) { - gchar *s = parse_string(doc, n); - if (!g_ascii_strcasecmp(s, "top")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_top; - else if (!g_ascii_strcasecmp(s, "bottom")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_bottom; - else if (!g_ascii_strcasecmp(s, "left")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_left; - else if (!g_ascii_strcasecmp(s, "right")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_right; - else if (!g_ascii_strcasecmp(s, "topleft")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_topleft; - else if (!g_ascii_strcasecmp(s, "topright")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_topright; - else if (!g_ascii_strcasecmp(s, "bottomleft")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_bottomleft; - else if (!g_ascii_strcasecmp(s, "bottomright")) - act->data.moveresize.corner = - prop_atoms.net_wm_moveresize_size_bottomright; - g_free(s); - } INTERACTIVE_LIMIT(act, uact); } g_free(actname); @@ -933,134 +899,6 @@ void action_toggle_decorations(union ActionData *data) client_action_end(data, FALSE); } -static guint32 pick_corner(gint x, gint y, gint cx, gint cy, gint cw, gint ch, - gboolean shaded) -{ - /* let's make x and y client relative instead of screen relative */ - x = x - cx; - y = ch - (y - cy); /* y is inverted, 0 is at the bottom of the window */ - -#define X x*ch/cw -#define A -4*X + 7*ch/3 -#define B 4*X -15*ch/9 -#define C -X/4 + 2*ch/3 -#define D X/4 + 5*ch/12 -#define E X/4 + ch/3 -#define F -X/4 + 7*ch/12 -#define G 4*X - 4*ch/3 -#define H -4*X + 8*ch/3 -#define a (y > 5*ch/9) -#define b (x < 4*cw/9) -#define c (x > 5*cw/9) -#define d (y < 4*ch/9) - - /* - Each of these defines (except X which is just there for fun), represents - the equation of a line. The lines they represent are shown in the diagram - below. Checking y against these lines, we are able to choose a region - of the window as shown. - - +---------------------A-------|-------|-------B---------------------+ - | |A B| | - | |A | | B| | - | | A B | | - | | A | | B | | - | | A B | | - | | A | | B | | - | northwest | A north B | northeast | - | | A | | B | | - | | A B | | - C---------------------+----A--+-------+--B----+---------------------D - |CCCCCCC | A B | DDDDDDD| - | CCCCCCCC | A | | B | DDDDDDDD | - | CCCCCCC A B DDDDDDD | - - - - - - - - - - - - +CCCCCCC+aaaaaaa+DDDDDDD+ - - - - - - - - - - - - - | | b c | | sh - | west | b move c | east | ad - | | b c | | ed - - - - - - - - - - - - +EEEEEEE+ddddddd+FFFFFFF+- - - - - - - - - - - - - | EEEEEEE G H FFFFFFF | - | EEEEEEEE | G | | H | FFFFFFFF | - |EEEEEEE | G H | FFFFFFF| - E---------------------+----G--+-------+--H----+---------------------F - | | G H | | - | | G | | H | | - | southwest | G south H | southeast | - | | G | | H | | - | | G H | | - | | G | | H | | - | | G H | | - | |G | | H| | - | |G H| | - +---------------------G-------|-------|-------H---------------------+ - */ - - if (shaded) { - /* for shaded windows, you can only resize west/east and move */ - if (b) - return prop_atoms.net_wm_moveresize_size_left; - if (c) - return prop_atoms.net_wm_moveresize_size_right; - return prop_atoms.net_wm_moveresize_move; - } - - if (y < A && y >= C) - return prop_atoms.net_wm_moveresize_size_topleft; - else if (y >= A && y >= B && a) - return prop_atoms.net_wm_moveresize_size_top; - else if (y < B && y >= D) - return prop_atoms.net_wm_moveresize_size_topright; - else if (y < C && y >= E && b) - return prop_atoms.net_wm_moveresize_size_left; - else if (y < D && y >= F && c) - return prop_atoms.net_wm_moveresize_size_right; - else if (y < E && y >= G) - return prop_atoms.net_wm_moveresize_size_bottomleft; - else if (y < G && y < H && d) - return prop_atoms.net_wm_moveresize_size_bottom; - else if (y >= H && y < F) - return prop_atoms.net_wm_moveresize_size_bottomright; - else - return prop_atoms.net_wm_moveresize_move; - -#undef X -#undef A -#undef B -#undef C -#undef D -#undef E -#undef F -#undef G -#undef H -#undef a -#undef b -#undef c -#undef d -} - -void action_resize(union ActionData *data) -{ - ObClient *c = data->moveresize.any.c; - guint32 corner; - - if (data->moveresize.keyboard) - corner = prop_atoms.net_wm_moveresize_size_keyboard; - else if (data->moveresize.corner) - corner = data->moveresize.corner; /* it was specified in the binding */ - else - corner = pick_corner(data->any.x, data->any.y, - c->frame->area.x, c->frame->area.y, - /* use the client size because the frame - can be differently sized (shaded - windows) and we want this based on the - clients size */ - c->area.width + c->frame->size.left + - c->frame->size.right, - c->area.height + c->frame->size.top + - c->frame->size.bottom, c->shaded); - - moveresize_start(c, data->any.x, data->any.y, data->any.button, corner); -} void action_directional_focus(union ActionData *data) { |
