2 * Copyright © 2014 Red Hat, Inc.
4 * Permission to use, copy, modify, distribute, and sell this software and
5 * its documentation for any purpose is hereby granted without fee, provided
6 * that the above copyright notice appear in all copies and that both that
7 * copyright notice and this permission notice appear in supporting
8 * documentation, and that the name of the copyright holders not be used in
9 * advertising or publicity pertaining to distribution of the software
10 * without specific, written prior permission. The copyright holders make
11 * no representations about the suitability of this software for any
12 * purpose. It is provided "as is" without express or implied warranty.
14 * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
15 * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
16 * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
17 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
18 * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
19 * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
20 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
24 #ifndef EVDEV_MT_TOUCHPAD_H
25 #define EVDEV_MT_TOUCHPAD_H
33 #define TOUCHPAD_HISTORY_LENGTH 4
34 #define TOUCHPAD_MIN_SAMPLES 4
37 TOUCHPAD_EVENT_NONE = 0,
38 TOUCHPAD_EVENT_MOTION = (1 << 0),
39 TOUCHPAD_EVENT_BUTTON_PRESS = (1 << 1),
40 TOUCHPAD_EVENT_BUTTON_RELEASE = (1 << 2),
51 BUTTON_EVENT_IN_BOTTOM_R = 30,
52 BUTTON_EVENT_IN_BOTTOM_L,
53 BUTTON_EVENT_IN_TOP_R,
54 BUTTON_EVENT_IN_TOP_M,
55 BUTTON_EVENT_IN_TOP_L,
69 BUTTON_STATE_TOP_TO_IGNORE,
79 TAP_STATE_TOUCH_2_HOLD,
81 TAP_STATE_TOUCH_3_HOLD,
82 TAP_STATE_DRAGGING_OR_DOUBLETAP,
84 TAP_STATE_DRAGGING_WAIT,
86 TAP_STATE_DEAD, /**< finger count exceeded */
89 enum tp_tap_touch_state {
90 TAP_TOUCH_STATE_IDLE = 16, /**< not in touch */
91 TAP_TOUCH_STATE_TOUCH, /**< touching, may tap */
92 TAP_TOUCH_STATE_DEAD, /**< exceeded motion/timeout */
101 struct tp_dispatch *tp;
102 enum touch_state state;
104 bool fake; /* a fake touch */
105 bool is_pointer; /* the pointer-controlling touch */
111 struct tp_motion samples[TOUCHPAD_HISTORY_LENGTH];
121 /* A pinned touchpoint is the one that pressed the physical button
122 * on a clickpad. After the release, it won't move until the center
123 * moves more than a threshold away from the original coordinates
131 /* Software-button state and timeout if applicable */
133 enum button_state state;
134 /* We use button_event here so we can use == on events */
135 enum button_event curr;
136 struct libinput_timer timer;
140 enum tp_tap_touch_state state;
145 int32_t x, y; /* first coordinates if is_palm == true */
146 uint32_t time; /* first timestamp if is_palm == true */
151 struct evdev_dispatch base;
152 struct evdev_device *device;
153 unsigned int nfingers_down; /* number of fingers down */
154 unsigned int slot; /* current slot */
157 unsigned int ntouches; /* number of slots */
158 struct tp_touch *touches; /* len == ntouches */
159 unsigned int fake_touches; /* fake touch mask */
166 struct motion_filter *filter;
169 double x_scale_coeff;
170 double y_scale_coeff;
174 bool is_clickpad; /* true for clickpads */
176 bool use_clickfinger; /* number of fingers decides button number */
180 uint32_t motion_dist; /* for pinned touches */
181 unsigned int active; /* currently active button, for release event */
183 /* Only used for clickpads. The software button areas are
184 * always 2 horizontal stripes across the touchpad.
185 * The buttons are split according to the edge settings.
189 int32_t rightbutton_left_edge;
194 int32_t rightbutton_left_edge;
195 int32_t leftbutton_right_edge;
197 } buttons; /* physical buttons */
200 enum libinput_pointer_axis direction;
203 enum touchpad_event queued;
206 struct libinput_device_config_tap config;
208 struct libinput_timer timer;
209 enum tp_tap_state state;
218 #define tp_for_each_touch(_tp, _t) \
219 for (unsigned int _i = 0; _i < (_tp)->ntouches && (_t = &(_tp)->touches[_i]); _i++)
222 tp_get_delta(struct tp_touch *t, double *dx, double *dy);
225 tp_set_pointer(struct tp_dispatch *tp, struct tp_touch *t);
228 tp_tap_handle_state(struct tp_dispatch *tp, uint64_t time);
231 tp_init_tap(struct tp_dispatch *tp);
234 tp_destroy_tap(struct tp_dispatch *tp);
237 tp_init_buttons(struct tp_dispatch *tp, struct evdev_device *device);
240 tp_destroy_buttons(struct tp_dispatch *tp);
243 tp_process_button(struct tp_dispatch *tp,
244 const struct input_event *e,
248 tp_post_button_events(struct tp_dispatch *tp, uint64_t time);
251 tp_button_handle_state(struct tp_dispatch *tp, uint64_t time);
254 tp_button_touch_active(struct tp_dispatch *tp, struct tp_touch *t);
257 tp_button_is_inside_softbutton_area(struct tp_dispatch *tp, struct tp_touch *t);