This document describes how to prepare your work environment to use MixedRealityToolkit-Unity in your Unity 3D project.
It is recommended to be running the Windows 10 Fall Creators update for modern Windows Universal apps targeting Mixed Reality Headsets
This can be verified by running the "WinVer" application from the Windows Run command
Windows Key + R -> WinVer
Which will display a new window as follows:
If you are not running the Windows 10 Fall Creators update, then you will need to Update your version of Windows.
Be sure to enable Developer mode for Windows 10 via:
Action Center -> All Settings -> Update & Security -> For Developers -> Enable Developer mode
If you have not already, download and install Visual Studio 2017 and these required components:
You can install more components and UWP SDK's as you wish.
Make sure you are running the appropriate version of Unity 3D on your machine. You should download and install the latest version this project says it supports on the main readme page.
The Mixed Reality Toolkit now supports the following Unity 3D versions:
Note: Be sure to include the Windows Store .NET scripting backend components.
You can download the latest unity package from Releases folder.
Optionally, If you'd like to build the Mixed Reality Toolkit from the source, you'll need to clone the GitHub repository from:
If you've never cloned a repo before then you should consider using the GitHub desktop client, see https://desktop.github.com/ for more information.
Open the folder you just cloned in Unity. Now, inside of Unity ensure you have the Assets folder selected in the project view, and export the package.
IMPORTANT: Make sure you select the root Assets folder in the Project. It contains important .rsp files like csc, gmcs and smcs.
Assets -> Export Package…
Open or create your project in Unity.
Then import the MRTK asset using Assets -> Import Package -> Custom Package…
[Navigate to the package
you have either downloaded or exported above].
NOTE: If you've prepared the source code yourself, The HoloToolkit-Examples and HoloToolkit-Test folders (and all its content and subfolders) are optional when you import the custom package. You can uncheck those folders in the Import Unity Package window that shows all the contents of the package before performing the import.
You should now have a Mixed Reality Toolkit
menu item in the Unity editor.
Note: This process should be repeated for the examples and test asset packages as well.
Select the "Apply Mixed Reality Project Settings" option in the Unity Editor:
Mixed Reality Toolkit -> Configure -> Apply Mixed Reality Project Settings
Select all the required options for your Project type:
Check:
- For Immersive headsets, check the Target Occluded Devices option
- For HoloLens, leave this option Unchecked
Note If you enable the Enable Xbox Controller Support option, this will download the ProjectSettings Input file and replace your current version in your project and override any existing input settings, the old file will be renamed to ".Old". Else, you will have to setup all the MRTK input axis manually.
Select the "Apply Mixed Reality Scene Settings" option in the Unity Editor:
Mixed Reality Toolkit -> Configure -> Apply Mixed Reality Scene Settings
Select all the required options for your Scene type:
Alternatively, you can setup your scene manually as follows:
-
Create a new Scene:
File -> New Scene
-
Remove the default
Main Camera
andDirectional Light
objects in the scene. -
Add the
MixedRealityCameraParent.prefab
(found under HoloToolkit/Input/Prefabs). Check the configured options for the Parent and child camera meet your requirements. -
Add the
Managers.prefab
(found under HoloToolkit/Input/Prefabs/Cursor), which will add a new Managers folder containing the InputManager Prefab and the all-important UI EventSystem object. -
Add the
DefaultCursor.prefab
(found under HoloToolkit/Input/Prefabs/Cursor) and add that Object to the InputManager Cursor parameter (to avoid it being searched for on scene start)
For Hololens Optionally, if you wish to enable spatial mapping in your scene for HoloLens, you can add the
SpatialMapping.prefab
(found under HoloToolkit/SpatialMapping/Prefabs) to your 'Managers' object. Be aware that you must also enableSpatial Perception
Capabilities:Edit/Project Settings/Player -> Inspector -> Publishing Settings/Capabilities
.
The MRTK provides you a quick and easy way to generate your Unity project from a custom window, which can be found under:
Mixed Reality Toolkit -> Build Window
This window offers many quick options to be able to:
- Build your UWP C# solution
- Build your project APPX
- (HoloLens) Deploy your project to a remote device
Unity supports running your Immersive solution direct from the editor BUT Only when the Mixed Reality Portal is running.
Unity may resolve this in the future and auto-start the portal, but it is better to have it running beforehand!
- Start the MR Portal
- Plug-in and wake up the headset or start the Simulator
- Make sure the "Cliffhouse" is displayed in the Headset
- Select the scene you want to run
- Hit Play in the Unity Editor
Provided everything was good, you should now see your scene running in the headset/simulator.
Alternatively, either Use the Unity Build options or the MRTK Build window to generate the UWP package and run locally on your machine.
- Be sure to plug in your HoloLens via usb.
- Open the above Build Window:
Mixed Reality Toolkit -> Build Window
. - Under
Deploy
be sure to fill out the device Username and Password fields. - In the
Quick Options
section, press the "Build SLN, Build APPX, then Install
" button to deploy to HoloLens.
Optionally, you can use the default build steps if needed.
Once you are ready to deploy to a platform and have built your UWP project, you need to get it on to the device to run, package and ship it to the store.
- Navigate to the Build Window:
Mixed Reality Toolkit -> Build Window
. - Press
Open Project Solution
to open the project in Visual Studio. - Select x64 in your build configuration options.
- In the debug toolbar, select "Local Machine" as the target. (or remote device if you are pushing to another machine)
- Run the app by hitting play.
See the Windows Developer site for publishing to the Microsoft Store.
- Navigate to the Build Window:
Mixed Reality Toolkit -> Build Window
. - Press
Open Project Solution
to open the project in Visual Studio. - Select x86 in your build configuration options.
- In the debug toolbar, select the emulator or the device that you're using.
- Run the app using the debug toolbar.