diff options
author | root <root@no.no.james.local> | 2015-12-28 11:06:03 +0000 |
---|---|---|
committer | root <root@no.no.james.local> | 2015-12-28 11:06:03 +0000 |
commit | 5a84d0ece0af652f3453088e1b2524c36730dff7 (patch) | |
tree | d5d3ec766db6002d876c468d7d18132f469cb719 /master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679 | |
download | xorg-input-kobomultitouch-pq-5a84d0ece0af652f3453088e1b2524c36730dff7.tar.gz xorg-input-kobomultitouch-pq-5a84d0ece0af652f3453088e1b2524c36730dff7.tar.bz2 xorg-input-kobomultitouch-pq-5a84d0ece0af652f3453088e1b2524c36730dff7.zip |
Diffstat (limited to 'master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679')
-rw-r--r-- | master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679 | 181 |
1 files changed, 181 insertions, 0 deletions
diff --git a/master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679 b/master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679 new file mode 100644 index 0000000..9b411ae --- /dev/null +++ b/master/marek-010e9b62eabfed042f35b72e8fa510df2dd7f679 @@ -0,0 +1,181 @@ +diff --git a/driver/kobomultitouch_drv.c b/driver/kobomultitouch_drv.c +index fca41b9..4a034c6 100644 +--- a/driver/kobomultitouch_drv.c ++++ b/driver/kobomultitouch_drv.c +@@ -193,24 +193,25 @@ static int device_close(LocalDevicePtr local) + return Success; + } + +-static void tickle_button(LocalDevicePtr local, int id) ++static void tickle_button(LocalDevicePtr local, int id, int posx, int posy) + { +- xf86PostButtonEvent(local->dev, FALSE, id, 1, 0, 0); +- xf86PostButtonEvent(local->dev, FALSE, id, 0, 0, 0); ++ xf86PostMotionEvent(local->dev, 1, 0, 2, posx, posy); ++ xf86PostButtonEvent(local->dev, 1, id, 1, 0, 0); ++ xf86PostButtonEvent(local->dev, 1, id, 0, 0, 0); + } + + static void button_scroll(LocalDevicePtr local, + int btdec, int btinc, + int *scroll, int step, +- int delta) ++ int delta, int posx, int posy) + { + *scroll += delta; + while (*scroll > step) { +- tickle_button(local, btinc); ++ tickle_button(local, btinc, posx, posy); + *scroll -= step; + } + while (*scroll < -step) { +- tickle_button(local, btdec); ++ tickle_button(local, btdec, posx, posy); + *scroll += step; + } + } +@@ -227,47 +228,49 @@ static void handle_gestures(LocalDevicePtr local, + vswipe = 0; + hswipe = 0; + } +- foreach_bit(i, gs->btmask) +- xf86PostButtonEvent(local->dev, FALSE, ++ foreach_bit(i, gs->btmask) { ++ xf86PostMotionEvent(local->dev, 1, 0, 2, gs->posx, gs->posy); ++ xf86PostButtonEvent(local->dev, 1, + i + 1, GETBIT(gs->btdata, i), 0, 0); +- if (GETBIT(gs->type, GS_MOVE)) +- xf86PostMotionEvent(local->dev, 0, 0, 2, gs->dx, gs->dy); +- ++ } ++ if (GETBIT(gs->type, GS_MOVE)) { ++ xf86PostMotionEvent(local->dev, 1, 0, 2, gs->posx, gs->posy); ++ } + if (GETBIT(gs->type, GS_VSCROLL)) { + int step = 1 + vscroll_fraction * get_cap_ysize(caps); +- button_scroll(local, 4, 5, &vscroll, step, gs->dy); ++ button_scroll(local, 4, 5, &vscroll, step, gs->dy, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_HSCROLL)) { + int step = 1 + hscroll_fraction * get_cap_xsize(caps); +- button_scroll(local, 6, 7, &hscroll, step, gs->dx); ++ button_scroll(local, 6, 7, &hscroll, step, gs->dx, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_VSWIPE)) { + int step = 1 + vswipe_fraction * get_cap_ysize(caps); +- button_scroll(local, 8, 9, &vswipe, step, gs->dy); ++ button_scroll(local, 8, 9, &vswipe, step, gs->dy, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_HSWIPE)) { + int step = 1 + hswipe_fraction * get_cap_xsize(caps); +- button_scroll(local, 10, 11, &hswipe, step, gs->dx); ++ button_scroll(local, 10, 11, &hswipe, step, gs->dx, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_SCALE)) { + int step = 1 + scale_fraction * get_cap_xsize(caps); +- button_scroll(local, 12, 13, &scale, step, gs->scale); ++ button_scroll(local, 12, 13, &scale, step, gs->scale, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_ROTATE)) { + int step = 1 + rot_fraction * get_cap_xsize(caps); +- button_scroll(local, 14, 15, &rot, step, gs->rot); ++ button_scroll(local, 14, 15, &rot, step, gs->rot, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_TAP) && gs->ntap == 1) { + foreach_bit(i, gs->tapmask) +- tickle_button(local, i + 1); ++ tickle_button(local, i + 1, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_VSWIPE4)) { + int step = 1 + vswipe_fraction * get_cap_ysize(caps); +- button_scroll(local, 16, 17, &vswipe, step, gs->dy); ++ button_scroll(local, 16, 17, &vswipe, step, gs->dy, gs->posx, gs->posy); + } + if (GETBIT(gs->type, GS_HSWIPE4)) { + int step = 1 + hswipe_fraction * get_cap_xsize(caps); +- button_scroll(local, 18, 19, &hswipe, step, gs->dx); ++ button_scroll(local, 18, 19, &hswipe, step, gs->dx, gs->posx, gs->posy); + } + } + +@@ -319,7 +322,7 @@ static int preinit(InputDriverPtr drv, InputInfoPtr pInfo, int flags) + return BadAlloc; + + pInfo->private = mt; +- pInfo->type_name = XI_TOUCHPAD; ++ pInfo->type_name = XI_TOUCHSCREEN; + pInfo->device_control = device_control; + pInfo->read_input = read_input; + pInfo->switch_mode = 0; +@@ -340,7 +343,7 @@ static InputInfoPtr preinit(InputDriverPtr drv, IDevPtr dev, int flags) + goto error; + + local->name = dev->identifier; +- local->type_name = XI_TOUCHPAD; ++ local->type_name = XI_TOUCHSCREEN; + local->device_control = device_control; + local->read_input = read_input; + local->private = mt; +diff --git a/include/gestures.h b/include/gestures.h +index b512121..659c95a 100644 +--- a/include/gestures.h ++++ b/include/gestures.h +@@ -38,7 +38,7 @@ + + struct Gestures { + bitmask_t type, btmask, btdata; +- int same_fingers, dx, dy, scale, rot; ++ int same_fingers, posx, posy, dx, dy, scale, rot; + bitmask_t tapmask; + int ntap; + }; +diff --git a/src/gestures.c b/src/gestures.c +index cc95e9b..cbc5ac6 100644 +--- a/src/gestures.c ++++ b/src/gestures.c +@@ -82,7 +82,6 @@ static void extract_movement(struct Gestures *gs, struct MTouch* mt) + float move, xmove = 0, ymove = 0; + float rad, rad2 = 0, scale = 0, rot = 0; + +- + if (!nmove || nmove != npoint) + return; + +@@ -182,9 +181,15 @@ static void extract_movement(struct Gestures *gs, struct MTouch* mt) + void extract_gestures(struct Gestures *gs, struct MTouch* mt) + { + memset(gs, 0, sizeof(struct Gestures)); ++ ++ gs->posx = mt->state.finger[0].position_x; ++ gs->posy = mt->state.finger[0].position_y; ++ + gs->same_fingers = mt->mem.same; ++ + extract_buttons(gs, mt); + extract_movement(gs, mt); ++ + mt->prev_state = mt->state; + } + +@@ -201,6 +206,9 @@ void extract_delayed_gestures(struct Gestures *gs, struct MTouch* mt) + memset(gs, 0, sizeof(struct Gestures)); + mt->mem.wait = 0; + ++ gs->posx = mt->state.finger[0].position_x; ++ gs->posy = mt->state.finger[0].position_y; ++ + if (mt->mem.tpdown < mt->mem.tpup) { + switch (mt->mem.maxtap) { + case 1: +@@ -227,8 +235,10 @@ void output_gesture(const struct Gestures *gs) + foreach_bit(i, gs->btmask) + xf86Msg(X_INFO, "button bit: %d %d\n", + i, GETBIT(gs->btdata, i)); +- if (GETBIT(gs->type, GS_MOVE)) ++ if (GETBIT(gs->type, GS_MOVE)) { ++ xf86Msg(X_INFO, "position: %d %d\n", gs->posx, gs->posy); + xf86Msg(X_INFO, "motion: %d %d\n", gs->dx, gs->dy); ++ } + if (GETBIT(gs->type, GS_VSCROLL)) + xf86Msg(X_INFO, "vscroll: %d\n", gs->dy); + if (GETBIT(gs->type, GS_HSCROLL)) |