title | description | author | ms.author | ms.date | ms.topic | keywords |
---|---|---|---|---|---|---|
Voice Input in Unreal |
Learn how to set up and use voice input, speech mappings, and recognition in Unreal mixed reality apps for HoloLens 2 devices. |
sean-kerawala |
sekerawa |
06/10/2020 |
article |
Windows Mixed Reality, Unreal, Unreal Engine 4, UE4, HoloLens 2, voice, voice input, speech recognition, mixed reality, development, features, documentation, guides, holograms, game development, mixed reality headset, windows mixed reality headset, virtual reality headset |
Voice input in Unreal allows you to interact with a hologram without having to use hand gestures and is only supported HoloLens 2. Voice input on HoloLens 2 is powered by the same engine that supports speech in all other Universal Windows Apps, but Unreal uses a more limited engine to process voice input. This limits voice input features in Unreal to predefined speech mappings, which are covered in the following sections.
If you use Windows Mixed Reality Plugin, Voice input doesn’t require any special Windows Mixed Reality APIs; it's built on the existing Unreal Engine 4 Input mapping API. If you use OpenXR, you should additionally install Microsoft OpenXR plugin.
To enable speech recognition on HoloLens:
- Select Project Settings > Platform > HoloLens > Capabilities and enable Microphone.
- Enabled speech recognition in Settings > Privacy > Speech and select English.
Note
Speech recognition always functions in the Windows display language configured in the Settings app. It’s recommended that you also enable Online speech recognition for the best service quality.
- A dialog will show up when the application first starts to ask if you want to enable the microphone. Selecting Yes starts voice input in the app.
Connecting speech to action is an important step when using voice input. These mappings monitor the app for speech keywords that a user might say, then fire off a linked action. You can find Speech Mappings by:
- Selecting Edit > Project Settings, scrolling to the Engine section, and clicking Input.
To add a new Speech Mapping for a jump command:
- Select the + icon next to Array elements and fill out the following values:
- jumpWord for Action Name
- jump for Speech Keyword
Note
Any English word(s) or short sentence(s) can be used as a keyword.
Speech Mappings can be used as Input components like Action or Axis Mappings or as blueprint nodes in the Event Graph. For example, you could link the jump command to print out two different logs depending on when the word is spoken:
- Double-click a blueprint to open it in the Event Graph.
- Right-click and search for the Action Name of your speech mapping (in this case jumpWord), then hit Enter to add an Input Action node to the graph.
- Drag and drop the Pressed pin to Print String node as shown in the image below. You can leave the Released pin empty, it won't execute anything for speech mappings.
- Play the app, say the word jump, and watch the console print out the logs!
That's all the setup you'll need to start adding voice input to your HoloLens apps in Unreal. You can find more information on speech and interactivity at the links below, and be sure to think about the experience you're creating for your users.
If you're following the Unreal development journey we've laid out, you're next task is exploring the Mixed Reality platform capabilities and APIs:
[!div class="nextstepaction"] HoloLens camera
You can always go back to the Unreal development checkpoints at any time.