Files
react-native/ReactCommon/react/renderer/components/view/PointerEvent.h
T
Vincent Riemer 966f800b7c Add key modifier properties to the PointerEvent interface
Summary:
Changelog: [iOS][Internal] - Add key modifier properties to the PointerEvent interface

This diff adds implementations of the `ctrlKey`, `shiftKey`, `altKey`, and `metaKey` properties on the PointerEvent interface for iOS.

Reviewed By: lunaleaps

Differential Revision: D37869377

fbshipit-source-id: b187bae93fbfc97b6ca1d8d9786ad85343484b3d
2022-07-18 14:12:25 -07:00

116 lines
3.1 KiB
C++
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#pragma once
#include <react/renderer/core/ReactPrimitives.h>
#include <react/renderer/debug/DebugStringConvertible.h>
#include <react/renderer/graphics/Geometry.h>
namespace facebook {
namespace react {
struct PointerEvent {
/*
* A unique identifier for the pointer causing the event.
*/
int pointerId;
/*
* The normalized pressure of the pointer input in the range 0 to 1, where 0
* and 1 represent the minimum and maximum pressure the hardware is capable of
* detecting, respectively.
*/
Float pressure;
/*
* Indicates the device type that caused the event (mouse, pen, touch, etc.)
*/
std::string pointerType;
/*
* Point within the application's viewport at which the event occurred (as
* opposed to the coordinate within the page).
*/
Point clientPoint;
/*
* The X/Y coordinate of the pointer in global (screen) coordinates.
*/
Point screenPoint;
/*
* The X/Y coordinate of the pointer relative to the position of the padding
* edge of the target node.
*/
Point offsetPoint;
/*
* The width (magnitude on the X axis), in CSS pixels, of the contact geometry
* of the pointer
*/
Float width;
/*
* The height (magnitude on the y axis), in CSS pixels, of the contact
* geometry of the pointer
*/
Float height;
/*
* The plane angle (in degrees, in the range of -90 to 90) between the YZ
* plane and the plane containing both the pointer (e.g. pen stylus) axis and
* the Y axis.
*/
int tiltX;
/*
* The plane angle (in degrees, in the range of -90 to 90) between the XZ
* plane and the plane containing both the pointer (e.g. pen stylus) axis and
* the X axis.
*/
int tiltY;
/*
* Returns a long with details about the event, depending on the event type.
*/
int detail;
/*
* The buttons being depressed (if any) when the mouse event was fired.
*/
int buttons;
/*
* The normalized tangential pressure of the pointer input (also known as
* barrel pressure or cylinder stress) in the range -1 to 1, where 0 is the
* neutral position of the control.
*/
Float tangentialPressure;
/*
* The clockwise rotation of the pointer (e.g. pen stylus) around its major
* axis in degrees, with a value in the range 0 to 359.
*/
int twist;
/*
* Returns true if the control key was down when the event was fired.
*/
bool ctrlKey;
/*
* Returns true if the shift key was down when the event was fired.
*/
bool shiftKey;
/*
* Returns true if the alt key was down when the event was fired.
*/
bool altKey;
/*
* Returns true if the meta key was down when the event was fired.
*/
bool metaKey;
};
#if RN_DEBUG_STRING_CONVERTIBLE
std::string getDebugName(PointerEvent const &pointerEvent);
std::vector<DebugStringConvertibleObject> getDebugProps(
PointerEvent const &pointerEvent,
DebugStringConvertibleOptions options);
#endif
} // namespace react
} // namespace facebook