diff options
author | David Walter Seikel | 2014-05-12 02:56:23 +1000 |
---|---|---|
committer | David Walter Seikel | 2014-05-12 02:56:23 +1000 |
commit | 8429c4858ff5dc70afe018c2a5a8d8eb302e2af3 (patch) | |
tree | 816150c3ddacf3cec1aa88b9c667a0abdec8e3f7 | |
parent | Fix up winFang move and resize. Still more to fix here though. (diff) | |
download | SledjHamr-8429c4858ff5dc70afe018c2a5a8d8eb302e2af3.zip SledjHamr-8429c4858ff5dc70afe018c2a5a8d8eb302e2af3.tar.gz SledjHamr-8429c4858ff5dc70afe018c2a5a8d8eb302e2af3.tar.bz2 SledjHamr-8429c4858ff5dc70afe018c2a5a8d8eb302e2af3.tar.xz |
A little more clean up of winFang move / resize.
-rw-r--r-- | src/libraries/winFang.c | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/src/libraries/winFang.c b/src/libraries/winFang.c index cd83291..708f0cd 100644 --- a/src/libraries/winFang.c +++ b/src/libraries/winFang.c | |||
@@ -17,7 +17,7 @@ static void _checkWindowBounds(winFang *win, Evas_Coord x, Evas_Coord y, Evas_Co | |||
17 | overs[2][0] = x + padding + w; overs[2][1] = y + padding + h; | 17 | overs[2][0] = x + padding + w; overs[2][1] = y + padding + h; |
18 | overs[3][0] = x - padding; overs[3][1] = y + padding + h; | 18 | overs[3][0] = x - padding; overs[3][1] = y + padding + h; |
19 | 19 | ||
20 | // If we are over two or more windows, stop. | 20 | // If we are over other windows, stop. |
21 | objs = evas_objects_in_rectangle_get(win->e, overs[0][0], overs[0][1], w + (padding * 2), h + (padding * 2), EINA_TRUE, EINA_FALSE); | 21 | objs = evas_objects_in_rectangle_get(win->e, overs[0][0], overs[0][1], w + (padding * 2), h + (padding * 2), EINA_TRUE, EINA_FALSE); |
22 | EINA_LIST_FOREACH(objs, this, test) | 22 | EINA_LIST_FOREACH(objs, this, test) |
23 | { | 23 | { |
@@ -56,20 +56,19 @@ static void _checkWindowBounds(winFang *win, Evas_Coord x, Evas_Coord y, Evas_Co | |||
56 | } | 56 | } |
57 | } | 57 | } |
58 | 58 | ||
59 | static void cb_mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_info) | 59 | static void _onHandleMove(void *data, Evas *evas, Evas_Object *obj, void *event_info) |
60 | { | 60 | { |
61 | Evas_Event_Mouse_Move *ev = event_info; | 61 | Evas_Event_Mouse_Move *ev = event_info; |
62 | winFang *win = data; | 62 | winFang *win = data; |
63 | Evas_Coord x, y, w, h, dx = 0, dy = 0, dw = 0, dh = 0, mx, my; | 63 | Evas_Coord x, y, w, h, dx, dy; |
64 | Evas_Object *img = win->win; | 64 | Evas_Object *img = win->win; |
65 | int i; | 65 | int i; |
66 | 66 | ||
67 | if (!ev->buttons) return; | 67 | if (!ev->buttons) return; |
68 | 68 | ||
69 | mx = ev->cur.canvas.x - ev->prev.output.x; | 69 | dx = ev->cur.canvas.x - ev->prev.output.x; |
70 | my = ev->cur.canvas.y - ev->prev.output.y; | 70 | dy = ev->cur.canvas.y - ev->prev.output.y; |
71 | evas_object_geometry_get(img, &x, &y, &w, &h); | 71 | evas_object_geometry_get(img, &x, &y, &w, &h); |
72 | |||
73 | for (i = 0; i < 4; i++) | 72 | for (i = 0; i < 4; i++) |
74 | { | 73 | { |
75 | if (obj == win->hand[i]) | 74 | if (obj == win->hand[i]) |
@@ -78,26 +77,26 @@ static void cb_mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_ | |||
78 | { | 77 | { |
79 | case 0 : | 78 | case 0 : |
80 | { | 79 | { |
81 | dw -= mx; dh -= my; dx += mx; dy += my; | 80 | w -= dx; h -= dy; x += dx; y += dy; |
82 | break; | 81 | break; |
83 | } | 82 | } |
84 | case 1 : | 83 | case 1 : |
85 | { | 84 | { |
86 | dw += mx; dh -= my; dy += my; | 85 | w += dx; h -= dy; y += dy; |
87 | break; | 86 | break; |
88 | } | 87 | } |
89 | case 2 : | 88 | case 2 : |
90 | { | 89 | { |
91 | dw += mx; dh += my; | 90 | w += dx; h += dy; |
92 | break; | 91 | break; |
93 | } | 92 | } |
94 | case 3 : | 93 | case 3 : |
95 | { | 94 | { |
96 | dw -= mx; dh += my; dx += mx; | 95 | w -= dx; h += dy; x += dx; |
97 | break; | 96 | break; |
98 | } | 97 | } |
99 | } | 98 | } |
100 | _checkWindowBounds(win, x + dx, y + dy, w + dw, h + dh); | 99 | _checkWindowBounds(win, x, y, w, h); |
101 | return; | 100 | return; |
102 | } | 101 | } |
103 | } | 102 | } |
@@ -115,9 +114,7 @@ static void _onBgMove(void *data, Evas *evas, Evas_Object *obj, void *event_info | |||
115 | // Looks like ePhysics wont cooperate about coords and other things, so plan B. | 114 | // Looks like ePhysics wont cooperate about coords and other things, so plan B. |
116 | 115 | ||
117 | evas_object_geometry_get(img, &x, &y, &w, &h); | 116 | evas_object_geometry_get(img, &x, &y, &w, &h); |
118 | x += ev->cur.canvas.x - ev->prev.output.x; | 117 | _checkWindowBounds(win, x + ev->cur.canvas.x - ev->prev.output.x, y + ev->cur.canvas.y - ev->prev.output.y, w, h); |
119 | y += ev->cur.canvas.y - ev->prev.output.y; | ||
120 | _checkWindowBounds(win, x, y, w, h); | ||
121 | } | 118 | } |
122 | 119 | ||
123 | static void _onBgUnclick(void *data, Evas *evas, Evas_Object *obj, void *event_info) | 120 | static void _onBgUnclick(void *data, Evas *evas, Evas_Object *obj, void *event_info) |
@@ -126,6 +123,7 @@ static void _onBgUnclick(void *data, Evas *evas, Evas_Object *obj, void *event_i | |||
126 | 123 | ||
127 | if (1 == ev->button) | 124 | if (1 == ev->button) |
128 | { | 125 | { |
126 | // Stop moving the window. | ||
129 | evas_object_event_callback_del(obj, EVAS_CALLBACK_MOUSE_UP, _onBgUnclick); | 127 | evas_object_event_callback_del(obj, EVAS_CALLBACK_MOUSE_UP, _onBgUnclick); |
130 | evas_object_event_callback_del(obj, EVAS_CALLBACK_MOUSE_MOVE, _onBgMove); | 128 | evas_object_event_callback_del(obj, EVAS_CALLBACK_MOUSE_MOVE, _onBgMove); |
131 | } | 129 | } |
@@ -137,6 +135,7 @@ static void _onBgClick(void *data, Evas *evas, Evas_Object *obj, void *event_inf | |||
137 | 135 | ||
138 | if (1 == ev->button) | 136 | if (1 == ev->button) |
139 | { | 137 | { |
138 | // Start moving the window. | ||
140 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_UP, _onBgUnclick, data); | 139 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_UP, _onBgUnclick, data); |
141 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_MOVE, _onBgMove, data); | 140 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_MOVE, _onBgMove, data); |
142 | } | 141 | } |
@@ -264,7 +263,7 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
264 | evas_obj_position_set(cx - 15, cy - 15), | 263 | evas_obj_position_set(cx - 15, cy - 15), |
265 | evas_obj_visibility_set(EINA_TRUE) | 264 | evas_obj_visibility_set(EINA_TRUE) |
266 | ); | 265 | ); |
267 | evas_object_event_callback_add(result->hand[i], EVAS_CALLBACK_MOUSE_MOVE, cb_mouse_move, result); | 266 | evas_object_event_callback_add(result->hand[i], EVAS_CALLBACK_MOUSE_MOVE, _onHandleMove, result); |
268 | eo_unref(result->hand[i]); | 267 | eo_unref(result->hand[i]); |
269 | } | 268 | } |
270 | } | 269 | } |