diff options
author | Rusty Lynch <rusty.lynch@intel.com> | 2013-08-08 21:22:40 -0700 |
---|---|---|
committer | Kristian Høgsberg <krh@bitplanet.net> | 2013-08-12 16:54:10 -0700 |
commit | 3bb2b8cfe950e084ea3bb214a06c296266f97da3 (patch) | |
tree | 0479eb2183252ff7f8a9be89245e99daec98ec5c /clients/smoke.c | |
parent | 041815aa0570b53eb587b960ded70a5a4c8d8184 (diff) |
smoke: Add touch support to smoke example
Diffstat (limited to 'clients/smoke.c')
-rw-r--r-- | clients/smoke.c | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/clients/smoke.c b/clients/smoke.c index 0177424b..6b557974 100644 --- a/clients/smoke.c +++ b/clients/smoke.c @@ -225,11 +225,9 @@ redraw_handler(struct widget *widget, void *data) wl_surface_commit(window_get_wl_surface(smoke->window)); } -static int -smoke_motion_handler(struct widget *widget, struct input *input, - uint32_t time, float x, float y, void *data) +static void +smoke_motion_handler(struct smoke *smoke, float x, float y) { - struct smoke *smoke = data; int i, i0, i1, j, j0, j1, k, d = 5; if (x - d < 1) @@ -257,11 +255,25 @@ smoke_motion_handler(struct widget *widget, struct input *input, smoke->b[0].v[k] += 256 - (random() & 512); smoke->b[0].d[k] += 1; } +} + +static int +mouse_motion_handler(struct widget *widget, struct input *input, + uint32_t time, float x, float y, void *data) +{ + smoke_motion_handler(data, x, y); return CURSOR_HAND1; } static void +touch_motion_handler(struct widget *widget, uint32_t time, + int32_t id, float x, float y, void *data) +{ + smoke_motion_handler(data, x, y); +} + +static void resize_handler(struct widget *widget, int32_t width, int32_t height, void *data) { @@ -304,7 +316,8 @@ int main(int argc, char *argv[]) smoke.b[1].u = calloc(size, sizeof(float)); smoke.b[1].v = calloc(size, sizeof(float)); - widget_set_motion_handler(smoke.widget, smoke_motion_handler); + widget_set_motion_handler(smoke.widget, mouse_motion_handler); + widget_set_touch_motion_handler(smoke.widget, touch_motion_handler); widget_set_resize_handler(smoke.widget, resize_handler); widget_set_redraw_handler(smoke.widget, redraw_handler); |