Controller Buttons¶
Introduction¶
VIVE Wave™ supports buttons listed below:
- Menu
- Grip
- DPad Left
- DPad Up
- DPad Right
- DPad Down
- Volume Up
- Volume Down
- A
- B
- X
- Y
- Touchpad
- Trigger
- Thumbstick (Joystick)
- Parking
Note
We recommend to use the API
bool UWaveVRBlueprintFunctionLibrary::IsButtonAvailable
to check if a button is available.
Get Button State¶
Blueprint¶
In Blueprint, there are APIs can be used to get buttons’ press / touch states.
The buttons are define in WaveVRBlueprintFunctionLibrary.h
UENUM(BlueprintType)
enum class EWVR_InputId : uint8
{
NoUse = 0, //WVR_InputId::WVR_InputId_Alias1_System,
Menu = 1, //WVR_InputId::WVR_InputId_Alias1_Menu,
Grip = 2, //WVR_InputId::WVR_InputId_Alias1_Grip,
DPad_Left = 3, //WVR_InputId::WVR_InputId_Alias1_DPad_Left,
DPad_Up = 4, //WVR_InputId::WVR_InputId_Alias1_DPad_Up,
DPad_Right = 5, //WVR_InputId::WVR_InputId_Alias1_DPad_Right,
DPad_Down = 6, //WVR_InputId::WVR_InputId_Alias1_DPad_Down,
Volume_Up = 7, //WVR_InputId::WVR_InputId_Alias1_Volume_Up,
Volume_Down = 8, //WVR_InputId::WVR_InputId_Alias1_Volume_Down,
Bumper = 9, //WVR_InputId::WVR_InputId_Alias1_Bumper,
A = 10, //WVR_InputId::WVR_InputId_Alias1_A,
B = 11, //WVR_InputId::WVR_InputId_Alias1_B,
X = 12, //WVR_InputId::WVR_InputId_Alias1_X,
Y = 13, //WVR_InputId::WVR_InputId_Alias1_Y,
Back = 14, //WVR_InputId::WVR_InputId_Alias1_Back,
Enter = 15, //WVR_InputId::WVR_InputId_Alias1_Enter,
Touchpad = 16, //WVR_InputId::WVR_InputId_Alias1_Touchpad,
Trigger = 17, //WVR_InputId::WVR_InputId_Alias1_Trigger,
Thumbstick = 18, //WVR_InputId::WVR_InputId_Alias1_Thumbstick,
UENUM(BlueprintType)
enum class EWVR_TouchId : uint8
{
NoUse = 0, //WVR_InputId::WVR_InputId_Alias1_System,
Touchpad = 16, //WVR_InputId::WVR_InputId_Alias1_Touchpad,
Trigger = 17, //WVR_InputId::WVR_InputId_Alias1_Trigger,
Thumbstick = 18, //WVR_InputId::WVR_InputId_Alias1_Thumbstick,
Parking = 19, //WVR_InputId::WVR_InputId_Alias1_Parking
Right-click on the Blueprint Event Graph and type WaveVR to see APIs under subtitle:
- Input
data:image/s3,"s3://crabby-images/63fab/63fabd6b02aa0b4d1c7bd0d16a8b4e30487c141f" alt="../_images/Unreal_WaveVR_Input_BlueprintFunctionLibrary1.png"
The API IsInputButtonPressed
, IsInputButtonTouched
and GetInputButtonAxis
of subtitle Input support left-handed mode.
data:image/s3,"s3://crabby-images/8c1c5/8c1c5ddaf2fb40d229a4f5be7d33d94eb38f6114" alt="../_images/UnrealControllerButtons_IsInputButtonPressed.png"
data:image/s3,"s3://crabby-images/24d10/24d10ba8b997405883804df58ee2254d920ce227" alt="../_images/UnrealControllerButtons_IsInputButtonTouched.png"
You can see the available Button Id
(NOT include Home/System/Power).
C++¶
In C++, you can use the sample code below to get the button_id
state of specified device
.
bool UWaveVRInputFunctionLibrary::IsInputButtonPressed(EWVR_DeviceType device, EWVR_InputId button_id)
bool UWaveVRInputFunctionLibrary::IsInputButtonTouched(EWVR_DeviceType device, EWVR_TouchId button_id)
FVector2D UWaveVRInputFunctionLibrary::GetInputButtonAxis(EWVR_DeviceType device, EWVR_TouchId button_id)
Unreal Input Plugin¶
Unreal provides the Engine Input .
In Settings -> Project Settings -> Engine/Input, you can define the Action & Axis Mapping via the Wave category to use the VIVE Wave™ Plugin buttons.
data:image/s3,"s3://crabby-images/13598/135983632d4f1b7f2a2379bca934cf4b63bd30b5" alt="../_images/Unreal_WaveVR_Input.png"
In C++ code (e.g. Pawn), you can listen to button’s state in SetupPlayerInputComponent
:
PlayerInputComponent->BindAction(<your defined action mapping>, IE_Pressed, this, <your function reference>);
PlayerInputComponent->BindAction(<your defined action mapping>, IE_Released, this, <your function reference>);
In Blueprint, you should Enable Input:
data:image/s3,"s3://crabby-images/b451e/b451e2595d350fb4c6e3982f1f16358fbcdec977" alt="../_images/Unreal_WaveVR_EnableInput.png"
Add key(s) by right-click on the Blueprint Event Graph -> type Input Action Events
data:image/s3,"s3://crabby-images/5a2a5/5a2a5323110e413bc629e2bc28428887a4125fc5" alt="../_images/Unreal_WaveVR_InputAction.png"