|
| 1 | +# Mixed Reality Toolkit – User SDK approach *(High level)* |
| 2 | + |
| 3 | +## Problem Statement |
| 4 | + |
| 5 | +Current examples / implementations are far too involved and require users to build new scripts / behaviours to build their project. Users complain the project is too hard to pick up and the current examples are not conducive to implementation (only demonstration) |
| 6 | + |
| 7 | +## Objective |
| 8 | + |
| 9 | +To rearchitect the generic consumption of the Mixed Reality Toolkit to enable users to build scenes through easy to use “drag and drop” components. |
| 10 | + |
| 11 | + |
| 12 | +An example workflow should resemble: |
| 13 | + |
| 14 | + * Consumer builds a 3D scene |
| 15 | + * MRTK is added to the project |
| 16 | + * Add a simple way to define walkable areas (Either through locomotion, free teleportation or restricted teleportation) |
| 17 | + * Enable selecting of an object in a scene and configuring it for interaction (pickup, push, throw, etc) |
| 18 | + * Enable animation interactions, e.g. opening doors |
| 19 | + * Enable passive interactions, interacting one object with another that is in control by the player |
| 20 | + * Quickly add Speech / Gesture / Focus / Controller services |
| 21 | + |
| 22 | +(purely a working set, needs refining) |
| 23 | + |
| 24 | +The ultimate goal is to deliver new users (and existing) with a rapid way to build projects / scenes, trying to cover the 80/20 rule. |
| 25 | +The simple promise for users building with these controls, is that they should always work, regardless of our plans under the hood for MRTK and preserve the projects they build. |
| 26 | + |
| 27 | +## High Level required components |
| 28 | + |
| 29 | +In transforming the frontend of the MRTK for consumers to construct their projects / scenes with, we need to define and develop a simple set of prefabs / scripts / Editor options to quickly and easily add MRTK activities / behaviors to a 3D scene (or virtual scene in the case of HoloLens) |
| 30 | +These can be categorized as: |
| 31 | + |
| 32 | +### Scene elements |
| 33 | + |
| 34 | +Scene elements relate to management style components / configuration to activate core components for the MRTK. Current elements would include: |
| 35 | + |
| 36 | + * Camera (current MRCP) |
| 37 | + * Managers (focus / gaze / controllers / motion controllers / etc) |
| 38 | + * Controllers (scene object collections, interactions) |
| 39 | + |
| 40 | +### Interaction controls |
| 41 | + |
| 42 | +Controls form how the user moves and interacts in the scene, ranging from: |
| 43 | + |
| 44 | + * Locomotion / Teleportation control |
| 45 | + * Locomotion / Teleportation boundaries / targets |
| 46 | + * Speech commands |
| 47 | + * Gestures |
| 48 | + * Pointers / Hands |
| 49 | + |
| 50 | +### Reaction Controls |
| 51 | + |
| 52 | +These components relate to things the user will interact with in a scene, enabling the player to affect the scene, ranging from: |
| 53 | + |
| 54 | + * Grabbing |
| 55 | + * Pushing |
| 56 | + * Opening |
| 57 | + * Pointer targets |
| 58 | + * Buttons / UX |
| 59 | + * Hot Zones (reaction-based events from either the player or an interaction control collision) |
| 60 | + * Highlighting |
| 61 | + |
| 62 | +### UX Systems |
| 63 | + |
| 64 | +In any project the user will need a friendly UX system to assist in their scenes, for example: |
| 65 | + |
| 66 | + * Menu Systems (Grid / Radial) |
| 67 | + * Layout components (Grid / Radial / Curved / Layered) |
| 68 | + * Controller systems (menu overlays for hands / controllers) |
| 69 | + * Tooltips |
| 70 | + * Fade Assist |
| 71 | + |
| 72 | +> **This is not an extensive list and subject to debate.** |
| 73 | +
|
| 74 | +## Initial Plans |
| 75 | + |
| 76 | +The proposal is to build a small subset of controls that utilize the current functionality of the MRTK, applying the above objectives and principles to define some of the high-Level components. |
| 77 | + |
| 78 | +An initial scene which should support both HL & Immersive (subject to discussion, separate may be easier for now), should walk a user in a common room style scenario. |
| 79 | + |
| 80 | +The example (lending from the Cliffhouse setup) should display a simple room, with hot spot teleport zones and activities that can be performed at each location, something akin to Rick and Morty VR or Job Simulator: |
| 81 | + |
| 82 | + |
| 83 | +<div style="text-align:center"> Figure 1 : Reference examples (Rick and Morty / Job Simulator) </div> |
| 84 | + |
| 85 | +The example should include a walk-through example for building the scene in Unity that any consumer can follow, starting from the empty room populated with some simple elements, e.g. |
| 86 | + |
| 87 | + * Buttons that show text on a wall – showing button interaction |
| 88 | + * Mugs that you can pick up (stretch and empty liquid :P) – showing grabbing / dropping |
| 89 | + * A puzzle where you slide tiles around a maze – showing pushing constrained objects around |
| 90 | + |
| 91 | +More examples can be added to the same room, building from a simple start. |
| 92 | +We ensure we build the components to meet these objectives and refine as necessary. The example scene and starter components should then be added to the existing MRTK solution for testing / consumption whilst more are built. |
| 93 | + |
| 94 | +## Work in progress |
| 95 | + |
| 96 | +The team have been working on the initial SDK setup scene with the first components, aims to have (as a start): |
| 97 | + |
| 98 | + * A starting workroom with defined workplaces |
| 99 | + * An area to pick up and interact with objects |
| 100 | + * An area to push objects around, possibly pick up |
| 101 | + * An area with buttons and UX interactive elements |
| 102 | + * A UX panel display area |
| 103 | + |
| 104 | + |
| 105 | +### Current working scene |
| 106 | + |
| 107 | + |
| 108 | +<div style="text-align:center"> Figure 2 : Work in progress example scene 1 </div> |
| 109 | + |
| 110 | +Elements being built in to the scene: |
| 111 | + |
| 112 | +1. Alcove for object to pick up, thinking a cube, cylinder, cup, picture frame |
| 113 | +2. A contained bin where balls will be dropped from *5 when buttons are pressed. Balls can be pushed around and possibly picked up and thrown |
| 114 | +3. Button table for push interaction UX items |
| 115 | +4. Display frame and information box area. Should also have some switchable indicators |
| 116 | +5. Drop points for adding new spheres |
| 117 | + |
| 118 | +For HoloLens, the room would not be displayed, and objects should interact with the environment, e.g. |
| 119 | + |
| 120 | + * Window or shelf for the Alcove (1) |
| 121 | + * Table for buttons (3) with Display elements in 4 floating |
| 122 | + * Elements dropped from (5) will just drop and interact with the Spatial Mesh |
| 123 | + |
| 124 | +# Reference Example |
| 125 | + |
| 126 | +VRTK are refactoring / rebuilding their new example scenes for their next release, which show an interesting path for example scenes: |
| 127 | + |
| 128 | + |
| 129 | +<div style="text-align:center"> Figure 3 : Reference, VRTK new samples </div> |
| 130 | + |
| 131 | +These do look cleaner and easier to digest, this doesn’t change how VRTK is currently implemented which is part of the work detailed here. |
| 132 | +But it is a great showcase for the quality level we should be aiming for which has started with Yoon’s updates to the examples. |
0 commit comments