From a11322d5de7959e98695445ddb270e0f28c421d5 Mon Sep 17 00:00:00 2001 From: David Walter Seikel Date: Wed, 14 May 2014 09:04:07 +1000 Subject: Implement a half arsed touch_start() from extantz. --- src/extantz/extantz.c | 24 ++++++++++++++++++++++++ src/extantz/extantz.h | 2 ++ src/extantz/scenri.c | 2 ++ 3 files changed, 28 insertions(+) (limited to 'src/extantz') diff --git a/src/extantz/extantz.c b/src/extantz/extantz.c index 848bc9a..e16db3c 100644 --- a/src/extantz/extantz.c +++ b/src/extantz/extantz.c @@ -83,6 +83,27 @@ static Eina_Bool _del(void *data, int type, Ecore_Con_Event_Server_Del *ev) return ECORE_CALLBACK_RENEW; } +static void _onWorldClick(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void *einfo) +{ + Evas_3D_Node *n = data; +// Evas_Event_Mouse_Down *ev = einfo; + + if (n) + { + char *name = NULL; + + name = evas_object_data_get(n, "Name"); + if (strcmp("cube", name) == 0) + { + char SID[64]; + + // CUBE_UUID.events.touch_start(1), but we just make one up for now. + snprintf(SID, sizeof(SID), "%08lx-%04lx-%04lx-%04lx-%012lx", random(), random() % 0xFFFF, random() % 0xFFFF, random() % 0xFFFF, random()); + sendForth(ourGlobals.server, SID, "events.touch_start(1)"); + } + } +} + static void gldata_init(GLData *gld) { gld->useIrr = USE_IRR; @@ -644,6 +665,9 @@ EAPI_MAIN int elm_main(int argc, char **argv) else PC("Failed to connect to server!"); + // Setup our callback for clicking in world. + ourGlobals.scene->clickCb = _onWorldClick; + elm_run(); if (ourGlobals.server) ecore_con_server_del(ourGlobals.server); diff --git a/src/extantz/extantz.h b/src/extantz/extantz.h index 0bbf76f..bfab4cb 100644 --- a/src/extantz/extantz.h +++ b/src/extantz/extantz.h @@ -158,6 +158,8 @@ typedef struct _Scene_Data Evas_3D_Texture *texture_diffuse; cameraMove *move; + + Evas_Object_Event_Cb clickCb; } Scene_Data; // Elm GL view related data here. diff --git a/src/extantz/scenri.c b/src/extantz/scenri.c index 051d39f..eaec88e 100644 --- a/src/extantz/scenri.c +++ b/src/extantz/scenri.c @@ -75,6 +75,7 @@ static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void { name = evas_object_data_get(n, "Name"); printf("Picked : "); + if (scene->clickCb) scene->clickCb(n, e, o, einfo); } else printf("Not picked : "); @@ -83,6 +84,7 @@ static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void printf("output(%d, %d) canvas(%d, %d) object(%d, %d) scene(%f, %f) texcoord(%f, %f) node(%p) %s mesh(%p)\n", ev->output.x, ev->output.y, ev->canvas.x, ev->canvas.y, obj_x, obj_y, scene_x, scene_y, s, t, n, name, m); + } Scene_Data *scenriAdd(Evas_Object *win) -- cgit v1.1