Skip to main content

Meta_PointerController

Module: Metanodes / Definitions

A PointerController casts a ray to collide with scene and gui objects. It is used to provide lasers on tracked controllers.

#include <meta_gui.hpp>

Public Types

TypeName
enumHand { Left, Right }
Values for Idx_Hand.
enumIDX { Idx_Enabled, Idx_Transform, Idx_Camera, Idx_ButtonSource, Idx_TouchSource, Idx_ShowCursor, Idx_ShowLaser, Idx_LaserSelectEnabled, Idx_Length, Idx_VisibleToAll, Idx_VisibleToSelf, Idx_DoubleClickDistanceTolerance, Idx_DoubleClickAngleTolerance, Idx_Hand, Idx_ActionMask }

Public Types Documentation

enum Hand

EnumeratorValueDescription
LeftSymbols - C: "LeftHand", Lua: __PointerController_LeftHand
RightSymbols - C: "RightHand", Lua: __PointerController_RightHand

Values for Idx_Hand.

enum IDX

EnumeratorValueDescription
Idx_Enabled
Idx_Transformbool - Enabled state of the controller and its raycast
Idx_Cameramat4w - Local transform (origin) of the pointer
Idx_ButtonSourcelink - Optionally specify a Meta_Camera which should be the only one that can see the pointer
Idx_TouchSourcelink - a Meta_TrackerInput providing tracker buttons. Button 0 acts as a "trigger" to click on whatever the pointer is pointing at
Idx_ShowCursorlink - a Meta_TrackerInput providing a touch pad tracker source
Idx_ShowLaserbool - Whether to show a cursor at the end of the laser
Idx_LaserSelectEnabledbool - Whether to show the red laser
Idx_Lengthbool - Whether the laser can select the 3D scene
Idx_VisibleToAllworld_float - The length of the ray, or zero if it should extend to the far clip plane
Idx_VisibleToSelfbool - Whether the laser is visible to all users in a collaboration
Idx_DoubleClickDistanceTolerancebool - Whether the laser is visible to the local user (you)
Idx_DoubleClickAngleTolerancefloat - The distance the laser is allowed to move between clicks before they count as separate clicks
Idx_Handfloat - The distance the laser is allowed to rotate between clicks before they count as separate clicks
Idx_ActionMaskHand (int) - Which hand should this be treated as? Button event codes are adjusted based on handedness.