Oculus Loading Splash Screens for Unreal Explained
Eric Cosky
The Oculus Rift supports an overlay system which presents images at 90 FPS while responding to head tracking regardless of the application's actual frame rate. The Unreal Engine's VR Splash Screens feature uses this feature to provide a comfortable experience while the application is busy transitioning between levels. While it is possible to make an application load new levels asynchronously, it does come at the cost of both time and complexity. More documentation on Unreal's VR Splash Screen system can be found here: https://docs.unrealengine.com/en-us/Platforms/VR/SplashScreens
Unreal includes a set of Oculus specific nodes that take advantage of a few extra features unique to the Rift. These include the ability to use multiple textures, position the splash screen texture and rotate them on all three axis at constant speeds. This provides the developer some creative options for stacking images that animate while a level is being loaded. Using these tools, it's a fairly straightforward task to present something more interesting than a static image between levels.
We've had a number of developers ask us for a complete sample of how to use the Oculus specific splash screen features, so here it is! It is a set of three levels: StartupLevel, Level1, and Level2. The StartupLevel configures four overlays which rotate independently, and after a brief delay to allow you to observe the effect, will load Level1.
The level blueprint for Level 1 simply waits one second and loads Level2. The loading splash screens will appear while Level2 is being loaded, because they have already been configured and remain ready for activation whenever a level is being loaded.
The level blueprint for Level 2 is pretty much the same as Level1's level blueprint - it just waits one second and loads Level1. Again, the loading splash screens will be visible during this transition.
The result of running the sample will be 10 seconds of the splash screens spinning for the initial startup level, then bouncing between Level1 and Level2. The loading screens will probably only be visible for a few moments on most systems because these levels are trivially small.
The LoadingLevel blueprint shows a few extra nodes which aren't connected to the execution path. They are there to point out a common source of confusion we've heard from developers. First, the Hide Splash Screen looks like it should hide the Loading Splash Screens, but it doesn't work that way as of this writing. If the graph is modified so that Hide Splash Screen is used (as shown below) instead of Hide Loading Splash Screen, the application will never actually hide the splash screens.
The important thing to understand here is that the Oculus-specific splash screen nodes need to be used together. While they are closely related to the standard Unreal splash screen nodes, they are not the same system.
Here's a looping GIF capture which shows Oculus Loading Splash Screen sample in action:
Enjoy!
Rift
Unreal
Explore more
GDC 2025: Emerging Opportunities in MR/VR on Meta Horizon OS
Discover some of the opportunities we shared at GDC 2025 to accelerate your development process, level up your skillset and expand your reach with Meta Horizon OS.
Seamlessly Power Colocated Mixed Reality Experiences with Colocation Discovery and Group Sharing
Colocation Discovery and Group Sharing work to support seamless colocated mixed reality experiences by allowing Meta Quest devices to discover other nearby devices running the same app and allowing all users to share spatial anchors. Learn how these APIs reduce user and developer friction.
At Meta Connect, we shared new hardware, development paths, tools, and mixed reality technologies paving the way for greater developer success on Meta Horizon OS.