diff options
author | David Walter Seikel | 2014-05-03 01:47:19 +1000 |
---|---|---|
committer | David Walter Seikel | 2014-05-03 01:47:19 +1000 |
commit | e8678fdfe62bf62113baef2948874c0adfc82045 (patch) | |
tree | e2f0e4a14126fb5e9637802a42db9205be2897cf /src/extantz | |
parent | Major cleanup of extantz, part one. (diff) | |
download | SledjHamr-e8678fdfe62bf62113baef2948874c0adfc82045.zip SledjHamr-e8678fdfe62bf62113baef2948874c0adfc82045.tar.gz SledjHamr-e8678fdfe62bf62113baef2948874c0adfc82045.tar.bz2 SledjHamr-e8678fdfe62bf62113baef2948874c0adfc82045.tar.xz |
Major extantz clean up part 2. Including new Evas_3d style camera.
Diffstat (limited to 'src/extantz')
-rw-r--r-- | src/extantz/Evas_3D_demo.c | 29 | ||||
-rwxr-xr-x | src/extantz/build.lua | 4 | ||||
-rw-r--r-- | src/extantz/camera.c | 182 | ||||
-rw-r--r-- | src/extantz/chat.c | 41 | ||||
-rw-r--r-- | src/extantz/extantz.c | 36 | ||||
-rw-r--r-- | src/extantz/extantz.h | 9 | ||||
-rw-r--r-- | src/extantz/fangWin.c | 174 |
7 files changed, 267 insertions, 208 deletions
diff --git a/src/extantz/Evas_3D_demo.c b/src/extantz/Evas_3D_demo.c index 5f33fed..df05838 100644 --- a/src/extantz/Evas_3D_demo.c +++ b/src/extantz/Evas_3D_demo.c | |||
@@ -268,13 +268,16 @@ _sphere_init(int precision) | |||
268 | 268 | ||
269 | Eina_Bool _animate_scene(void *data) | 269 | Eina_Bool _animate_scene(void *data) |
270 | { | 270 | { |
271 | globals *ourGlobals = data; | ||
272 | |||
271 | static float angle = 0.0f; | 273 | static float angle = 0.0f; |
272 | static float earthAngle = 0.0f; | 274 | static float earthAngle = 0.0f; |
273 | static int frame = 0; | 275 | static int frame = 0; |
274 | static int inc = 1; | 276 | static int inc = 1; |
275 | static int sonicFrame = 0; | 277 | static int sonicFrame = 0; |
278 | Evas_Real x, y, z; | ||
276 | 279 | ||
277 | Scene_Data *scene = (Scene_Data *)data; | 280 | Scene_Data *scene = ourGlobals->scene; |
278 | 281 | ||
279 | // Animate cube. | 282 | // Animate cube. |
280 | angle += 0.5; | 283 | angle += 0.5; |
@@ -303,6 +306,13 @@ Eina_Bool _animate_scene(void *data) | |||
303 | evas_3d_node_orientation_angle_axis_set(angle, 0.0, 1.0, 0.0) | 306 | evas_3d_node_orientation_angle_axis_set(angle, 0.0, 1.0, 0.0) |
304 | ); | 307 | ); |
305 | 308 | ||
309 | // Camera movement. | ||
310 | eo_do(scene->camera_node, evas_3d_node_position_get(EVAS_3D_SPACE_PARENT, &x, &y, &z)); | ||
311 | x += ourGlobals->gld.move->x; | ||
312 | y += ourGlobals->gld.move->y; | ||
313 | z += ourGlobals->gld.move->z; | ||
314 | eo_do(scene->camera_node, evas_3d_node_position_set(x, y, z)); | ||
315 | |||
306 | return EINA_TRUE; | 316 | return EINA_TRUE; |
307 | } | 317 | } |
308 | 318 | ||
@@ -602,7 +612,10 @@ static void _on_mouse_move(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void | |||
602 | elm_object_tooltip_show(scene->image); | 612 | elm_object_tooltip_show(scene->image); |
603 | } | 613 | } |
604 | else | 614 | else |
615 | { | ||
616 | elm_object_tooltip_text_set(scene->image, ""); | ||
605 | elm_object_tooltip_hide(scene->image); | 617 | elm_object_tooltip_hide(scene->image); |
618 | } | ||
606 | } | 619 | } |
607 | 620 | ||
608 | static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void *einfo) | 621 | static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void *einfo) |
@@ -619,6 +632,9 @@ static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void | |||
619 | Eina_Bool pick; | 632 | Eina_Bool pick; |
620 | char *name = NULL; | 633 | char *name = NULL; |
621 | 634 | ||
635 | // Set the focus onto us. | ||
636 | elm_object_focus_set(o, EINA_TRUE); | ||
637 | |||
622 | evas_object_geometry_get(o, &x, &y, &w, &h); | 638 | evas_object_geometry_get(o, &x, &y, &w, &h); |
623 | 639 | ||
624 | obj_x = ev->canvas.x - x; | 640 | obj_x = ev->canvas.x - x; |
@@ -673,15 +689,18 @@ void Evas_3D_Demo_add(globals *ourGlobals) | |||
673 | // Elm can't seem to be able to tell us WHERE an image was clicked, so use raw Evas calbacks instead. | 689 | // Elm can't seem to be able to tell us WHERE an image was clicked, so use raw Evas calbacks instead. |
674 | evas_object_event_callback_add(temp, EVAS_CALLBACK_MOUSE_MOVE, _on_mouse_move, &ourScene); | 690 | evas_object_event_callback_add(temp, EVAS_CALLBACK_MOUSE_MOVE, _on_mouse_move, &ourScene); |
675 | evas_object_event_callback_add(temp, EVAS_CALLBACK_MOUSE_DOWN, _on_mouse_down, &ourScene); | 691 | evas_object_event_callback_add(temp, EVAS_CALLBACK_MOUSE_DOWN, _on_mouse_down, &ourScene); |
692 | cameraAdd(obj, &ourGlobals->gld); | ||
676 | elm_win_resize_object_add(ourGlobals->win, obj); | 693 | elm_win_resize_object_add(ourGlobals->win, obj); |
677 | // elm_box_pack_end(ourGlobals->gld.bx, obj); | 694 | // elm_box_pack_end(ourGlobals->gld.bx, obj); |
678 | 695 | ||
679 | // Add animation timer callback. | 696 | // Add animation timer callback. |
680 | // ecore_timer_add(0.016, _animate_scene, &ourScene); | 697 | // ecore_timer_add(0.016, _animate_scene, &ourScene); |
698 | ourGlobals->gld.move = calloc(1, sizeof(cameraMove)); | ||
681 | } | 699 | } |
682 | 700 | ||
683 | void Evas_3D_Demo_fini() | 701 | void Evas_3D_Demo_fini(globals *ourGlobals) |
684 | { | 702 | { |
685 | free(sphere_vertices); | 703 | eo_unref(ourGlobals->scene->image); |
686 | free(sphere_indices); | 704 | free(sphere_vertices); |
687 | } \ No newline at end of file | 705 | free(sphere_indices); |
706 | } | ||
diff --git a/src/extantz/build.lua b/src/extantz/build.lua index 2871ae6..75b210f 100755 --- a/src/extantz/build.lua +++ b/src/extantz/build.lua | |||
@@ -17,10 +17,10 @@ CFLAGS = CFLAGS .. ' -I../../libraries/irrlicht-1.8.1/include -I/usr/X11R6/inc | |||
17 | LDFLAGS = LDFLAGS .. ' -L../../libraries/irrlicht-1.8.1/lib/Linux' | 17 | LDFLAGS = LDFLAGS .. ' -L../../libraries/irrlicht-1.8.1/lib/Linux' |
18 | libs = libs .. ' -lIrrlicht -lGL -lbz2' | 18 | libs = libs .. ' -lIrrlicht -lGL -lbz2' |
19 | 19 | ||
20 | removeFiles(dir, {'../../extantz', 'crappisspuke.o', 'CDemo.o', 'extantzCamera.o', 'gears.o', 'ephysics_demo.o', 'Evas_3D_demo.o', 'fangWin.o', 'chat.o', 'woMan.o', '../../media/extantz.edj'}) | 20 | removeFiles(dir, {'../../extantz', 'crappisspuke.o', 'CDemo.o', 'extantzCamera.o', 'gears.o', 'ephysics_demo.o', 'camera.o', 'Evas_3D_demo.o', 'fangWin.o', 'chat.o', 'woMan.o', '../../media/extantz.edj'}) |
21 | 21 | ||
22 | runCommand('edje_cc', dir, 'edje_cc ' .. EDJE_FLAGS .. ' extantz.edc ../../media/extantz.edj') | 22 | runCommand('edje_cc', dir, 'edje_cc ' .. EDJE_FLAGS .. ' extantz.edc ../../media/extantz.edj') |
23 | runCommand('Irrlicht files', dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c crappisspuke.cpp -o crappisspuke.o ' .. LDFLAGS) | 23 | runCommand('Irrlicht files', dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c crappisspuke.cpp -o crappisspuke.o ' .. LDFLAGS) |
24 | runCommand(nil, dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c CDemo.cpp -o CDemo.o ' .. LDFLAGS) | 24 | runCommand(nil, dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c CDemo.cpp -o CDemo.o ' .. LDFLAGS) |
25 | runCommand(nil, dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c extantzCamera.cpp -o extantzCamera.o ' .. LDFLAGS) | 25 | runCommand(nil, dir, 'g++ ' .. CFLAGS .. ' -ffast-math -c extantzCamera.cpp -o extantzCamera.o ' .. LDFLAGS) |
26 | compileFiles('../../extantz', dir, {'gears', 'ephysics_demo', 'Evas_3D_demo', 'fangWin', 'chat', 'woMan', 'extantz'}, 'crappisspuke.o CDemo.o extantzCamera.o') | 26 | compileFiles('../../extantz', dir, {'gears', 'ephysics_demo', 'camera', 'Evas_3D_demo', 'fangWin', 'chat', 'woMan', 'extantz'}, 'crappisspuke.o CDemo.o extantzCamera.o') |
diff --git a/src/extantz/camera.c b/src/extantz/camera.c new file mode 100644 index 0000000..331a85a --- /dev/null +++ b/src/extantz/camera.c | |||
@@ -0,0 +1,182 @@ | |||
1 | #include "extantz.h" | ||
2 | |||
3 | |||
4 | static void _on_camera_input_down(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
5 | { | ||
6 | GLData *gld = data; | ||
7 | Evas_Event_Key_Down *ev = event_info; | ||
8 | |||
9 | if (gld->move) | ||
10 | { | ||
11 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't know at what point the camera animate routine is actually called. | ||
12 | |||
13 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | ||
14 | // TODO - make this a hash lookup dammit. | ||
15 | if (0 == strcmp(ev->key, "Escape")) | ||
16 | { | ||
17 | } | ||
18 | else if (0 == strcmp(ev->key, "Left")) | ||
19 | gld->move->y = 2.0; | ||
20 | else if (0 == strcmp(ev->key, "Right")) | ||
21 | gld->move->y = -2.0; | ||
22 | else if (0 == strcmp(ev->key, "Up")) | ||
23 | gld->move->x = 2.0; | ||
24 | else if (0 == strcmp(ev->key, "Down")) | ||
25 | gld->move->x = -2.0; | ||
26 | else if (0 == strcmp(ev->key, "Prior")) | ||
27 | gld->move->z = -2.0; | ||
28 | else if (0 == strcmp(ev->key, "Next")) | ||
29 | gld->move->z = 2.0; | ||
30 | // else if (0 == strcmp(ev->key, "Home")) | ||
31 | // ; | ||
32 | // else if (0 == strcmp(ev->key, "End")) | ||
33 | // ; | ||
34 | else if (0 == strcmp(ev->key, "space")) | ||
35 | gld->move->jump = 1.0; | ||
36 | else | ||
37 | printf("Unexpected down keystroke - %s\n", ev->key); | ||
38 | } | ||
39 | else | ||
40 | printf("Camera input not ready\n"); | ||
41 | } | ||
42 | |||
43 | /* SL / OS camera controls | ||
44 | up / down / w / s moves avatar forward / backward | ||
45 | shifted version does the same | ||
46 | double tap triggers run mode / or fast fly mode | ||
47 | Running backwards turns your avatar to suit, walking does not. | ||
48 | left / right / a / d rotates avatar left / right, strafes in mouselook | ||
49 | shifted version turns the avatar to walk sideways, so not really a strafe. | ||
50 | So not sure if the "strafe" in mouse look turns the avatar as well? | ||
51 | PgDn / c crouch while it is held down move up in flight mode | ||
52 | PgUp jump move down in flight mode | ||
53 | Home toggle flying | ||
54 | End Nothing? | ||
55 | Esc return to third person view | ||
56 | m toggle mouse look | ||
57 | mouse wheel move view closer / further away from current focused object or avatar | ||
58 | Alt left click focus on some other object | ||
59 | Ins ??? | ||
60 | Del ??? | ||
61 | BS ??? | ||
62 | Tab ??? | ||
63 | |||
64 | Mouse look is just first person view, moving mouse looks left / right / up / down. | ||
65 | Not sure if the avatar rotates with left / right, but that's likely. | ||
66 | |||
67 | mouse moves With the left mouse button held down - | ||
68 | left / right up / down | ||
69 | --------------------------------- | ||
70 | for avatar swings avatar around zoom in and out of avatar | ||
71 | for object nothing | ||
72 | alt orbit left / right zoom in and out | ||
73 | alt ctrl orbit left / right orbit up / down | ||
74 | alt shift orbit left / right zoom in and out | ||
75 | alt ctrl shift shift view left / right / up / down | ||
76 | ctrl Nothing? | ||
77 | shift Nothing? | ||
78 | ctrl shift Nothing? | ||
79 | |||
80 | Need to also consider when looking at a moving object / avatar. | ||
81 | |||
82 | I think there are other letter keys that duplicate arrow keys and such. I'll look for them later, but I don't use them. | ||
83 | No idea what the function keys are mapped to, but think it's various non camera stuff. | ||
84 | I'm damn well leaving the Win/Command and Menu keys for the OS / window manager. lol | ||
85 | Keypad keys? Not interested, I don't have them. | ||
86 | Print Screen / SysRq, Pause / Break, other oddball keys, also not interested. | ||
87 | NOTE - gonna have an easily programmable "bind key to command" thingy, like E17s, so that can deal with other keys. | ||
88 | Should even let them be saveable so people can swap them with other people easily. | ||
89 | |||
90 | TODO - implement things like space mouse, sixaxis, phone as controller, joysticks, data gloves, etc. | ||
91 | */ | ||
92 | |||
93 | /* A moveRotate array of floats. | ||
94 | * X, Y, Z, and whatever the usual letters are for rotations. lol | ||
95 | * Each one means "move or rotate this much in this direction". | ||
96 | * Where 1.0 means "what ever the standard move is if that key is held down". | ||
97 | * So a keyboard move would just change it's part to 1.0 or -1.0 on key down, | ||
98 | * and back to 0.0 on key up. Or 2.0 / -2.0 if in run mode. | ||
99 | * Which would even work in fly mode. | ||
100 | * A joystick could be set to range over -2.0 to 2.0, and just set it's part directly. | ||
101 | * A mouse look rotate, well will come to that when we need to. B-) | ||
102 | * Setting the x or y to be the DIFFERENCE in window position of the mouse (-1.0 to 1.0) since the last frame. | ||
103 | * | ||
104 | * TODO - In the Elm_glview version, 2.0 seems to be correct speed for walking, but I thought 1.0 was in Evas_GL. | ||
105 | */ | ||
106 | |||
107 | static void _on_camera_input_up(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
108 | { | ||
109 | GLData *gld = data; | ||
110 | Evas_Event_Key_Up *ev = event_info; | ||
111 | |||
112 | if (gld->move) | ||
113 | { | ||
114 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't know at what point the camera animate routine is actually called. | ||
115 | |||
116 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | ||
117 | // TODO - make this a hash lookup dammit. | ||
118 | if (0 == strcmp(ev->key, "Escape")) | ||
119 | { | ||
120 | } | ||
121 | else if (0 == strcmp(ev->key, "Left")) | ||
122 | gld->move->y = 0.0; | ||
123 | else if (0 == strcmp(ev->key, "Right")) | ||
124 | gld->move->y = 0.0; | ||
125 | else if (0 == strcmp(ev->key, "Up")) | ||
126 | gld->move->x = 0.0; | ||
127 | else if (0 == strcmp(ev->key, "Down")) | ||
128 | gld->move->x = 0.0; | ||
129 | else if (0 == strcmp(ev->key, "Prior")) | ||
130 | gld->move->z = 0.0; | ||
131 | else if (0 == strcmp(ev->key, "Next")) | ||
132 | gld->move->z = 0.0; | ||
133 | // else if (0 == strcmp(ev->key, "Home")) | ||
134 | // ; | ||
135 | // else if (0 == strcmp(ev->key, "End")) | ||
136 | // ; | ||
137 | else if (0 == strcmp(ev->key, "space")) | ||
138 | gld->move->jump = 0.0; | ||
139 | else | ||
140 | printf("Unexpected up keystroke - %s\n", ev->key); | ||
141 | } | ||
142 | else | ||
143 | printf("Camera input not ready\n"); | ||
144 | } | ||
145 | |||
146 | // Elm style event callback. | ||
147 | static Eina_Bool _cb_event_GL(void *data, Evas_Object *obj, Evas_Object *src, Evas_Callback_Type type, void *event_info) | ||
148 | { | ||
149 | GLData *gld = data; | ||
150 | Eina_Bool processed = EINA_FALSE; | ||
151 | |||
152 | switch (type) | ||
153 | { | ||
154 | case EVAS_CALLBACK_KEY_DOWN : | ||
155 | { | ||
156 | _on_camera_input_down(gld, evas_object_evas_get(obj), obj, event_info); | ||
157 | processed = EINA_TRUE; | ||
158 | break; | ||
159 | } | ||
160 | |||
161 | case EVAS_CALLBACK_KEY_UP : | ||
162 | { | ||
163 | _on_camera_input_up(gld, evas_object_evas_get(obj), obj, event_info); | ||
164 | processed = EINA_TRUE; | ||
165 | break; | ||
166 | } | ||
167 | |||
168 | default : | ||
169 | printf("Unknown GL input event.\n"); | ||
170 | } | ||
171 | |||
172 | return processed; | ||
173 | } | ||
174 | |||
175 | |||
176 | void cameraAdd(Evas_Object *win, GLData *gld) | ||
177 | { | ||
178 | // In this code, we are making our own camera, so grab it's input when we are focused. | ||
179 | evas_object_event_callback_add(win, EVAS_CALLBACK_KEY_DOWN, _on_camera_input_down, gld); | ||
180 | evas_object_event_callback_add(win, EVAS_CALLBACK_KEY_UP, _on_camera_input_up, gld); | ||
181 | elm_object_event_callback_add(win, _cb_event_GL, gld); | ||
182 | } | ||
diff --git a/src/extantz/chat.c b/src/extantz/chat.c index 23155a9..e8a0c4d 100644 --- a/src/extantz/chat.c +++ b/src/extantz/chat.c | |||
@@ -7,30 +7,41 @@ void chat_add(GLData *gld) | |||
7 | 7 | ||
8 | win = fang_win_add(gld); | 8 | win = fang_win_add(gld); |
9 | 9 | ||
10 | bx = elm_box_add(win); | 10 | bx = eo_add(ELM_OBJ_BOX_CLASS, win); |
11 | eo_do(bx, | ||
12 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, EVAS_HINT_EXPAND), | ||
13 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL) | ||
14 | ); | ||
11 | elm_win_resize_object_add(win, bx); | 15 | elm_win_resize_object_add(win, bx); |
12 | evas_object_size_hint_weight_set(bx, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); | ||
13 | evas_object_size_hint_align_set(bx, EVAS_HINT_FILL, EVAS_HINT_FILL); | ||
14 | 16 | ||
15 | en = elm_entry_add(win); | 17 | en = eo_add(ELM_OBJ_ENTRY_CLASS, win); |
16 | elm_entry_scrollable_set(en, EINA_TRUE); | ||
17 | evas_object_size_hint_weight_set(en, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); | ||
18 | evas_object_size_hint_align_set(en, EVAS_HINT_FILL, EVAS_HINT_FILL); | ||
19 | elm_object_text_set(en, "History is shown here"); | 18 | elm_object_text_set(en, "History is shown here"); |
20 | elm_entry_editable_set(en, EINA_FALSE); | 19 | eo_do(en, |
21 | evas_object_show(en); | 20 | elm_obj_entry_scrollable_set(EINA_TRUE), |
21 | elm_obj_entry_editable_set(EINA_FALSE), | ||
22 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, EVAS_HINT_EXPAND), | ||
23 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), | ||
24 | evas_obj_visibility_set(EINA_TRUE) | ||
25 | ); | ||
22 | elm_box_pack_end(bx, en); | 26 | elm_box_pack_end(bx, en); |
27 | eo_unref(en); | ||
23 | 28 | ||
24 | en = elm_entry_add(win); | 29 | en = eo_add(ELM_OBJ_ENTRY_CLASS, win); |
25 | elm_entry_scrollable_set(en, EINA_TRUE); | ||
26 | evas_object_size_hint_weight_set(en, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); | ||
27 | evas_object_size_hint_align_set(en, EVAS_HINT_FILL, EVAS_HINT_FILL); | ||
28 | elm_object_text_set(en, ""); | 30 | elm_object_text_set(en, ""); |
29 | elm_entry_editable_set(en, EINA_TRUE); | 31 | eo_do(en, |
30 | evas_object_show(en); | 32 | elm_obj_entry_scrollable_set(EINA_TRUE), |
33 | // TODO - Setting editable to TRUE is what hangs up extantz on exit. | ||
34 | // elm_obj_entry_editable_set(EINA_TRUE), | ||
35 | elm_obj_entry_editable_set(EINA_FALSE), | ||
36 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, EVAS_HINT_EXPAND), | ||
37 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), | ||
38 | evas_obj_visibility_set(EINA_TRUE) | ||
39 | ); | ||
31 | elm_box_pack_end(bx, en); | 40 | elm_box_pack_end(bx, en); |
41 | eo_unref(en); | ||
32 | 42 | ||
33 | evas_object_show(bx); | 43 | evas_object_show(bx); |
44 | eo_unref(bx); | ||
34 | 45 | ||
35 | fang_win_complete(gld, win, 30, 500, gld->win_w / 3, gld->win_h / 3); | 46 | fang_win_complete(gld, win, 30, 500, gld->win_w / 3, gld->win_h / 3); |
36 | } | 47 | } |
diff --git a/src/extantz/extantz.c b/src/extantz/extantz.c index 28df70f..6ef2b75 100644 --- a/src/extantz/extantz.c +++ b/src/extantz/extantz.c | |||
@@ -34,7 +34,8 @@ static void _resize(GLData *gld) | |||
34 | { | 34 | { |
35 | Evas_GL_API *gl = gld->glApi; | 35 | Evas_GL_API *gl = gld->glApi; |
36 | 36 | ||
37 | _resize_winwin(gld); | 37 | if (gld->elmGl) |
38 | _resize_winwin(gld); | ||
38 | 39 | ||
39 | #if DO_GEARS | 40 | #if DO_GEARS |
40 | GLfloat ar, m[16] = { | 41 | GLfloat ar, m[16] = { |
@@ -56,7 +57,8 @@ static void _resize(GLData *gld) | |||
56 | memcpy(gld->proj, m, sizeof gld->proj); | 57 | memcpy(gld->proj, m, sizeof gld->proj); |
57 | #endif | 58 | #endif |
58 | 59 | ||
59 | gl->glViewport(0, 0, (GLint) gld->img_w, (GLint) gld->img_h); | 60 | if (gl) |
61 | gl->glViewport(0, 0, (GLint) gld->img_w, (GLint) gld->img_h); | ||
60 | } | 62 | } |
61 | 63 | ||
62 | static void _resize_gl(Evas_Object *obj) | 64 | static void _resize_gl(Evas_Object *obj) |
@@ -71,6 +73,16 @@ static void _resize_gl(Evas_Object *obj) | |||
71 | _resize(gld); | 73 | _resize(gld); |
72 | } | 74 | } |
73 | 75 | ||
76 | static void _on_resize(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
77 | { | ||
78 | globals *ourGlobals = data; | ||
79 | GLData *gld = &ourGlobals->gld; | ||
80 | |||
81 | eo_do(gld->win, evas_obj_size_get(&gld->win_w, &gld->win_h)); | ||
82 | eo_do(ourGlobals->tb, evas_obj_size_set(gld->win_w, 25)); | ||
83 | _resize(gld); | ||
84 | } | ||
85 | |||
74 | // Callback from Evas, also used as the general callback for deleting the GL stuff. | 86 | // Callback from Evas, also used as the general callback for deleting the GL stuff. |
75 | static void _clean_gl(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) | 87 | static void _clean_gl(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) |
76 | { | 88 | { |
@@ -128,6 +140,7 @@ static void _draw_gl(Evas_Object *obj) | |||
128 | { | 140 | { |
129 | globals *ourGlobals = evas_object_data_get(obj, "glob"); | 141 | globals *ourGlobals = evas_object_data_get(obj, "glob"); |
130 | GLData *gld = &ourGlobals->gld; | 142 | GLData *gld = &ourGlobals->gld; |
143 | if (!ourGlobals) return; | ||
131 | 144 | ||
132 | if (!gld->doneIrr) gld->doneIrr = startIrr(gld); // Needs to be after gld->win is shown, and needs to be done in the render thread. | 145 | if (!gld->doneIrr) gld->doneIrr = startIrr(gld); // Needs to be after gld->win is shown, and needs to be done in the render thread. |
133 | #if DO_GEARS | 146 | #if DO_GEARS |
@@ -142,7 +155,7 @@ static void _draw_gl(Evas_Object *obj) | |||
142 | drawGears(gld); | 155 | drawGears(gld); |
143 | #endif | 156 | #endif |
144 | 157 | ||
145 | _animate_scene(ourGlobals->scene); | 158 | _animate_scene(ourGlobals); |
146 | 159 | ||
147 | drawIrr_end(gld); | 160 | drawIrr_end(gld); |
148 | 161 | ||
@@ -254,17 +267,19 @@ static Evas_Object *_toolbar_menu_add(Evas_Object *win, Evas_Object *tb, char *l | |||
254 | return menu; | 267 | return menu; |
255 | } | 268 | } |
256 | 269 | ||
257 | static void makeMainMenu(GLData *gld) | 270 | static void makeMainMenu(globals *ourGlobals) |
258 | { | 271 | { |
272 | GLData *gld = &ourGlobals->gld; | ||
259 | Evas_Object *menu, *tb; | 273 | Evas_Object *menu, *tb; |
260 | Elm_Object_Item *tb_it; | 274 | Elm_Object_Item *tb_it; |
261 | 275 | ||
262 | // A toolbar thingy. | 276 | // A toolbar thingy. |
263 | tb = eo_add(ELM_OBJ_TOOLBAR_CLASS, gld->win); | 277 | tb = eo_add(ELM_OBJ_TOOLBAR_CLASS, gld->win); |
278 | ourGlobals->tb = tb; | ||
264 | eo_do(tb, | 279 | eo_do(tb, |
265 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, 0.0), | 280 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, 0.0), |
266 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), | 281 | evas_obj_size_hint_align_set(EVAS_HINT_FILL, EVAS_HINT_FILL), |
267 | elm_obj_toolbar_shrink_mode_set(ELM_TOOLBAR_SHRINK_SCROLL), | 282 | elm_obj_toolbar_shrink_mode_set(ELM_TOOLBAR_SHRINK_MENU), |
268 | evas_obj_size_set(gld->win_w, 25), | 283 | evas_obj_size_set(gld->win_w, 25), |
269 | evas_obj_position_set(0, 0), | 284 | evas_obj_position_set(0, 0), |
270 | elm_obj_toolbar_align_set(0.0) | 285 | elm_obj_toolbar_align_set(0.0) |
@@ -306,7 +321,6 @@ static void makeMainMenu(GLData *gld) | |||
306 | tb_it = elm_toolbar_item_append(tb, NULL, "date time:o'clock", NULL, NULL); | 321 | tb_it = elm_toolbar_item_append(tb, NULL, "date time:o'clock", NULL, NULL); |
307 | 322 | ||
308 | evas_object_show(tb); | 323 | evas_object_show(tb); |
309 | eo_unref(tb); | ||
310 | } | 324 | } |
311 | 325 | ||
312 | EAPI_MAIN int elm_main(int argc, char **argv) | 326 | EAPI_MAIN int elm_main(int argc, char **argv) |
@@ -354,6 +368,7 @@ EAPI_MAIN int elm_main(int argc, char **argv) | |||
354 | #endif | 368 | #endif |
355 | 369 | ||
356 | evas_object_smart_callback_add(gld->win, "delete,request", _on_done, gld); | 370 | evas_object_smart_callback_add(gld->win, "delete,request", _on_done, gld); |
371 | evas_object_event_callback_add(gld->win, EVAS_CALLBACK_RESIZE, _on_resize, &ourGlobals); | ||
357 | 372 | ||
358 | // Get the screen size. | 373 | // Get the screen size. |
359 | elm_win_screen_size_get(gld->win, &gld->win_x, &gld->win_y, &gld->scr_w, &gld->scr_h); | 374 | elm_win_screen_size_get(gld->win, &gld->win_x, &gld->win_y, &gld->scr_w, &gld->scr_h); |
@@ -373,7 +388,6 @@ EAPI_MAIN int elm_main(int argc, char **argv) | |||
373 | elm_win_resize_object_add(gld->win, obj); | 388 | elm_win_resize_object_add(gld->win, obj); |
374 | eo_unref(obj); | 389 | eo_unref(obj); |
375 | 390 | ||
376 | |||
377 | gld->bx = eo_add(ELM_OBJ_BOX_CLASS, gld->win); | 391 | gld->bx = eo_add(ELM_OBJ_BOX_CLASS, gld->win); |
378 | eo_do(gld->bx, | 392 | eo_do(gld->bx, |
379 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, EVAS_HINT_EXPAND), | 393 | evas_obj_size_hint_weight_set(EVAS_HINT_EXPAND, EVAS_HINT_EXPAND), |
@@ -384,13 +398,12 @@ EAPI_MAIN int elm_main(int argc, char **argv) | |||
384 | 398 | ||
385 | // overlay_add(gld); | 399 | // overlay_add(gld); |
386 | woMan_add(gld); | 400 | woMan_add(gld); |
387 | // TODO - This is what causes it to hang after quitting. Fix it. | 401 | chat_add(gld); |
388 | // chat_add(gld); | ||
389 | 402 | ||
390 | // Gotta do this after adding the windows, otherwise the menu renders under the window. | 403 | // Gotta do this after adding the windows, otherwise the menu renders under the window. |
391 | // This sucks, gotta redefine this menu each time we create a new window? | 404 | // This sucks, gotta redefine this menu each time we create a new window? |
392 | // Also, GL focus gets lost when any menu is used. sigh | 405 | // Also, GL focus gets lost when any menu is used. sigh |
393 | makeMainMenu(gld); | 406 | makeMainMenu(&ourGlobals); |
394 | 407 | ||
395 | // This does elm_box_pack_end(), so needs to be after the others. | 408 | // This does elm_box_pack_end(), so needs to be after the others. |
396 | init_evas_gl(&ourGlobals); | 409 | init_evas_gl(&ourGlobals); |
@@ -418,8 +431,9 @@ EAPI_MAIN int elm_main(int argc, char **argv) | |||
418 | 431 | ||
419 | if (gld->win) | 432 | if (gld->win) |
420 | { | 433 | { |
434 | Evas_3D_Demo_fini(&ourGlobals); | ||
435 | eo_unref(ourGlobals.tb); | ||
421 | eo_unref(gld->bx); | 436 | eo_unref(gld->bx); |
422 | Evas_3D_Demo_fini(); | ||
423 | evas_object_del(gld->win); | 437 | evas_object_del(gld->win); |
424 | } | 438 | } |
425 | 439 | ||
diff --git a/src/extantz/extantz.h b/src/extantz/extantz.h index c475fa8..b91124e 100644 --- a/src/extantz/extantz.h +++ b/src/extantz/extantz.h | |||
@@ -1,5 +1,5 @@ | |||
1 | #define USE_PHYSICS 1 | 1 | #define USE_PHYSICS 1 |
2 | #define USE_IRR 1 | 2 | #define USE_IRR 0 |
3 | #define USE_DEMO 1 | 3 | #define USE_DEMO 1 |
4 | #define DO_GEARS 0 | 4 | #define DO_GEARS 0 |
5 | 5 | ||
@@ -128,6 +128,8 @@ struct _Gear | |||
128 | int count; | 128 | int count; |
129 | }; | 129 | }; |
130 | 130 | ||
131 | |||
132 | |||
131 | typedef struct _Scene_Data | 133 | typedef struct _Scene_Data |
132 | { | 134 | { |
133 | Evas_Object *image; // Our Elm image. | 135 | Evas_Object *image; // Our Elm image. |
@@ -216,6 +218,7 @@ typedef struct _globals | |||
216 | { | 218 | { |
217 | Evas *evas; | 219 | Evas *evas; |
218 | Evas_Object *win; // Our Elm window. | 220 | Evas_Object *win; // Our Elm window. |
221 | Evas_Object *tb; // Our Elm toolbar. | ||
219 | Eina_Clist widgets; // Our windows widgets. | 222 | Eina_Clist widgets; // Our windows widgets. |
220 | int logDom; // Our logging domain. | 223 | int logDom; // Our logging domain. |
221 | 224 | ||
@@ -239,7 +242,9 @@ EAPI void finishIrr(GLData *gld); | |||
239 | 242 | ||
240 | EAPI void Evas_3D_Demo_add(globals *ourGlobals); | 243 | EAPI void Evas_3D_Demo_add(globals *ourGlobals); |
241 | Eina_Bool _animate_scene(void *data); | 244 | Eina_Bool _animate_scene(void *data); |
242 | void Evas_3D_Demo_fini(void); | 245 | void Evas_3D_Demo_fini(globals *ourGlobals); |
246 | |||
247 | void cameraAdd(Evas_Object *win, GLData *gld); | ||
243 | 248 | ||
244 | Evas_Object *fang_win_add(GLData *gld); | 249 | Evas_Object *fang_win_add(GLData *gld); |
245 | void fang_win_complete(GLData *gld, Evas_Object *win, int x, int y, int w, int h); | 250 | void fang_win_complete(GLData *gld, Evas_Object *win, int x, int y, int w, int h); |
diff --git a/src/extantz/fangWin.c b/src/extantz/fangWin.c index 06bfde4..8f68658 100644 --- a/src/extantz/fangWin.c +++ b/src/extantz/fangWin.c | |||
@@ -1,176 +1,6 @@ | |||
1 | #include "extantz.h" | 1 | #include "extantz.h" |
2 | 2 | ||
3 | 3 | ||
4 | static void _on_camera_input_down(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
5 | { | ||
6 | GLData *gld = data; | ||
7 | Evas_Event_Key_Down *ev = event_info; | ||
8 | |||
9 | if (gld->move) | ||
10 | { | ||
11 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't know at what point the camera animate routine is actually called. | ||
12 | |||
13 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | ||
14 | // TODO - make this a hash lookup dammit. | ||
15 | if (0 == strcmp(ev->key, "Escape")) | ||
16 | { | ||
17 | } | ||
18 | else if (0 == strcmp(ev->key, "Left")) | ||
19 | gld->move->r = 2.0; | ||
20 | else if (0 == strcmp(ev->key, "Right")) | ||
21 | gld->move->r = -2.0; | ||
22 | else if (0 == strcmp(ev->key, "Up")) | ||
23 | gld->move->x = 2.0; | ||
24 | else if (0 == strcmp(ev->key, "Down")) | ||
25 | gld->move->x = -2.0; | ||
26 | // else if (0 == strcmp(ev->key, "Prior")) | ||
27 | // ; | ||
28 | // else if (0 == strcmp(ev->key, "Next")) | ||
29 | // ; | ||
30 | // else if (0 == strcmp(ev->key, "Home")) | ||
31 | // ; | ||
32 | // else if (0 == strcmp(ev->key, "End")) | ||
33 | // ; | ||
34 | else if (0 == strcmp(ev->key, "space")) | ||
35 | gld->move->jump = 1.0; | ||
36 | else | ||
37 | printf("Unexpected down keystroke - %s\n", ev->key); | ||
38 | } | ||
39 | else | ||
40 | printf("Camera input not ready\n"); | ||
41 | } | ||
42 | |||
43 | /* SL / OS camera controls | ||
44 | up / down / w / s moves avatar forward / backward | ||
45 | shifted version does the same | ||
46 | double tap triggers run mode / or fast fly mode | ||
47 | Running backwards turns your avatar to suit, walking does not. | ||
48 | left / right / a / d rotates avatar left / right, strafes in mouselook | ||
49 | shifted version turns the avatar to walk sideways, so not really a strafe. | ||
50 | So not sure if the "strafe" in mouse look turns the avatar as well? | ||
51 | PgDn / c crouch while it is held down move up in flight mode | ||
52 | PgUp jump move down in flight mode | ||
53 | Home toggle flying | ||
54 | End Nothing? | ||
55 | Esc return to third person view | ||
56 | m toggle mouse look | ||
57 | mouse wheel move view closer / further away from current focused object or avatar | ||
58 | Alt left click focus on some other object | ||
59 | Ins ??? | ||
60 | Del ??? | ||
61 | BS ??? | ||
62 | Tab ??? | ||
63 | |||
64 | Mouse look is just first person view, moving mouse looks left / right / up / down. | ||
65 | Not sure if the avatar rotates with left / right, but that's likely. | ||
66 | |||
67 | mouse moves With the left mouse button held down - | ||
68 | left / right up / down | ||
69 | --------------------------------- | ||
70 | for avatar swings avatar around zoom in and out of avatar | ||
71 | for object nothing | ||
72 | alt orbit left / right zoom in and out | ||
73 | alt ctrl orbit left / right orbit up / down | ||
74 | alt shift orbit left / right zoom in and out | ||
75 | alt ctrl shift shift view left / right / up / down | ||
76 | ctrl Nothing? | ||
77 | shift Nothing? | ||
78 | ctrl shift Nothing? | ||
79 | |||
80 | Need to also consider when looking at a moving object / avatar. | ||
81 | |||
82 | I think there are other letter keys that duplicate arrow keys and such. I'll look for them later, but I don't use them. | ||
83 | No idea what the function keys are mapped to, but think it's various non camera stuff. | ||
84 | I'm damn well leaving the Win/Command and Menu keys for the OS / window manager. lol | ||
85 | Keypad keys? Not interested, I don't have them. | ||
86 | Print Screen / SysRq, Pause / Break, other oddball keys, also not interested. | ||
87 | NOTE - gonna have an easily programmable "bind key to command" thingy, like E17s, so that can deal with other keys. | ||
88 | Should even let them be saveable so people can swap them with other people easily. | ||
89 | |||
90 | TODO - implement things like space mouse, sixaxis, phone as controller, joysticks, data gloves, etc. | ||
91 | */ | ||
92 | |||
93 | /* A moveRotate array of floats. | ||
94 | * X, Y, Z, and whatever the usual letters are for rotations. lol | ||
95 | * Each one means "move or rotate this much in this direction". | ||
96 | * Where 1.0 means "what ever the standard move is if that key is held down". | ||
97 | * So a keyboard move would just change it's part to 1.0 or -1.0 on key down, | ||
98 | * and back to 0.0 on key up. Or 2.0 / -2.0 if in run mode. | ||
99 | * Which would even work in fly mode. | ||
100 | * A joystick could be set to range over -2.0 to 2.0, and just set it's part directly. | ||
101 | * A mouse look rotate, well will come to that when we need to. B-) | ||
102 | * Setting the x or y to be the DIFFERENCE in window position of the mouse (-1.0 to 1.0) since the last frame. | ||
103 | * | ||
104 | * TODO - In the Elm_glview version, 2.0 seems to be correct speed for walking, but I thought 1.0 was in Evas_GL. | ||
105 | */ | ||
106 | |||
107 | static void _on_camera_input_up(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
108 | { | ||
109 | GLData *gld = data; | ||
110 | Evas_Event_Key_Up *ev = event_info; | ||
111 | |||
112 | if (gld->move) | ||
113 | { | ||
114 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't know at what point the camera animate routine is actually called. | ||
115 | |||
116 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | ||
117 | // TODO - make this a hash lookup dammit. | ||
118 | if (0 == strcmp(ev->key, "Escape")) | ||
119 | { | ||
120 | } | ||
121 | else if (0 == strcmp(ev->key, "Left")) | ||
122 | gld->move->r = 0.0; | ||
123 | else if (0 == strcmp(ev->key, "Right")) | ||
124 | gld->move->r = 0.0; | ||
125 | else if (0 == strcmp(ev->key, "Up")) | ||
126 | gld->move->x = 0.0; | ||
127 | else if (0 == strcmp(ev->key, "Down")) | ||
128 | gld->move->x = 0.0; | ||
129 | // else if (0 == strcmp(ev->key, "Prior")) | ||
130 | // ; | ||
131 | // else if (0 == strcmp(ev->key, "Next")) | ||
132 | // ; | ||
133 | // else if (0 == strcmp(ev->key, "Home")) | ||
134 | // ; | ||
135 | // else if (0 == strcmp(ev->key, "End")) | ||
136 | // ; | ||
137 | else if (0 == strcmp(ev->key, "space")) | ||
138 | gld->move->jump = 0.0; | ||
139 | else | ||
140 | printf("Unexpected up keystroke - %s\n", ev->key); | ||
141 | } | ||
142 | else | ||
143 | printf("Camera input not ready\n"); | ||
144 | } | ||
145 | |||
146 | // Elm style event callback. | ||
147 | static Eina_Bool _cb_event_GL(void *data, Evas_Object *obj, Evas_Object *src, Evas_Callback_Type type, void *event_info) | ||
148 | { | ||
149 | GLData *gld = data; | ||
150 | Eina_Bool processed = EINA_FALSE; | ||
151 | |||
152 | switch (type) | ||
153 | { | ||
154 | case EVAS_CALLBACK_KEY_DOWN : | ||
155 | { | ||
156 | _on_camera_input_down(gld, evas_object_evas_get(obj), obj, event_info); | ||
157 | processed = EINA_TRUE; | ||
158 | break; | ||
159 | } | ||
160 | |||
161 | case EVAS_CALLBACK_KEY_UP : | ||
162 | { | ||
163 | _on_camera_input_up(gld, evas_object_evas_get(obj), obj, event_info); | ||
164 | processed = EINA_TRUE; | ||
165 | break; | ||
166 | } | ||
167 | |||
168 | default : | ||
169 | printf("Unknown GL input event.\n"); | ||
170 | } | ||
171 | |||
172 | return processed; | ||
173 | } | ||
174 | 4 | ||
175 | // Elm inlined image windows needs this to change focus on mouse click. | 5 | // Elm inlined image windows needs this to change focus on mouse click. |
176 | // Evas style event callback. | 6 | // Evas style event callback. |
@@ -305,9 +135,7 @@ void overlay_add(GLData *gld) | |||
305 | // According to the Elm inlined image window example, this is what's needed to. | 135 | // According to the Elm inlined image window example, this is what's needed to. |
306 | evas_object_event_callback_add(elm_win_inlined_image_object_get(gld->winwin), EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_elm, gld); | 136 | evas_object_event_callback_add(elm_win_inlined_image_object_get(gld->winwin), EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_elm, gld); |
307 | // In this code, we are making our own camera, so grab it's input when we are focused. | 137 | // In this code, we are making our own camera, so grab it's input when we are focused. |
308 | evas_object_event_callback_add(gld->winwin, EVAS_CALLBACK_KEY_DOWN, _on_camera_input_down, gld); | 138 | cameraAdd(gld->winwin, gld); |
309 | evas_object_event_callback_add(gld->winwin, EVAS_CALLBACK_KEY_UP, _on_camera_input_up, gld); | ||
310 | elm_object_event_callback_add(gld->winwin, _cb_event_GL, gld); | ||
311 | 139 | ||
312 | elm_win_alpha_set(gld->winwin, EINA_TRUE); | 140 | elm_win_alpha_set(gld->winwin, EINA_TRUE); |
313 | // Apparently transparent is not good enough for ELM backgrounds, so make it a rectangle. | 141 | // Apparently transparent is not good enough for ELM backgrounds, so make it a rectangle. |