Spatial Control Room was developed as part of my bachelor's thesis. It is a mixed-reality operating concept for use in production control rooms (PCR), which are mainly found in television productions. The focus was on developing an alternative to conventional vision mixers and monitor walls. I came up with the idea when I was working on a production myself. I noticed that although augmented reality and similar technologies are already being used in film and television to add virtual studios or additional information in sports, immersive technologies have so far mainly been used as a medium and not as a tool for actual content creation. I was therefore interested in whether the existing processes in a production control room could be improved and optimized through the integration of Extended Reality.
Spatial Control Room connects to a computer running OBS (Open Broadcaster Software) and enables the simultaneous streaming of 10 individual scenes to a Quest 3 headset, along with the preview and program buses. Like professional vision mixers, the program bus (marked with a red frame) displays the outgoing video signal, while the preview bus (marked with a green frame) shows the source targeted for the next cut. Instead of pressing buttons on a physical control panel, users can simply tap a video panel to mark it as preview. With a hand gesture resembling scissors, users can signal a cut, causing the video panel to switch to the program state.
The different panels, each displaying various scenes, can be freely positioned and scaled within the environment, offering a clear advantage over traditional physical monitor walls. To improve ergonomics, panels automatically turn towards the user or follow their head position if desired. Another benefit is that the video panels can be duplicated infinitely, allowing placement in various locations, such as directly on cameras, thereby saving on additional hardware costs. The aspect ratio can be adjusted, which is particularly useful for productions that are also broadcast on social media channels with vertical or square video formats.
All basic functions of the application are controlled via a fold-out action bar. This includes a menu for placing individual scenes, virtual labels for labeling hardware, and controls to start or stop OBS's recording and streaming functions. Furthermore, various passthrough modes can be selected to change the real environment, enhancing concentration.
[!Note] Linux and MacOS versions and newer releases should also work, but have not been tested.
Download and install OBS Studio (Open Broadcaster Software): https://obsproject.com/download
Tested with OBS Studio windows version 30.0.2
Download and install OBS-NDI and the NDI Runtime as described here: https://github.com/obs-ndi/obs-ndi
Tested with NDI Runtime 6 windows version NDIRedistV6 (is recognized by some browsers as an unsafe download)
Tested with OBS-NDI windows version obs-ndi-4.13.1-windows-x64
Start OBS and activate the "Studio Mode" with the button in the lower right corner (more about Studio Mode)
Click on Tools in the top menu bar and open the NDI output settings, here the main output and the preview output must be activated
Click on Tools in the top menu bar, open the WebSocket server settings, enable the server and click on Apply (click on Show Connect Info to see your credentials)
Click on Scene Collection in the top menu bar and import the .json file found on Latest Releases
Add any number of sources to Scene 1-10, such as webcams, capture cards, or videos
[!Important] "Spatial Control Room Feeds" must be the lowest in the list and should not be changed!
[!Tip] To display video sources correctly in the Quest App, uncheck "Hide source when playback ends" in its properties; it is also a good idea to enable "Restart playback when source becomes active".
[!Tip] If the NDI streams don't show up. One thing you can try is temporarily connecting the headset to a different Wi-Fi network and then back to the original one.
[!Note] The application has been developed for the Meta Quest 3, a Meta Quest Pro or newer headsets with Meta Horizon OS should also work, but have not been tested. All previous models may not have enough power to transmit more than one NDI stream.
Connect the headset to the same network as the computer running OBS
The computer should be connected with an Ethernet cable; for best performance use a modern Wi-Fi 6E router
Start the APP, open the action bar and click the gear icon to enter your WebSocket credentials and select the NDI streams as follows:
Feed Group 1 = YourComputerName (Feed1_Group)
/
Feed Group 2 = YourComputerName (Feed2_Group)
/
Feed Group 3 = YourComputerName (Feed3_Group)
Tab on "Connect". If the connection is successful, a message should appear below the action bar.
Passthrough via Meta Quest Link
main
branch2022.3.13
via the Unity Hub (if the version is not avaiable in the hub anymore, you can download it here)Add
on the “Projects” tab and navigating to the location where you downloaded the repositoryAssets/_SpatialControlRoom/Scenes
and open the scene named SpatialControlRoom
Put on your headset open the action bar and click the gear icon to enter your WebSocket credentials (local IP) and select the NDI streams as follows:
Feed Group 1 = YourComputerName (Feed1_Group)
/
Feed Group 2 = YourComputerName (Feed2_Group)
/
Feed Group 3 = YourComputerName (Feed3_Group)
Tab on "Connect". If the connection is successful, a message should appear below the action bar.
Aids for aligning panels (snapping)
Grouping of panels
Saving and loading of arrangements using spatial anchors
Clean-up function that automatically arranges panels logically
Automatic scaling of UI elements as distance increases
Object tracking for linking panels to physical objects like cameras
Option to show the title-safe area
Displaying of audio levels and intercom integration
Integration of advanced tools such as vectorscope or waveform monitor
Intercom integration
Seperate workspaces for video, audio and light
Multi-user support
Make sure that Main Output and Preview Output are checked in the NDI Output Settings panel in OBS. Open the Spatial Control Room Feed scene, go to the Feed1 group and double-click the Preview source. In the properties, make sure the correct source name is selected (YourComputerName (OBS Preview)), do the same for "Program" (YourComputerName (OBS Program)).
Streaming and receiving NDI requires a good network connection and places a heavy load on the CPU. Use a fast WiFi 6E standard router (e.g. TP-Link Archer AXE75) and make sure your computer is connected directly to it with an Ethernet cable. Make sure the headset is connected to the fastest connection (6GHz), as modern routers often create multiple WiFi networks for different bands. It may also help to block other devices from connecting to the network to free up bandwidth.
If you do not need all 10 scenes, it is a good idea to disable the NDI streams you do not need. To do this, click the gear icon and set feed group 3 and feed group 2 to None. This should give you a significant performance boost by reducing the CPU load.
[!Note] Feed Group 3 contains scenes 7-10, Feed Group 2 contains scenes 3-6, Feed Group 1 contains scenes 1-2 and the Preview and Program feed.
You can also set the CPU level of the Quest to level 5 by sending the following Adb command via the Meta Quest Developer Hub: adb shell setprop debug.oculus.cpuLevel 5
(more about ADB)
Also check whether your computer has enough power to run OBS smoothly.
I studied user interface design and am a trained media designer with a strong interest in XR and spatial computing. I am also interested in 3D motion design and digital music production. For questions about the project or a general exchange I am available here: