-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
SteamVR Input (IVRInput/IVRDriverInput): * Added motion range parameter to UpdateSkeletonComponent in IVRDriverInput. This allows the driver to specify which range of motion set the given transforms are for, with controller or without controller * Added boneCount member InputSkeletalActionData struct. This lets users know how many bones are in the target skeleton by calling GetSkeletalActionData. * Added GetSkeletalBoneData as a separate call to get the bone transforms. User code should now call GetSkeletalActionData first to determine if the action is active, and if so then call GetSkeletalBoneData to retrieve the transforms. * Added an input example to the sample driver. This includes an input profile, localized strings, icons, etc. * Added ulRestrictToDevice argument to GetDigitalActionData, GetAnalogActionData, GetSkeletalActionData, GetSkeletalBoneData, GetSkeletalBoneDataCompressed, and TriggerHapticVibration. This allows applications to use the same action for both hands and differentiate them when calling to fetch the actual data. To get these handles, pass "/user/hand/right" or "/user/hand/left" to IVRInput::GetInputSourceHandle. * Added nPriority to VRActiveActionSet_t. This allows applications to control how multiple bindings from different actions sets block each other. If action set A and action set B both have something bound to the trigger, the action set with the larger priority number will be returned to the application and the action set with the smaller priority number will receive no input. If multiple action sets use the same priority number, the application will get inputs from all actions in those sets even if they're bound to the same input source. IVRRenderModels: * Added GetComponentStateForDevicePath, which allows applications to animate controller components while using the new input system. To get these handles, pass "/user/hand/right" or "/user/hand/left" to IVRInput::GetInputSourceHandle or use the devicePath field in the structure filled out by IVRInput::GetOriginTrackedDeviceInfo. IVRSpatialAnchors: * Add a new interface that lets clients request driver descriptors for physical locations. These descriptors are opaque strings that are stored by the client until they want to recover that position for future use. The driver can update the coordinates whenever it has better information (for example when the HMD gets physically closer to the original location). The client should treat active anchors like object poses that could update at any time. Drivers don't have to implement any special support for this, in which case the runtime will provide fallback descriptors which are no better or worse than just having the application record virtual coordinates. As of this release, no drivers are providing special descriptors. This interface is present for prototyping but is not recommended for production use at this time. Further documentation is provided in the associated headers. IVRVirtualDisplay: * Added the ability for DisplayRedirect devices to disable mura correction in the compositor (set Prop_DriverRequestedMuraCorrectionMode_Int32 to EVRMuraCorrectionMode_NoCorrection). * Added the ability for DisplayRedirect devices to specify parameters to use for mura feathering. This is to allow DisplayRedirect devices that use the IVRVirtualDisplay interface to handle only a subset of mura correction in the middle of the display, while the compositor continues to correct the outer area. Mura correction values are linearly interpolated to zero over the specified ranges in pixels; corners use the max value. IVRCompositorPluginProvider: * Initial support for loading SteamVR drivers in the compositor process. Currently only supports IVRVirtualDisplay components in order to provide async reprojection support. New texture submission formats for macOS 10.14: * macOS 10.14 now supports cross-process sharable MTLTexture objects. Applications on macOS 10.14 or higher should prefer submitting textures to the compositor using TextureType_Metal rather than TextureType_IOSurface. * TextureType_Metal textures of type MTLTextureType2D and MTLTextureType2DArray can be submitted to IVRCompositor::Submit. When submitting MTLTextureType2DArray textures, the compositor assumes layer 0 is the left eye texture (vr::EVREye::Eye_left) and layer 1 is the right eye texture (vr::EVREye::Eye_Right). Applications must still call IVRCompositor::Submit twice, once for each eye, when submitting MTLTextureType2DArray textures, and the two layers of the texture will only be utilized if the same MTLTexturetype2DArray texture is submitted to each call. [git-p4: depot-paths = "//vr/steamvr/sdk_release/": change = 4637165]
- Loading branch information
Showing
49 changed files
with
1,823 additions
and
202 deletions.
There are no files selected for viewing
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file modified
BIN
+17.8 KB
(100%)
bin/osx32/libopenvr_api.dylib.dSYM/Contents/Resources/DWARF/libopenvr_api.dylib
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file added
BIN
+4.48 KB
samples/bin/drivers/sample/resources/icons/controller_status_error.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+4.2 KB
samples/bin/drivers/sample/resources/icons/controller_status_ready.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+4.58 KB
samples/bin/drivers/sample/resources/icons/controller_status_ready_alert.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+4.54 KB
samples/bin/drivers/sample/resources/icons/controller_status_ready_low.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+4.5 KB
samples/bin/drivers/sample/resources/icons/controller_status_searching.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+4.52 KB
samples/bin/drivers/sample/resources/icons/controller_status_searching_alert.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+3.27 KB
samples/bin/drivers/sample/resources/icons/controller_status_standby.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
47 changes: 47 additions & 0 deletions
47
samples/bin/drivers/sample/resources/input/legacy_binding_mycontroller.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
{ | ||
"bindings" : { | ||
"/actions/legacy" : { | ||
"sources" : [ | ||
{ | ||
"inputs" : { | ||
"single" : { | ||
"output" : "/actions/legacy/in/right_axis1_press" | ||
} | ||
}, | ||
"mode" : "button", | ||
"parameters" : { | ||
"sub_mode" : "complex" | ||
}, | ||
"path" : "/user/hand/right/input/a" | ||
}, | ||
{ | ||
"inputs" : { | ||
"single" : { | ||
"output" : "/actions/legacy/in/right_a_press" | ||
} | ||
}, | ||
"mode" : "button", | ||
"parameters" : { | ||
"sub_mode" : "complex" | ||
}, | ||
"path" : "/user/hand/right/input/c" | ||
}, | ||
{ | ||
"inputs" : { | ||
"single" : { | ||
"output" : "/actions/legacy/in/right_grip_press" | ||
} | ||
}, | ||
"mode" : "button", | ||
"parameters" : { | ||
"sub_mode" : "complex" | ||
}, | ||
"path" : "/user/hand/right/input/b" | ||
} | ||
] | ||
} | ||
}, | ||
"controller_type" : "mycontroller", | ||
"description" : "", | ||
"name" : "Default binding for Sample Driver Controller for legacy applications" | ||
} |
37 changes: 37 additions & 0 deletions
37
samples/bin/drivers/sample/resources/input/mycontroller_profile.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
{ | ||
"jsonid": "input_profile", | ||
"legacy_binding": "{sample}/input/legacy_binding_mycontroller.json", | ||
"controller_type": "mycontroller", | ||
"input_bindingui_mode": "single_device", | ||
"input_bindingui_right": { | ||
"image": "{sample}/icons/sample_controller.svg" | ||
}, | ||
"input_source": { | ||
"/input/a": { | ||
"binding_image_point": [ 80, 60 ], | ||
"type": "button", | ||
"order": 1 | ||
}, | ||
"/input/b": { | ||
"binding_image_point": [ 250, 60 ], | ||
"type": "button", | ||
"order": 2 | ||
}, | ||
"/input/c": { | ||
"binding_image_point": [ 450, 60 ], | ||
"type": "button", | ||
"order": 3 | ||
}, | ||
"/output/haptic": { | ||
"binding_image_point": [ 300, 150 ], | ||
"type": "vibration", | ||
"order": 4 | ||
} | ||
}, | ||
"default_bindings": [ | ||
{ | ||
"app_key": "openvr.component.vrcompositor", | ||
"binding_url": "vrcompositor_binding_mycontroller.json" | ||
} | ||
] | ||
} |
37 changes: 37 additions & 0 deletions
37
samples/bin/drivers/sample/resources/input/vrcompositor_binding_mycontroller.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
{ | ||
"app_key" : "openvr.component.vrcompositor", | ||
"bindings" : { | ||
"/actions/lasermouse" : { | ||
"sources" : [ | ||
{ | ||
"inputs" : { | ||
"single" : { | ||
"output" : "/actions/lasermouse/in/leftclick" | ||
} | ||
}, | ||
"mode" : "button", | ||
"path" : "/devices/sample/CTRL_1234/input/b" | ||
} | ||
] | ||
}, | ||
"/actions/system" : { | ||
"sources" : [ | ||
{ | ||
"inputs" : { | ||
"single" : { | ||
"output" : "/actions/system/in/toggledashboard" | ||
} | ||
}, | ||
"mode" : "button", | ||
"parameters" : { | ||
"sub_mode" : "complex" | ||
}, | ||
"path" : "/devices/sample/CTRL_1234/input/a" | ||
} | ||
] | ||
} | ||
}, | ||
"controller_type" : "mycontroller", | ||
"description" : "", | ||
"name" : "My VR Compositor configuration for mycontroller" | ||
} |
8 changes: 8 additions & 0 deletions
8
samples/bin/drivers/sample/resources/localization/localization.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
[ | ||
{ | ||
"language_tag": "en_US", | ||
"mycontroller" : "Sample Driver Controller", | ||
|
||
"/input/c" : "'C' key" | ||
} | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Oops, something went wrong.
6aacebd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JoeLudwig I saw in latest beta notes that Vive controller has a new firmware to support the new haptics API in here. Is there a way to query whether the controller has been updated to support the new API? And/or does the driver emulate it as a fallback as best as possible?
Also, is there a way to get the valid frequency ranges, etc., and does the new API allow superimposing multiple events or does a new call to TriggerHapticVibration cancel existing playing ones?