blob: 69651841d01209afba262f677c48473801b7468f [file] [log] [blame]
[email protected]5481eb7b2012-02-14 19:11:261// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]493d14212011-07-07 15:38:482// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef PPAPI_CPP_INPUT_EVENT_H_
6#define PPAPI_CPP_INPUT_EVENT_H_
7
[email protected]aa0c8652011-07-19 19:33:558#include <string>
[email protected]79cad342013-08-01 00:22:489#include <vector>
[email protected]aa0c8652011-07-19 19:33:5510
[email protected]493d14212011-07-07 15:38:4811#include "ppapi/c/ppb_input_event.h"
12#include "ppapi/cpp/resource.h"
[email protected]cdf4e912012-06-21 23:15:1013#include "ppapi/cpp/touch_point.h"
[email protected]493d14212011-07-07 15:38:4814
[email protected]63e627d2011-08-16 19:15:3115/// @file
16/// This file defines the API used to handle mouse and keyboard input events.
17
[email protected]493d14212011-07-07 15:38:4818namespace pp {
19
20class FloatPoint;
[email protected]09af0f72012-02-27 20:23:1921class InstanceHandle;
[email protected]493d14212011-07-07 15:38:4822class Point;
23class Var;
24
[email protected]63e627d2011-08-16 19:15:3125/// This class represents an input event resource. Normally you will get passed
26/// this object through the HandleInputEvent() function on the
27/// <code>Instance</code> object.
[email protected]493d14212011-07-07 15:38:4828///
29/// Typically you would check the type of the event and then create the
30/// appropriate event-specific object to query the properties.
31///
[email protected]63e627d2011-08-16 19:15:3132/// <strong>Example:</strong>
[email protected]febbb9c2013-04-09 18:40:1733/// @code
[email protected]63e627d2011-08-16 19:15:3134///
[email protected]493d14212011-07-07 15:38:4835/// bool MyInstance::HandleInputEvent(const pp::InputEvent& event) {
36/// switch (event.GetType()) {
[email protected]d8f4fba2013-06-26 23:38:1037/// case PP_INPUTEVENT_TYPE_MOUSEDOWN {
[email protected]493d14212011-07-07 15:38:4838/// pp::MouseInputEvent mouse_event(event);
39/// return HandleMouseDown(mouse_event.GetMousePosition());
40/// }
41/// default:
42/// return false;
43/// }
[email protected]63e627d2011-08-16 19:15:3144///
[email protected]febbb9c2013-04-09 18:40:1745/// @endcode
[email protected]493d14212011-07-07 15:38:4846class InputEvent : public Resource {
47 public:
48 /// Default constructor that creates an is_null() InputEvent object.
49 InputEvent();
50
[email protected]63e627d2011-08-16 19:15:3151 /// This constructor constructs an input event from the provided input event
52 /// resource ID. The InputEvent object will be is_null() if the given
53 /// resource is not a valid input event.
54 ///
55 /// @param[in] input_event_resource A input event resource ID.
[email protected]493d14212011-07-07 15:38:4856 explicit InputEvent(PP_Resource input_event_resource);
57
58 ~InputEvent();
59
[email protected]63e627d2011-08-16 19:15:3160 /// GetType() returns the type of input event for this input event
61 /// object.
62 ///
63 /// @return A <code>PP_InputEvent_Type</code> if successful,
64 /// PP_INPUTEVENT_TYPE_UNDEFINED if the resource is invalid.
[email protected]493d14212011-07-07 15:38:4865 PP_InputEvent_Type GetType() const;
66
[email protected]63e627d2011-08-16 19:15:3167 /// GetTimeStamp() returns the time that the event was generated. The time
68 /// will be before the current time since processing and dispatching the
69 /// event has some overhead. Use this value to compare the times the user
70 /// generated two events without being sensitive to variable processing time.
[email protected]493d14212011-07-07 15:38:4871 ///
72 /// The return value is in time ticks, which is a monotonically increasing
73 /// clock not related to the wall clock time. It will not change if the user
74 /// changes their clock or daylight savings time starts, so can be reliably
75 /// used to compare events. This means, however, that you can't correlate
76 /// event times to a particular time of day on the system clock.
[email protected]63e627d2011-08-16 19:15:3177 ///
78 /// @return A <code>PP_TimeTicks</code> containing the time the event was
79 /// generated.
[email protected]493d14212011-07-07 15:38:4880 PP_TimeTicks GetTimeStamp() const;
81
[email protected]63e627d2011-08-16 19:15:3182 /// GetModifiers() returns a bitfield indicating which modifiers were down
83 /// at the time of the event. This is a combination of the flags in the
84 /// <code>PP_InputEvent_Modifier</code> enum.
[email protected]493d14212011-07-07 15:38:4885 ///
86 /// @return The modifiers associated with the event, or 0 if the given
87 /// resource is not a valid event resource.
88 uint32_t GetModifiers() const;
89};
90
[email protected]63e627d2011-08-16 19:15:3191/// This class handles mouse events.
[email protected]493d14212011-07-07 15:38:4892class MouseInputEvent : public InputEvent {
93 public:
94 /// Constructs an is_null() mouse input event object.
95 MouseInputEvent();
96
[email protected]63e627d2011-08-16 19:15:3197 /// This constructor constructs a mouse input event object from the provided
98 /// generic input event. If the given event is itself is_null() or is not
99 /// a mouse input event, the mouse object will be is_null().
100 ///
101 /// @param event An <code>InputEvent</code>.
[email protected]493d14212011-07-07 15:38:48102 explicit MouseInputEvent(const InputEvent& event);
103
[email protected]63e627d2011-08-16 19:15:31104 /// This constructor manually constructs a mouse event from the provided
105 /// parameters.
106 ///
[email protected]935d00fd2013-03-29 22:26:15107 /// @param[in] instance The instance for which this event occurred.
[email protected]63e627d2011-08-16 19:15:31108 ///
109 /// @param[in] type A <code>PP_InputEvent_Type</code> identifying the type of
110 /// input event.
111 ///
112 /// @param[in] time_stamp A <code>PP_TimeTicks</code> indicating the time
[email protected]935d00fd2013-03-29 22:26:15113 /// when the event occurred.
[email protected]63e627d2011-08-16 19:15:31114 ///
115 /// @param[in] modifiers A bit field combination of the
116 /// <code>PP_InputEvent_Modifier</code> flags.
117 ///
118 /// @param[in] mouse_button The button that changed for mouse down or up
119 /// events. This value will be <code>PP_EVENT_MOUSEBUTTON_NONE</code> for
120 /// mouse move, enter, and leave events.
121 ///
122 /// @param[in] mouse_position A <code>Point</code> containing the x and y
[email protected]935d00fd2013-03-29 22:26:15123 /// position of the mouse when the event occurred.
[email protected]63e627d2011-08-16 19:15:31124 ///
125 /// @param[in] click_count
[email protected]f1a0afd2012-02-16 19:33:07126 // TODO(brettw) figure out exactly what this means.
[email protected]63e627d2011-08-16 19:15:31127 ///
[email protected]80473262011-08-31 17:15:18128 /// @param[in] mouse_movement The change in position of the mouse.
[email protected]09af0f72012-02-27 20:23:19129 MouseInputEvent(const InstanceHandle& instance,
[email protected]aa0c8652011-07-19 19:33:55130 PP_InputEvent_Type type,
131 PP_TimeTicks time_stamp,
132 uint32_t modifiers,
133 PP_InputEvent_MouseButton mouse_button,
134 const Point& mouse_position,
[email protected]80473262011-08-31 17:15:18135 int32_t click_count,
136 const Point& mouse_movement);
[email protected]aa0c8652011-07-19 19:33:55137
[email protected]63e627d2011-08-16 19:15:31138 /// GetButton() returns the mouse position for a mouse input event.
[email protected]493d14212011-07-07 15:38:48139 ///
140 /// @return The mouse button associated with mouse down and up events. This
141 /// value will be PP_EVENT_MOUSEBUTTON_NONE for mouse move, enter, and leave
142 /// events, and for all non-mouse events.
[email protected]d912c6982011-07-20 22:04:32143 PP_InputEvent_MouseButton GetButton() const;
[email protected]493d14212011-07-07 15:38:48144
[email protected]80473262011-08-31 17:15:18145 /// GetPosition() returns the pixel location of a mouse input event. When
146 /// the mouse is locked, it returns the last known mouse position just as
147 /// mouse lock was entered.
[email protected]493d14212011-07-07 15:38:48148 ///
149 /// @return The point associated with the mouse event, relative to the upper-
150 /// left of the instance receiving the event. These values can be negative for
151 /// mouse drags. The return value will be (0, 0) for non-mouse events.
[email protected]d912c6982011-07-20 22:04:32152 Point GetPosition() const;
[email protected]493d14212011-07-07 15:38:48153
154 // TODO(brettw) figure out exactly what this means.
[email protected]d912c6982011-07-20 22:04:32155 int32_t GetClickCount() const;
[email protected]80473262011-08-31 17:15:18156
157 /// Returns the change in position of the mouse. When the mouse is locked,
158 /// although the mouse position doesn't actually change, this function
159 /// still provides movement information, which indicates what the change in
160 /// position would be had the mouse not been locked.
161 ///
162 /// @return The change in position of the mouse, relative to the previous
163 /// position.
164 Point GetMovement() const;
[email protected]493d14212011-07-07 15:38:48165};
166
167class WheelInputEvent : public InputEvent {
168 public:
169 /// Constructs an is_null() wheel input event object.
170 WheelInputEvent();
171
[email protected]63e627d2011-08-16 19:15:31172 /// This constructor constructs a wheel input event object from the
173 /// provided generic input event. If the given event is itself
174 /// is_null() or is not a wheel input event, the wheel object will be
175 /// is_null().
176 ///
[email protected]0325ee32011-11-10 18:35:10177 /// @param[in] event A generic input event.
[email protected]493d14212011-07-07 15:38:48178 explicit WheelInputEvent(const InputEvent& event);
179
[email protected]aa0c8652011-07-19 19:33:55180 /// Constructs a wheel input even from the given parameters.
[email protected]63e627d2011-08-16 19:15:31181 ///
[email protected]935d00fd2013-03-29 22:26:15182 /// @param[in] instance The instance for which this event occurred.
[email protected]63e627d2011-08-16 19:15:31183 ///
184 /// @param[in] time_stamp A <code>PP_TimeTicks</code> indicating the time
[email protected]935d00fd2013-03-29 22:26:15185 /// when the event occurred.
[email protected]63e627d2011-08-16 19:15:31186 ///
187 /// @param[in] modifiers A bit field combination of the
188 /// <code>PP_InputEvent_Modifier</code> flags.
189 ///
190 /// @param[in] wheel_delta The scroll wheel's horizontal and vertical scroll
191 /// amounts.
192 ///
193 /// @param[in] wheel_ticks The number of "clicks" of the scroll wheel that
194 /// have produced the event.
195 ///
196 /// @param[in] scroll_by_page When true, the user is requesting to scroll
197 /// by pages. When false, the user is requesting to scroll by lines.
[email protected]09af0f72012-02-27 20:23:19198 WheelInputEvent(const InstanceHandle& instance,
[email protected]aa0c8652011-07-19 19:33:55199 PP_TimeTicks time_stamp,
200 uint32_t modifiers,
201 const FloatPoint& wheel_delta,
202 const FloatPoint& wheel_ticks,
203 bool scroll_by_page);
204
[email protected]63e627d2011-08-16 19:15:31205 /// GetDelta() returns the amount vertically and horizontally the user has
206 /// requested to scroll by with their mouse wheel. A scroll down or to the
207 /// right (where the content moves up or left) is represented as positive
208 /// values, and a scroll up or to the left (where the content moves down or
209 /// right) is represented as negative values.
[email protected]493d14212011-07-07 15:38:48210 ///
211 /// This amount is system dependent and will take into account the user's
212 /// preferred scroll sensitivity and potentially also nonlinear acceleration
213 /// based on the speed of the scrolling.
214 ///
215 /// Devices will be of varying resolution. Some mice with large detents will
216 /// only generate integer scroll amounts. But fractional values are also
217 /// possible, for example, on some trackpads and newer mice that don't have
218 /// "clicks".
[email protected]63e627d2011-08-16 19:15:31219 ///
[email protected]935d00fd2013-03-29 22:26:15220 /// @return The vertical and horizontal scroll values. The units are either in
[email protected]63e627d2011-08-16 19:15:31221 /// pixels (when scroll_by_page is false) or pages (when scroll_by_page is
222 /// true). For example, y = -3 means scroll up 3 pixels when scroll_by_page
223 /// is false, and scroll up 3 pages when scroll_by_page is true.
[email protected]d912c6982011-07-20 22:04:32224 FloatPoint GetDelta() const;
[email protected]493d14212011-07-07 15:38:48225
[email protected]63e627d2011-08-16 19:15:31226 /// GetTicks() returns the number of "clicks" of the scroll wheel
227 /// that have produced the event. The value may have system-specific
228 /// acceleration applied to it, depending on the device. The positive and
229 /// negative meanings are the same as for GetDelta().
[email protected]493d14212011-07-07 15:38:48230 ///
231 /// If you are scrolling, you probably want to use the delta values. These
232 /// tick events can be useful if you aren't doing actual scrolling and don't
233 /// want or pixel values. An example may be cycling between different items in
234 /// a game.
235 ///
[email protected]63e627d2011-08-16 19:15:31236 /// @return The number of "clicks" of the scroll wheel. You may receive
237 /// fractional values for the wheel ticks if the mouse wheel is high
238 /// resolution or doesn't have "clicks". If your program wants discrete
239 /// events (as in the "picking items" example) you should accumulate
[email protected]493d14212011-07-07 15:38:48240 /// fractional click values from multiple messages until the total value
241 /// reaches positive or negative one. This should represent a similar amount
242 /// of scrolling as for a mouse that has a discrete mouse wheel.
[email protected]d912c6982011-07-20 22:04:32243 FloatPoint GetTicks() const;
[email protected]493d14212011-07-07 15:38:48244
[email protected]63e627d2011-08-16 19:15:31245 /// GetScrollByPage() indicates if the scroll delta x/y indicates pages or
246 /// lines to scroll by.
247 ///
248 /// @return true if the event is a wheel event and the user is scrolling
249 /// by pages, false if not or if the resource is not a wheel event.
[email protected]493d14212011-07-07 15:38:48250 bool GetScrollByPage() const;
251};
252
253class KeyboardInputEvent : public InputEvent {
254 public:
255 /// Constructs an is_null() keyboard input event object.
256 KeyboardInputEvent();
257
[email protected]63e627d2011-08-16 19:15:31258 /// Constructs a keyboard input event object from the provided generic input
[email protected]493d14212011-07-07 15:38:48259 /// event. If the given event is itself is_null() or is not a keyboard input
260 /// event, the keybaord object will be is_null().
[email protected]63e627d2011-08-16 19:15:31261 ///
262 /// @param[in] event A generic input event.
[email protected]493d14212011-07-07 15:38:48263 explicit KeyboardInputEvent(const InputEvent& event);
264
[email protected]aa0c8652011-07-19 19:33:55265 /// Constructs a keyboard input even from the given parameters.
[email protected]63e627d2011-08-16 19:15:31266 ///
[email protected]935d00fd2013-03-29 22:26:15267 /// @param[in] instance The instance for which this event occurred.
[email protected]63e627d2011-08-16 19:15:31268 ///
269 /// @param[in] type A <code>PP_InputEvent_Type</code> identifying the type of
270 /// input event.
271 ///
272 /// @param[in] time_stamp A <code>PP_TimeTicks</code> indicating the time
[email protected]935d00fd2013-03-29 22:26:15273 /// when the event occurred.
[email protected]63e627d2011-08-16 19:15:31274 ///
275 /// @param[in] modifiers A bit field combination of the
276 /// <code>PP_InputEvent_Modifier</code> flags.
277 ///
278 /// @param[in] key_code This value reflects the DOM KeyboardEvent
279 /// <code>keyCode</code> field. Chrome populates this with the Windows-style
280 /// Virtual Key code of the key.
281 ///
282 /// @param[in] character_text This value represents the typed character as a
283 /// UTF-8 string.
[email protected]09af0f72012-02-27 20:23:19284 KeyboardInputEvent(const InstanceHandle& instance,
[email protected]aa0c8652011-07-19 19:33:55285 PP_InputEvent_Type type,
286 PP_TimeTicks time_stamp,
287 uint32_t modifiers,
288 uint32_t key_code,
289 const Var& character_text);
290
[email protected]63e627d2011-08-16 19:15:31291 /// Returns the DOM keyCode field for the keyboard event.
[email protected]493d14212011-07-07 15:38:48292 /// Chrome populates this with the Windows-style Virtual Key code of the key.
293 uint32_t GetKeyCode() const;
294
295 /// Returns the typed character for the given character event.
296 ///
297 /// @return A string var representing a single typed character for character
298 /// input events. For non-character input events the return value will be an
299 /// undefined var.
300 Var GetCharacterText() const;
301};
302
[email protected]cdf4e912012-06-21 23:15:10303class TouchInputEvent : public InputEvent {
304 public:
305 /// Constructs an is_null() touch input event object.
306 TouchInputEvent();
307
308 /// Constructs a touch input event object from the given generic input event.
309 /// If the given event is itself is_null() or is not a touch input event, the
310 /// touch object will be is_null().
311 explicit TouchInputEvent(const InputEvent& event);
312
313 /// Constructs a touch input even from the given parameters.
314 ///
[email protected]935d00fd2013-03-29 22:26:15315 /// @param[in] instance The instance for which this event occurred.
[email protected]cdf4e912012-06-21 23:15:10316 ///
317 /// @param[in] type A <code>PP_InputEvent_Type</code> identifying the type of
318 /// input event.
319 ///
320 /// @param[in] time_stamp A <code>PP_TimeTicks</code> indicating the time
[email protected]935d00fd2013-03-29 22:26:15321 /// when the event occurred.
[email protected]cdf4e912012-06-21 23:15:10322 ///
323 /// @param[in] modifiers A bit field combination of the
324 /// <code>PP_InputEvent_Modifier</code> flags.
325 TouchInputEvent(const InstanceHandle& instance,
326 PP_InputEvent_Type type,
327 PP_TimeTicks time_stamp,
328 uint32_t modifiers);
329
330 /// Adds the touch-point to the specified TouchList.
331 void AddTouchPoint(PP_TouchListType list, PP_TouchPoint point);
332
333 /// @return The number of TouchPoints in this TouchList.
334 uint32_t GetTouchCount(PP_TouchListType list) const;
335
336 /// @return The TouchPoint at the given index of the given list, or an empty
337 /// TouchPoint if the index is out of range.
338 TouchPoint GetTouchByIndex(PP_TouchListType list, uint32_t index) const;
339
340 /// @return The TouchPoint in the given list with the given identifier, or an
341 /// empty TouchPoint if the list does not contain a TouchPoint with that
342 /// identifier.
343 TouchPoint GetTouchById(PP_TouchListType list, uint32_t id) const;
344};
345
[email protected]79cad342013-08-01 00:22:48346class IMEInputEvent : public InputEvent {
347 public:
348 /// Constructs an is_null() IME input event object.
349 IMEInputEvent();
[email protected]cdf4e912012-06-21 23:15:10350
[email protected]79cad342013-08-01 00:22:48351 /// Constructs an IME input event object from the provided generic input
352 /// event. If the given event is itself is_null() or is not an IME input
353 /// event, the object will be is_null().
354 ///
355 /// @param[in] event A generic input event.
356 explicit IMEInputEvent(const InputEvent& event);
357
358 /// This constructor manually constructs an IME event from the provided
359 /// parameters.
360 ///
361 /// @param[in] instance The instance for which this event occurred.
362 ///
363 /// @param[in] type A <code>PP_InputEvent_Type</code> identifying the type of
364 /// input event. The type must be one of the ime event types.
365 ///
366 /// @param[in] time_stamp A <code>PP_TimeTicks</code> indicating the time
367 /// when the event occurred.
368 ///
369 /// @param[in] text The string returned by <code>GetText</code>.
370 ///
371 /// @param[in] segment_offsets The array of numbers returned by
372 /// <code>GetSegmentOffset</code>.
373 ///
374 /// @param[in] target_segment The number returned by
375 /// <code>GetTargetSegment</code>.
376 ///
377 /// @param[in] selection The range returned by <code>GetSelection</code>.
378 IMEInputEvent(const InstanceHandle& instance,
379 PP_InputEvent_Type type,
380 PP_TimeTicks time_stamp,
381 const Var& text,
382 const std::vector<uint32_t>& segment_offsets,
383 int32_t target_segment,
384 const std::pair<uint32_t, uint32_t>& selection);
385
386 /// Returns the composition text as a UTF-8 string for the given IME event.
387 ///
388 /// @return A string var representing the composition text. For non-IME
389 /// input events the return value will be an undefined var.
390 Var GetText() const;
391
392 /// Returns the number of segments in the composition text.
393 ///
394 /// @return The number of segments. For events other than COMPOSITION_UPDATE,
395 /// returns 0.
396 uint32_t GetSegmentNumber() const;
397
398 /// Returns the position of the index-th segmentation point in the composition
399 /// text. The position is given by a byte-offset (not a character-offset) of
400 /// the string returned by GetText(). It always satisfies
401 /// 0=GetSegmentOffset(0) < ... < GetSegmentOffset(i) < GetSegmentOffset(i+1)
402 /// < ... < GetSegmentOffset(GetSegmentNumber())=(byte-length of GetText()).
403 /// Note that [GetSegmentOffset(i), GetSegmentOffset(i+1)) represents the
404 /// range of the i-th segment, and hence GetSegmentNumber() can be a valid
405 /// argument to this function instead of an off-by-1 error.
406 ///
407 /// @param[in] ime_event A <code>PP_Resource</code> corresponding to an IME
408 /// event.
409 ///
410 /// @param[in] index An integer indicating a segment.
411 ///
412 /// @return The byte-offset of the segmentation point. If the event is not
413 /// COMPOSITION_UPDATE or index is out of range, returns 0.
414 uint32_t GetSegmentOffset(uint32_t index) const;
415
416 /// Returns the index of the current target segment of composition.
417 ///
418 /// @return An integer indicating the index of the target segment. When there
419 /// is no active target segment, or the event is not COMPOSITION_UPDATE,
420 /// returns -1.
421 int32_t GetTargetSegment() const;
422
423 /// Obtains the range selected by caret in the composition text.
424 ///
425 /// @param[out] start An integer indicating a start offset of selection range.
426 ///
427 /// @param[out] end An integer indicating an end offset of selection range.
428 void GetSelection(uint32_t* start, uint32_t* end) const;
429};
[email protected]493d14212011-07-07 15:38:48430} // namespace pp
431
432#endif // PPAPI_CPP_INPUT_EVENT_H_