Date: Thu, 19 Jul 2012 18:02:59 GMT From: Brooks Davis <brooks@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 214614 for review Message-ID: <201207191802.q6JI2xx9086862@skunkworks.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://p4web.freebsd.org/@@214614?ac=10 Change 214614 by brooks@brooks_ecr_current on 2012/07/19 18:02:40 Improve the quality of touch screen events by ignoring release events which are not followed by invalid (no-contact) readings on the next cycle. Also manufacture release events in the event that we start a ts_poll, get a no-contact reading the first time, and the previous event returned was a contact event. Convert pictview_pan() to use ts_poll.. Affected files ... .. //depot/projects/ctsrd/beribsd/src/ctsrd-lib/libde4tc/de4tc.c#11 edit Differences ... ==== //depot/projects/ctsrd/beribsd/src/ctsrd-lib/libde4tc/de4tc.c#11 (text+ko) ==== @@ -153,9 +153,10 @@ ts_poll(void) { struct timespec stime = {0, 1000000}; - static struct tsstate *sp; - int init = 0; - struct tsstate tmp_s; + static struct tsstate *sp = NULL; + int init = 0, first_pass = 1; + int check_release = 0; + struct tsstate tmp_s, rel_s; if (sp == NULL) { sp = malloc(sizeof(struct tsstate)); @@ -171,6 +172,22 @@ tmp_s.ts_y2 = le32toh(mtlctrl[6]); tmp_s.ts_gesture = le32toh(mtlctrl[7]); if (tmp_s.ts_gesture < 0) { + if (check_release) { + check_release = 0; + *sp = rel_s; + return (sp); + } + if (first_pass && !init && sp->ts_count > 0) { + /* + * If we returned a touch last time around + * then fake up a release now. + * XXX: we should probably have a timelimit + */ + sp->ts_count = 0; + sp->ts_gesture = 0; + return(sp); + } + first_pass = 0; nanosleep(&stime, NULL); continue; } @@ -182,9 +199,19 @@ tmp_s.ts_x2 != sp->ts_x2 || tmp_s.ts_y2 != sp->ts_y2 || tmp_s.ts_count != sp->ts_count || tmp_s.ts_gesture != sp->ts_gesture) { - *sp = tmp_s; - return (sp); + /* + * If we get an release event, differ returning + * it until we sleep and get a non-event. + */ + if (tmp_s.ts_count == 0) { + check_release = 1; + rel_s = tmp_s; + } else { + *sp = tmp_s; + return (sp); + } } + first_pass = 0; nanosleep(&stime, NULL); } }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201207191802.q6JI2xx9086862>