Assignment for RMIT Mixed Reality in 2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

191 lines
15 KiB

  1. # Examples
  2. This directory contains Unity3d scenes that demonstrate the scripts and prefabs being used in the game world to create desired functionality.
  3. > *VRTK offers a VR Simulator that works without any third party SDK, but VR device support requires a supported VR SDK to be imported into the Unity project.*
  4. The example scenes support all the VRTK supported VR SDKs. To make use of VR devices (besides the included VR Simulator) import the needed third party VR SDK into the project.
  5. For further information about setting up a specific SDK and using VRTK in your own project, check out the
  6. [GETTING_STARTED.md](/Assets/VRTK/Documentation/GETTING_STARTED.md) document.
  7. There is also a `/ExampleResources/Scripts` directory within the `VRTK/Examples` directory that contains helper scripts utilised by the example scenes to highlight certain functionality (such as event listeners). These example scripts are not required for real world usage.
  8. ## Current Examples
  9. ### 001_CameraRig_VRPlayArea
  10. A simple scene showing the `[CameraRig]` prefab usage.
  11. ### 002_Controller_Events
  12. A simple scene displaying the events from the controller in the console window.
  13. ### 003_Controller_SimplePointer
  14. A scene with basic objects that can be pointed at with the laser beam from the controller activated by pressing the `Touchpad`. The pointer events are also displayed in the console window.
  15. ### 004_CameraRig_BasicTeleport
  16. A scene with basic objects that can be traversed using the controller laser beam to point at an object in the game world where the user is to be teleported to by pressing `Touchpad` on the controller. When the `Touchpad` is released, the user is teleported to the laser beam end location.
  17. ### 005_Controller_BasicObjectGrabbing
  18. A scene with a selection of objects that can be grabbed by touching them with the controller and pressing the `Grip` button down. Releasing the grip button will propel the object in the direction and velocity of the grabbing controller. The scene also demonstrates simple highlighting of objects when the controller touches them. The interaction events are also displayed in the console window.
  19. ### 006_Controller_UsingADoor
  20. A scene with a door interactable object that is set to `usable` and when the door is used by pressing the controller `Trigger` button, the door swings open (or closes if it's already open).
  21. ### 007_CameraRig_HeightAdjustTeleport
  22. A scene with a selection of varying height objects that can be traversed using the controller laser beam to point at an object and if the laser beam is pointing on top of the object then the user is teleported to the top of the object. Also, it shows that if the user steps into a part of the play area that is not on the object then the user will fall to the nearest object. This also enables the user to climb objects just by standing over them as the floor detection is done from the position of the headset.
  23. ### 008_Controller_UsingAGrabbedObject
  24. A scene with interactable objects that can be grabbed (pressing the `Grip` controller button) and then used (pressing the `Trigger` controller button). There is a gun on a table that can be picked up and fired, or a strange box that when picked up and used the top spins.
  25. ### 009_Controller_BezierPointer
  26. A scene with a selection of varying height objects that can be traversed using the controller however, rather than just pointing a straight beam, the beam is curved (over a bezier curve) which allows climbing on top of items that the user cannot visibly see.
  27. ### 010_CameraRig_TerrainTeleporting
  28. A scene with a terrain object and a selection of varying height 3d objects that can be traversed using the controller laser beam pointer. It shows how the Height Adjust Teleporter can be used to climb up and down game objects as well as traversing terrains as well.
  29. ### 011_Camera_HeadSetCollisionFading
  30. A scene with three walls around the play area and if the user puts their head into any of the collidable walls then the headset fades to black to prevent seeing unwanted object clipping artefacts.
  31. ### 012_Controller_PointerWithAreaCollision
  32. A scene which demonstrates how to use a controller pointer to traverse a world but where the beam shows the projected play area space and if the space collides with any objects then the teleportation action is disabled. This means it's possible to create a level with areas where the user cannot teleport to because they would allow the user to clip into objects.
  33. ### 013_Controller_UsingAndGrabbingMultipleObjects
  34. A scene which demonstrates how interactable objects can be grabbed by holding down the grab button continuously or by pressing the grab button once to pick up and once again to release. The scene also shows that the use button can have a hold down to keep using or a press use button once to start using and press again to stop using. This allows multiple objects to be put into their Using state at the same time as also demonstrated in this example scene.
  35. ### 014_Controller_SnappingObjectsOnGrab
  36. A scene with a selection of objects that demonstrate the different snap to controller mechanics. The two green guns, light saber and sword utilise a Snap Handle which uses an empty game object as a child of the interactable object as the orientation point at grab, so the rotation and position of the object matches that of the given `Snap Handle`. The red gun utilises a basic snap where no precision is required and no Snap Handles are provided which does not affect the object's rotation but positions the centre of the object to the snap point on the controller. The red/green gun utilises the `Precision Snap` which does not affect the rotation or position of the grabbed object and picks the object up at the point that the controller snap point is touching the object.
  37. ### 015_Controller_TouchpadAxisControl
  38. A scene with an R/C car that is controlled by using the Controller Touchpad. Moving a finger up and down on the Touchpad will cause the car to drive forward or backward. Moving a finger to the left or right of the `Touchpad` will cause the car to turn in that direction. Pressing the `Trigger` will cause the car to jump, this utilises the Trigger axis and the more the trigger is depressed, the higher the car will jump.
  39. ### 016_Controller_HapticRumble
  40. A scene with a collection of breakable boxes and a sword. The sword can be picked up and swung at the boxes. The controller rumbles at an appropriate vibration depending on how hard the sword hits the box. The box also breaks apart if it is hit hard enough by the sword.
  41. ### 017_CameraRig_TouchpadWalking
  42. A scene which demonstrates how to move around the game world using the touchpad by sliding a finger forward and backwards to move in that direction. Sliding a finger left and right across the touchpad strafes in that direction. The rotation is done via the user in game physically rotating their body in the place space and whichever way the headset is looking will be the way the user walks forward. Crouching is also possible as demonstrated in this scene and in conjunction with the Headset Collision Fade script it can detect unwanted collisions (e.g. if the user stands up whilst walking as crouched) and reset their position to the last good known position.
  43. ### 018_CameraRig_FramesPerSecondCounter
  44. A scene which displays the frames per second in the centre of the headset view. Pressing the trigger generates a new sphere and pressing the touchpad generates ten new spheres. Eventually when lots of spheres are present the FPS will drop and demonstrate the prefab.
  45. ### 019_Controller_InteractingWithPointer
  46. A scene which shows how the controller pointer beam can be used to toggle the use actions on interactable objects. Pressing the touchpad activates the beam and aiming it at objects will toggle their use state. It also demonstrates how a game menu could be created by using interactable objects snapped to a game object can trigger actions. Pressing the Application Menu button displays a cube connected to the controller which has menu options. Pointing the beam with the other controller at the cube will select the menu options accordingly.
  47. ### 020_CameraRig_MeshTeleporting
  48. A scene with an object with a mesh collider to demonstrate how the Height Adjust Teleporter can be used to climb up and down objects with a mesh collider.
  49. ### 021_Controller_GrabbingObjectsWithJoints
  50. A scene with a collection of Interactable Objects that are attached to other objects with joints. The example shows that Interactable Objects can have different attach mechanics to determine the best way of connecting the object to the controller. Fixed Joint works well for holding objects like cubes as they track perfectly to the controller whereas a Spring Joint works well on the drawer to give it a natural slide when operating. Finally, the Rotator Track works well on the door to give a natural control over the swing of the door. There is also a Character Joint object that can be manipulated into different shapes by pulling each of the relevant sections.
  51. ### 022_Controller_CustomBezierPointer
  52. A scene that demonstrates how the Bezier Pointer can have complex objects passed to it to generate the tracer beam and the cursor of the pointer. In the scene, particle objects with rotations are used to demonstrate a different look to the bezier pointer beam.
  53. ### 023_Controller_ChildOfControllerOnGrab
  54. A scene that demonstrates the grab mechanic where the object being grabbed becomes a child of the controller doing the grabbing. This works well for objects that need absolute tracking of the controller and do not want to be disjointed under any circumstances. The object becomes an extension of the controller. The scene demonstrates this with a bow and arrow example, where the bow can be picked up and tracked to the controller, whilst the other controller is responsible for picking up arrows to fire in the bow.
  55. ### 024_CameraRig_ExcludeTeleportLocation
  56. A scene that shows how to exclude certain objects from being teleportable by either applying a named Tag to the object or by applying a Script of a certain name. In the scene, the yellow objects are excluded from teleport locations by having an `ExcludeTeleport` tag set on them and the black objects are excluded by having a script called `ExcludeTeleport` attached to them. The `ExcludeTeleport` script has no methods and is just used as a placeholder.
  57. ### 025_Controls_Overview
  58. A scene that showcases the existing interactive controls, different ways how they can be set up and how to react to events sent by them.
  59. ### 026_Controller_ForceHoldObject
  60. A scene that shows how to grab an object on game start and prevent the user from dropping that object. The scene auto grabs two swords to each of the controllers and it's not possible to drop either of the swords.
  61. ### 027_CameraRig_TeleportByModelVillage
  62. A scene that demonstrates how to teleport to different locations without needing a world pointer and using the Destination Events abstract class on objects that represent a mini map of the game world. Touching and using an object on the map teleports the user to the specified location.
  63. ### 028_CameraRig_RoomExtender
  64. A scene that demonstrates the concept of extending the physical room scale space by multiplying the physical steps taken in the chaperone bounds. A higher multiplier will mean the user can walk further in the play area and the walk multiplier can be toggled by a button press.
  65. ### 029_Controller_Tooltips
  66. A scene that demonstrates adding tooltips to game objects and to the controllers using the prefabs `ObjectTooltip` and `ControllerTooltips`.
  67. ### 030_Controls_RadialTouchpadMenu
  68. A scene that demonstrates adding dynamic radial menus to controllers and other objects using the prefab `RadialMenu`.
  69. ### 031_CameraRig_HeadsetGazePointer
  70. A scene that demonstrates the ability to attach a pointer to the headset to allow for a gaze pointer for teleporting or other interactions supported by the World Pointers. The `Touchpad` on the right controller activates the gaze beam, whereas the `Touchpad` on the left controller activates a beam projected from a drone in the sky as the World Pointers can be attached to any object.
  71. ### 032_Controller_CustomControllerModel
  72. A scene that demonstrates how to use custom models for the controllers instead of the default HTC Vive controllers. It uses two simple hands in place of the default controllers and shows simple state changes based on whether the grab button or use button are being pressed.
  73. ### 033_CameraRig_TeleportingInNavMesh
  74. A scene that demonstrates how a baked NavMesh can be used to define the regions that a user is allowed to teleport into.
  75. ### 034_Controls_InteractingWithUnityUI
  76. A scene that demonstrates how to interact with Unity UI elements. The scene uses the `VRTK_UIPointer` script on the right Controller to allow for the interaction with Unity UI elements using a Simple Pointer beam. The left Controller controls a Simple Pointer on the headset to demonstrate gaze interaction with Unity UI elements.
  77. ### 035_Controller_OpacityAndHighlighting
  78. A scene that demonstrates how to change the opacity of the controller and how to highlight elements of the controller such as the buttons or even the entire controller model.
  79. ### 036_Controller_CustomCompoundPointer
  80. A scene that demonstrates how the Bezier Pointer can display an object (teleport beam) only if the teleport location is valid, and can create an animated trail along the tracer curve. This scene provides a textured environment for testing the teleport, some active "plasma" spheres on the wall that can be activated with the pointer and another sphere that can be also grabbed and launched around.
  81. ### 037_CameraRig_ClimbingFalling
  82. A scene that demonstrates how to set up the climbing mechanism with different activities to try it with. Various objects with a `VRTK_InteractableObject` component are scattered throughout the level. They all have the `GrabAttachMechanic` set to `Climbable`.
  83. ### 038_CameraRig_CameraRig_DashTeleport
  84. A scene that shows the teleporting behaviour and also demonstrates a way to use the broadcasted RaycastHit array. In the example obstacles in the way of the dash turn off their mesh renderers while the dash is in progress.
  85. ### 039_CameraRig_AdaptiveQuality
  86. > **Only Compatible With Unity 5.4 and above**
  87. A scene displays the frames per second in the centre of the headset view. The debug visualization of this script is displayed near the top edge of the headset view. Pressing the trigger generates a new sphere and pressing the touchpad generates ten new spheres. Eventually when lots of spheres are present the FPS will drop and demonstrate the script.
  88. ### 040_Controls_PanelMenu
  89. A scene that demonstrates how to attach interactable panel prefabs to game objects to provide additional settings.
  90. ### 041_Controller_ObjectSnappingToDropZones
  91. A scene that uses the `VRTK_SnapDropZone` prefab to set up pre-determined snap zones for a range of objects and demonstrates how only objects of certain types can be snapped into certain areas.
  92. ### 042_CameraRig_MoveInPlace
  93. A scene that demonstrates how the user can move and traverse colliders by either swinging the controllers in a walking fashion or by running on the spot utilising the head bob for movement.
  94. ### 043_Controller_SecondaryControllerActions
  95. A scene that demonstrates the ability to grab an object with one controller and scale it by grabbing and pulling with the second controller.
  96. ### 044_CameraRig_RestrictedTeleportZones
  97. A scene that uses the `VRTK_DestinationPoint` prefab to set up a collection of pre-defined teleport locations.