amis-rpc-design/node_modules/react-native/ReactCommon/react/renderer/components/view/PointerEvent.h
2023-10-07 19:42:30 +08:00

126 lines
3.3 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/Point.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;
/*
* Indicates if the pointer represents the primary pointer of this pointer
* type.
*/
bool isPrimary;
/*
* The button number that was pressed (if applicable) when the pointer event
* was fired.
*/
int button;
};
#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