diff options
author | David Walter Seikel | 2013-01-27 12:15:55 +1000 |
---|---|---|
committer | David Walter Seikel | 2013-01-27 12:15:55 +1000 |
commit | 6347bf218495877f00c91798fdde81a6103f6294 (patch) | |
tree | ff1e398611abe0f27939c91bcdf0a9eaba701f15 | |
parent | Make keyboard rotation work. (diff) | |
download | SledjHamr-6347bf218495877f00c91798fdde81a6103f6294.zip SledjHamr-6347bf218495877f00c91798fdde81a6103f6294.tar.gz SledjHamr-6347bf218495877f00c91798fdde81a6103f6294.tar.bz2 SledjHamr-6347bf218495877f00c91798fdde81a6103f6294.tar.xz |
Fix up those arrow keys by getting elm out of the loop.
-rw-r--r-- | ClientHamr/extantz/extantz.c | 128 |
1 files changed, 69 insertions, 59 deletions
diff --git a/ClientHamr/extantz/extantz.c b/ClientHamr/extantz/extantz.c index 7e9f353..6d45501 100644 --- a/ClientHamr/extantz/extantz.c +++ b/ClientHamr/extantz/extantz.c | |||
@@ -350,86 +350,95 @@ static void _cb_mouse_down_elm(void *data, Evas *evas, Evas_Object *obj, void *e | |||
350 | { | 350 | { |
351 | gld->camFocus = 0; | 351 | gld->camFocus = 0; |
352 | // TODO - Yes we really DO need to figure out what was clicked on and set focus to it. sigh | 352 | // TODO - Yes we really DO need to figure out what was clicked on and set focus to it. sigh |
353 | // For now, we only got one window, focus on it's box. | 353 | // elm_object_focus_set(gld->bx, EINA_TRUE); |
354 | elm_object_focus_set(gld->bx, EINA_TRUE); | ||
355 | printf("ELM object focused.\n"); | 354 | printf("ELM object focused.\n"); |
356 | } | 355 | } |
357 | } | 356 | } |
358 | 357 | ||
359 | static Eina_Bool _on_camera_input(void *data, Evas_Object *obj, Evas_Object *src, Evas_Callback_Type type, void *event_info) | 358 | // These do not work as elm callbacks, coz Elm is grabbing the Left, Right, Up, and Down KEY_DOWNs. Something else is messing up Home + PgUp / PgDn. |
359 | // It's a purely Evas object anyway. | ||
360 | static void _on_camera_input_down(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
360 | { | 361 | { |
361 | GLData *gld = data; | 362 | GLData *gld = data; |
363 | Evas_Event_Key_Down *ev = event_info; | ||
362 | 364 | ||
363 | if (gld->camFocus) | 365 | if (gld->camFocus) |
364 | { | 366 | { |
365 | if (gld->move) | 367 | if (gld->move) |
366 | { | 368 | { |
367 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't now at what point the camera animate routine is actually called. | 369 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't now at what point the camera animate routine is actually called. |
368 | Evas_Event_Key_Down *ev = event_info; | ||
369 | 370 | ||
370 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | 371 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... |
371 | // TODO - make this a hash lookup dammit. | 372 | // TODO - make this a hash lookup dammit. |
372 | // TODO - these are not working, coz Elm is grabbing the Left, Right, Up, and Down KEY_DOWNs. | 373 | if (0 == strcmp(ev->key, "Escape")) |
373 | // TODO - no idea why yet, but can't do Home and Prior / Next at the same time. Don't seem to be a bug in the Irrlicht original at least. | ||
374 | if (EVAS_CALLBACK_KEY_DOWN == type) | ||
375 | { | 374 | { |
376 | if (0 == strcmp(ev->keyname, "Escape")) | ||
377 | { | ||
378 | } | ||
379 | else if (0 == strcmp(ev->key, "Left")) | ||
380 | gld->move->r = 1.0; | ||
381 | else if (0 == strcmp(ev->key, "Right")) | ||
382 | gld->move->r = -1.0; | ||
383 | else if (0 == strcmp(ev->key, "Up")) | ||
384 | gld->move->x = 1.0; | ||
385 | else if (0 == strcmp(ev->key, "Down")) | ||
386 | gld->move->x = -1.0; | ||
387 | else if (0 == strcmp(ev->key, "Prior")) | ||
388 | gld->move->x = 1.0; | ||
389 | else if (0 == strcmp(ev->key, "Next")) | ||
390 | gld->move->x = -1.0; | ||
391 | else if (0 == strcmp(ev->key, "Home")) | ||
392 | gld->move->r = 1.0; | ||
393 | else if (0 == strcmp(ev->key, "End")) | ||
394 | gld->move->r = -1.0; | ||
395 | else if (0 == strcmp(ev->key, "space")) | ||
396 | gld->move->jump = 1.0; | ||
397 | else | ||
398 | printf("Unexpected down keystroke - %s\n", ev->key); | ||
399 | } | 375 | } |
400 | else if (EVAS_CALLBACK_KEY_UP == type) | 376 | else if (0 == strcmp(ev->key, "Left")) |
377 | gld->move->r = 1.0; | ||
378 | else if (0 == strcmp(ev->key, "Right")) | ||
379 | gld->move->r = -1.0; | ||
380 | else if (0 == strcmp(ev->key, "Up")) | ||
381 | gld->move->x = 1.0; | ||
382 | else if (0 == strcmp(ev->key, "Down")) | ||
383 | gld->move->x = -1.0; | ||
384 | else if (0 == strcmp(ev->key, "Prior")) | ||
385 | ; | ||
386 | else if (0 == strcmp(ev->key, "Next")) | ||
387 | ; | ||
388 | else if (0 == strcmp(ev->key, "Home")) | ||
389 | ; | ||
390 | else if (0 == strcmp(ev->key, "End")) | ||
391 | ; | ||
392 | else if (0 == strcmp(ev->key, "space")) | ||
393 | gld->move->jump = 1.0; | ||
394 | else | ||
395 | printf("Unexpected down keystroke - %s\n", ev->key); | ||
396 | } | ||
397 | else | ||
398 | printf("Camera input not ready\n"); | ||
399 | } | ||
400 | } | ||
401 | |||
402 | static void _on_camera_input_up(void *data, Evas *evas, Evas_Object *obj, void *event_info) | ||
403 | { | ||
404 | GLData *gld = data; | ||
405 | Evas_Event_Key_Up *ev = event_info; | ||
406 | |||
407 | if (gld->camFocus) | ||
408 | { | ||
409 | if (gld->move) | ||
410 | { | ||
411 | // TODO - Careful, gld->move MIGHT be read at the other end by another thread. MIGHT, coz I really don't now at what point the camera animate routine is actually called. | ||
412 | |||
413 | // Yes, we are dealing with the horrid Evas keyboard handling FUCKING STRING COMPARES! Soooo ... | ||
414 | // TODO - make this a hash lookup dammit. | ||
415 | if (0 == strcmp(ev->key, "Escape")) | ||
401 | { | 416 | { |
402 | if (0 == strcmp(ev->keyname, "Escape")) | ||
403 | { | ||
404 | } | ||
405 | else if (0 == strcmp(ev->key, "Left")) | ||
406 | gld->move->r = 0.0; | ||
407 | else if (0 == strcmp(ev->key, "Right")) | ||
408 | gld->move->r = 0.0; | ||
409 | else if (0 == strcmp(ev->key, "Up")) | ||
410 | gld->move->x = 0.0; | ||
411 | else if (0 == strcmp(ev->key, "Down")) | ||
412 | gld->move->x = 0.0; | ||
413 | else if (0 == strcmp(ev->key, "Prior")) | ||
414 | gld->move->x = 0.0; | ||
415 | else if (0 == strcmp(ev->key, "Next")) | ||
416 | gld->move->x = 0.0; | ||
417 | else if (0 == strcmp(ev->key, "Home")) | ||
418 | gld->move->r = 0.0; | ||
419 | else if (0 == strcmp(ev->key, "End")) | ||
420 | gld->move->r = 0.0; | ||
421 | else if (0 == strcmp(ev->key, "space")) | ||
422 | gld->move->jump = 0.0; | ||
423 | else | ||
424 | printf("Unexpected up keystroke - %s\n", ev->key); | ||
425 | } | 417 | } |
426 | return EINA_TRUE; | 418 | else if (0 == strcmp(ev->key, "Left")) |
419 | gld->move->r = 0.0; | ||
420 | else if (0 == strcmp(ev->key, "Right")) | ||
421 | gld->move->r = 0.0; | ||
422 | else if (0 == strcmp(ev->key, "Up")) | ||
423 | gld->move->x = 0.0; | ||
424 | else if (0 == strcmp(ev->key, "Down")) | ||
425 | gld->move->x = 0.0; | ||
426 | else if (0 == strcmp(ev->key, "Prior")) | ||
427 | ; | ||
428 | else if (0 == strcmp(ev->key, "Next")) | ||
429 | ; | ||
430 | else if (0 == strcmp(ev->key, "Home")) | ||
431 | ; | ||
432 | else if (0 == strcmp(ev->key, "End")) | ||
433 | ; | ||
434 | else if (0 == strcmp(ev->key, "space")) | ||
435 | gld->move->jump = 0.0; | ||
436 | else | ||
437 | printf("Unexpected up keystroke - %s\n", ev->key); | ||
427 | } | 438 | } |
428 | else | 439 | else |
429 | printf("Camera input not ready\n"); | 440 | printf("Camera input not ready\n"); |
430 | } | 441 | } |
431 | |||
432 | return EINA_FALSE; // TRUE = event was processed here, don't propagate. FALSE = propagate event, not processed here. | ||
433 | } | 442 | } |
434 | 443 | ||
435 | static void _resize(GLData *gld) | 444 | static void _resize(GLData *gld) |
@@ -544,7 +553,6 @@ on_del(void *data, Evas *e, Evas_Object *obj, void *event_info) | |||
544 | if (!gld) return; | 553 | if (!gld) return; |
545 | Evas_GL_API *gl = gld->glapi; | 554 | Evas_GL_API *gl = gld->glapi; |
546 | 555 | ||
547 | elm_object_event_callback_del(gld->r1, _on_camera_input, gld); | ||
548 | ecore_animator_del(gld->animator); | 556 | ecore_animator_del(gld->animator); |
549 | 557 | ||
550 | if (gld->useEGL) | 558 | if (gld->useEGL) |
@@ -740,7 +748,8 @@ static void init_evas_gl(GLData *gld, int w, int h) | |||
740 | gld->animator = ecore_animator_add(doFrame, gld); // This animator will be called every frame tick, which defaults to 1/30 seconds. | 748 | gld->animator = ecore_animator_add(doFrame, gld); // This animator will be called every frame tick, which defaults to 1/30 seconds. |
741 | 749 | ||
742 | // In this code, we are making our own camera, so grab it's input when we are focused. | 750 | // In this code, we are making our own camera, so grab it's input when we are focused. |
743 | elm_object_event_callback_add(gld->win, _on_camera_input, gld); | 751 | evas_object_event_callback_add(gld->win, EVAS_CALLBACK_KEY_DOWN, _on_camera_input_down, gld); |
752 | evas_object_event_callback_add(gld->win, EVAS_CALLBACK_KEY_UP, _on_camera_input_up, gld); | ||
744 | evas_object_event_callback_add(gld->r1, EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_GL, gld); | 753 | evas_object_event_callback_add(gld->r1, EVAS_CALLBACK_MOUSE_DOWN, _cb_mouse_down_GL, gld); |
745 | gld->camFocus = 1; // Start with the GL camera focused. | 754 | gld->camFocus = 1; // Start with the GL camera focused. |
746 | 755 | ||
@@ -1012,6 +1021,7 @@ fill(Evas_Object *win) | |||
1012 | 1021 | ||
1013 | evas_object_show(bx); | 1022 | evas_object_show(bx); |
1014 | } | 1023 | } |
1024 | |||
1015 | static void | 1025 | static void |
1016 | cb_mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_info) | 1026 | cb_mouse_move(void *data, Evas *evas, Evas_Object *obj, void *event_info) |
1017 | { | 1027 | { |