diff options
author | David Walter Seikel | 2014-05-11 05:00:01 +1000 |
---|---|---|
committer | David Walter Seikel | 2014-05-11 05:00:01 +1000 |
commit | 8982ca01141f87d3744dd3b5866b05b0117889c6 (patch) | |
tree | 096bcdaa758083efd69e55e361ce52a49fbd04a3 /src | |
parent | Add physics to the windows. (diff) | |
download | SledjHamr-8982ca01141f87d3744dd3b5866b05b0117889c6.zip SledjHamr-8982ca01141f87d3744dd3b5866b05b0117889c6.tar.gz SledjHamr-8982ca01141f87d3744dd3b5866b05b0117889c6.tar.bz2 SledjHamr-8982ca01141f87d3744dd3b5866b05b0117889c6.tar.xz |
Add internal window title bar, and dragging them around. Plus some related clean ups.
Diffstat (limited to 'src')
-rw-r--r-- | src/GuiLua/GuiLua.c | 4 | ||||
-rw-r--r-- | src/extantz/ephysics_demo.c | 2 | ||||
-rw-r--r-- | src/extantz/woMan.c | 2 | ||||
-rw-r--r-- | src/libraries/winFang.c | 104 | ||||
-rw-r--r-- | src/libraries/winFang.h | 3 | ||||
-rw-r--r-- | src/purkle/purkle.c | 2 |
6 files changed, 102 insertions, 15 deletions
diff --git a/src/GuiLua/GuiLua.c b/src/GuiLua/GuiLua.c index 494be84..09c3fe9 100644 --- a/src/GuiLua/GuiLua.c +++ b/src/GuiLua/GuiLua.c | |||
@@ -196,6 +196,8 @@ static int widget(lua_State *L) | |||
196 | ); | 196 | ); |
197 | evas_object_smart_callback_add(wid->obj, "clicked", _on_click, wid); | 197 | evas_object_smart_callback_add(wid->obj, "clicked", _on_click, wid); |
198 | 198 | ||
199 | evas_object_show(win->box); | ||
200 | |||
199 | lua_pushlightuserdata(L, (void *) wid); | 201 | lua_pushlightuserdata(L, (void *) wid); |
200 | return 1; | 202 | return 1; |
201 | } | 203 | } |
@@ -259,7 +261,7 @@ static int window(lua_State *L) | |||
259 | world = gl->world; | 261 | world = gl->world; |
260 | } | 262 | } |
261 | 263 | ||
262 | win = winFangAdd(parent, 25, 25, w, h, title, name, world); | 264 | win = winFangAdd(parent, 25, 55, w, h, title, name, world); |
263 | if (gl) | 265 | if (gl) |
264 | { | 266 | { |
265 | // If there's no parent, we become the parent. | 267 | // If there's no parent, we become the parent. |
diff --git a/src/extantz/ephysics_demo.c b/src/extantz/ephysics_demo.c index 4655dbb..6ace8a0 100644 --- a/src/extantz/ephysics_demo.c +++ b/src/extantz/ephysics_demo.c | |||
@@ -44,7 +44,7 @@ EPhysics_World *ephysicsAdd(globals *ourGlobals) | |||
44 | ephysics_body_evas_object_set(box_body1, box1, EINA_TRUE); | 44 | ephysics_body_evas_object_set(box_body1, box1, EINA_TRUE); |
45 | ephysics_body_restitution_set(box_body1, 0.7); | 45 | ephysics_body_restitution_set(box_body1, 0.7); |
46 | ephysics_body_friction_set(box_body1, 0); | 46 | ephysics_body_friction_set(box_body1, 0); |
47 | ephysics_body_linear_velocity_set(box_body1, -1500, 2000, 0); | 47 | ephysics_body_linear_velocity_set(box_body1, -150, 20, 0); |
48 | ephysics_body_angular_velocity_set(box_body1, 0, 0, 36); | 48 | ephysics_body_angular_velocity_set(box_body1, 0, 0, 36); |
49 | ephysics_body_sleeping_threshold_set(box_body1, 0.1, 0.1); | 49 | ephysics_body_sleeping_threshold_set(box_body1, 0.1, 0.1); |
50 | eo_unref(box1); | 50 | eo_unref(box1); |
diff --git a/src/extantz/woMan.c b/src/extantz/woMan.c index 2911686..52b3a30 100644 --- a/src/extantz/woMan.c +++ b/src/extantz/woMan.c | |||
@@ -159,7 +159,7 @@ winFang *woMan_add(globals *ourGlobals) | |||
159 | char buf[PATH_MAX]; | 159 | char buf[PATH_MAX]; |
160 | int i; | 160 | int i; |
161 | 161 | ||
162 | me = winFangAdd(ourGlobals->mainWindow, 30, 150, ourGlobals->win_w / 3, ourGlobals->win_h / 3, "virtual world manager", "woMan", ourGlobals->world); | 162 | me = winFangAdd(ourGlobals->mainWindow, 30, 200, ourGlobals->win_w / 3, ourGlobals->win_h / 3, "virtual world manager", "woMan", ourGlobals->world); |
163 | 163 | ||
164 | // A tab thingy. | 164 | // A tab thingy. |
165 | tb = elm_toolbar_add(me->win); | 165 | tb = elm_toolbar_add(me->win); |
diff --git a/src/libraries/winFang.c b/src/libraries/winFang.c index 205cedb..bcf99ce 100644 --- a/src/libraries/winFang.c +++ b/src/libraries/winFang.c | |||
@@ -49,6 +49,55 @@ static void cb_mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_ | |||
49 | evas_map_free(p); | 49 | evas_map_free(p); |
50 | } | 50 | } |
51 | 51 | ||
52 | static void _onBgMove(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
53 | { | ||
54 | Evas_Event_Mouse_Move *ev = event_info; | ||
55 | winFang *win = data; | ||
56 | Evas_Coord x, y, w, h; | ||
57 | Evas_Object *img = elm_win_inlined_image_object_get(win->win), *test; | ||
58 | Eina_List *objs, *this; | ||
59 | int padding = 1, i = 0, overs[4][2]; | ||
60 | |||
61 | if (obj != img) return; | ||
62 | if (1 != ev->buttons) return; | ||
63 | |||
64 | // Looks like ePhysics wont cooperate about coords and other things, so plan B. | ||
65 | |||
66 | evas_object_geometry_get(img, &x, &y, &w, &h); | ||
67 | x += ev->cur.canvas.x - ev->prev.output.x; | ||
68 | y += ev->cur.canvas.y - ev->prev.output.y; | ||
69 | overs[0][0] = x - padding; overs[0][1] = y - padding; | ||
70 | overs[1][0] = x + padding + w; overs[1][1] = y - padding; | ||
71 | overs[2][0] = x + padding + w; overs[2][1] = y + padding + h; | ||
72 | overs[3][0] = x - padding; overs[3][1] = y + padding + h; | ||
73 | |||
74 | // If we are over two or more windows, stop. | ||
75 | objs = evas_objects_in_rectangle_get(win->e, overs[0][0], overs[0][1], w + (padding * 2), h + (padding * 2), EINA_TRUE, EINA_FALSE); | ||
76 | EINA_LIST_FOREACH(objs, this, test) | ||
77 | { | ||
78 | const char * name = evas_object_name_get(test); | ||
79 | if (name && (strcmp("winFang", name) == 0)) | ||
80 | i++; | ||
81 | } | ||
82 | if (2 <= i) | ||
83 | { | ||
84 | return; | ||
85 | } | ||
86 | |||
87 | // Check if we are outside the parent window. | ||
88 | evas_object_geometry_get(win->parent->win, NULL, NULL, &w, &h); | ||
89 | if ((overs[0][0] < 0) || (overs[0][1] < 0)) | ||
90 | { | ||
91 | return; | ||
92 | } | ||
93 | if ((overs[2][0] > w) || (overs[2][1] > h)) | ||
94 | { | ||
95 | return; | ||
96 | } | ||
97 | |||
98 | evas_object_move(img, x, y); | ||
99 | } | ||
100 | |||
52 | static void _on_done(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) | 101 | static void _on_done(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) |
53 | { | 102 | { |
54 | elm_exit(); | 103 | elm_exit(); |
@@ -75,7 +124,8 @@ void winFangShow(winFang *win) | |||
75 | winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, char *name, EPhysics_World *world) | 124 | winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, char *name, EPhysics_World *world) |
76 | { | 125 | { |
77 | winFang *result; | 126 | winFang *result; |
78 | Evas_Object *obj, *obj2; | 127 | Evas_Object *obj, *obj1; |
128 | Evas *obj2; | ||
79 | char buf[PATH_MAX]; | 129 | char buf[PATH_MAX]; |
80 | int i; | 130 | int i; |
81 | 131 | ||
@@ -84,6 +134,7 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
84 | eina_clist_init(&result->winFangs); | 134 | eina_clist_init(&result->winFangs); |
85 | 135 | ||
86 | if (parent) result->internal = EINA_TRUE; | 136 | if (parent) result->internal = EINA_TRUE; |
137 | result->parent = parent; | ||
87 | 138 | ||
88 | result->x = x; | 139 | result->x = x; |
89 | result->y = y; | 140 | result->y = y; |
@@ -98,9 +149,11 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
98 | result->win = elm_win_add(parent->win, name, ELM_WIN_INLINED_IMAGE); | 149 | result->win = elm_win_add(parent->win, name, ELM_WIN_INLINED_IMAGE); |
99 | eina_clist_add_head(&parent->winFangs, &result->node); | 150 | eina_clist_add_head(&parent->winFangs, &result->node); |
100 | obj = elm_win_inlined_image_object_get(result->win); | 151 | obj = elm_win_inlined_image_object_get(result->win); |
152 | evas_object_name_set(obj, "winFang"); | ||
101 | // On mouse down we try to shift focus to the backing image, this seems to be the correct thing to force focus onto it's widgets. | 153 | // On mouse down we try to shift focus to the backing image, this seems to be the correct thing to force focus onto it's widgets. |
102 | // According to the Elm inlined image window example, this is what's needed to. | 154 | // According to the Elm inlined image window example, this is what's needed to. |
103 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_elm, NULL); | 155 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_elm, NULL); |
156 | evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_MOVE, _onBgMove, result); | ||
104 | elm_win_alpha_set(result->win, EINA_TRUE); | 157 | elm_win_alpha_set(result->win, EINA_TRUE); |
105 | 158 | ||
106 | // image object for win is unlinked to its pos/size - so manual control | 159 | // image object for win is unlinked to its pos/size - so manual control |
@@ -110,6 +163,7 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
110 | evas_object_resize(obj, result->w, result->h); | 163 | evas_object_resize(obj, result->w, result->h); |
111 | 164 | ||
112 | obj2 = evas_object_evas_get(obj); | 165 | obj2 = evas_object_evas_get(obj); |
166 | result->e = obj2; | ||
113 | // Create corner handles. | 167 | // Create corner handles. |
114 | snprintf(buf, sizeof(buf), "%s/pt.png", elm_app_data_dir_get()); | 168 | snprintf(buf, sizeof(buf), "%s/pt.png", elm_app_data_dir_get()); |
115 | for (i = 0; i < 4; i++) | 169 | for (i = 0; i < 4; i++) |
@@ -143,16 +197,6 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
143 | eo_unref(result->hand[i]); | 197 | eo_unref(result->hand[i]); |
144 | #endif | 198 | #endif |
145 | } | 199 | } |
146 | if (world) | ||
147 | { | ||
148 | result->body = ephysics_body_box_add(world); | ||
149 | ephysics_body_evas_object_set(result->body, obj, EINA_TRUE); | ||
150 | ephysics_body_restitution_set(result->body, 0.7); | ||
151 | ephysics_body_friction_set(result->body, 0); | ||
152 | ephysics_body_linear_velocity_set(result->body, 80, -60, 0); | ||
153 | ephysics_body_angular_velocity_set(result->body, 0, 0, 360); | ||
154 | ephysics_body_sleeping_threshold_set(result->body, 0.1, 0.1); | ||
155 | } | ||
156 | } | 200 | } |
157 | else | 201 | else |
158 | { | 202 | { |
@@ -182,6 +226,44 @@ winFang *winFangAdd(winFang *parent, int x, int y, int w, int h, char *title, ch | |||
182 | ); | 226 | ); |
183 | elm_win_resize_object_add(result->win, result->box); | 227 | elm_win_resize_object_add(result->win, result->box); |
184 | 228 | ||
229 | if (result->internal) | ||
230 | { | ||
231 | result->title = eo_add(ELM_OBJ_LABEL_CLASS, result->win, | ||
232 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), | ||
233 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, 0.0), | ||
234 | evas_obj_visibility_set(EINA_TRUE) | ||
235 | ); | ||
236 | elm_object_style_set(result->title, "slide_bounce"); | ||
237 | snprintf(buf, PATH_MAX, "<b>%s</b>", title); | ||
238 | elm_object_text_set(result->title, buf); | ||
239 | elm_box_pack_end(result->box, result->title); | ||
240 | eo_unref(result->title); | ||
241 | |||
242 | #if 0 | ||
243 | // EPysics enable the window. | ||
244 | if (world) | ||
245 | { | ||
246 | result->body = ephysics_body_box_add(world); | ||
247 | ephysics_body_evas_object_set(result->body, obj, EINA_TRUE); | ||
248 | ephysics_body_mass_set(result->body, 0); | ||
249 | // ephysics_body_restitution_set(result->body, 0.7); | ||
250 | // ephysics_body_friction_set(result->body, 0); | ||
251 | // ephysics_body_linear_velocity_set(result->body, 0, 0, 0); | ||
252 | // ephysics_body_angular_velocity_set(result->body, 0, 0, 0); | ||
253 | ephysics_body_sleeping_threshold_set(result->body, 0.1, 0.1); | ||
254 | } | ||
255 | #endif | ||
256 | |||
257 | obj1 = eo_add(ELM_OBJ_SEPARATOR_CLASS, result->win, | ||
258 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), | ||
259 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, 0.0), | ||
260 | elm_obj_separator_horizontal_set(EINA_TRUE), | ||
261 | evas_obj_visibility_set(EINA_TRUE) | ||
262 | ); | ||
263 | elm_box_pack_end(result->box, obj1); | ||
264 | eo_unref(obj1); | ||
265 | } | ||
266 | |||
185 | evas_object_resize(result->win, result->w, result->h); | 267 | evas_object_resize(result->win, result->w, result->h); |
186 | evas_object_show(result->win); | 268 | evas_object_show(result->win); |
187 | 269 | ||
diff --git a/src/libraries/winFang.h b/src/libraries/winFang.h index a84c8de..f3b4e45 100644 --- a/src/libraries/winFang.h +++ b/src/libraries/winFang.h | |||
@@ -18,7 +18,10 @@ | |||
18 | 18 | ||
19 | typedef struct _winFang | 19 | typedef struct _winFang |
20 | { | 20 | { |
21 | Evas *e; | ||
22 | struct _winFang *parent; | ||
21 | Evas_Object *win; | 23 | Evas_Object *win; |
24 | Evas_Object *title; | ||
22 | Evas_Object *bg; | 25 | Evas_Object *bg; |
23 | Evas_Object *box; | 26 | Evas_Object *box; |
24 | EPhysics_Body *body; | 27 | EPhysics_Body *body; |
diff --git a/src/purkle/purkle.c b/src/purkle/purkle.c index 8ea012c..ef0bbf2 100644 --- a/src/purkle/purkle.c +++ b/src/purkle/purkle.c | |||
@@ -19,7 +19,7 @@ static winFang *purkleAdd(winFang *parent, int w, int h, EPhysics_World *world) | |||
19 | Widget *wid; | 19 | Widget *wid; |
20 | Evas_Object *en; | 20 | Evas_Object *en; |
21 | 21 | ||
22 | me = winFangAdd(parent, 30, 520, w, h, "chatter box", "purkle", world); | 22 | me = winFangAdd(parent, 30, 590, w, h, "chatter box", "purkle", world); |
23 | 23 | ||
24 | en = eo_add(ELM_OBJ_ENTRY_CLASS, me->win, | 24 | en = eo_add(ELM_OBJ_ENTRY_CLASS, me->win, |
25 | elm_obj_entry_scrollable_set(EINA_TRUE), | 25 | elm_obj_entry_scrollable_set(EINA_TRUE), |