Interact with the Real World: OpenXR Scene Understanding
OpenXR Scene Understanding Plugin Setup
Supported Unreal Engine version: 4.27 +
-
Enable Plugins:
- Please enable plugin in Edit > Plugins > Virtual Reality:
data:image/s3,"s3://crabby-images/6294f/6294f4a5830a46e0bd42dd364272f02c5686e64b" alt="image1.png"
-
Disable Plugins:
- The "Steam VR" plugin must be disabled for OpenXR to work.
-
- Please disable plugin in Edit > Plugins > Virtual Reality:
data:image/s3,"s3://crabby-images/8378e/8378e19aa7d14feafe101680f95f3d6385090f23" alt="image2.png"
-
-
Project Settings:
- Please make sure the “ OpenXR Scene Understanding extension ” is enabled, the setting is in Edit > Project Settings > Plugins > Vive OpenXR > Scene Understanding:
-
Project Settings:
data:image/s3,"s3://crabby-images/70764/7076430a5e8404d76a16871c8029979cec6f6859" alt="image3.png"
Introduction to Blueprint Nodes for OpenXR Scene Understanding
-
Used to limit the range that will be scanned
-
These bounding volumes are used to determine which scene components to include in the resulting scene.
- Set Scene Compute Oriented Box Bound : Set the bounds of the box shape.
- Set Scene Compute Sphere Bound : Set the bounds of the sphere shape.
- Set Scene Compute Frustum Bound : Set the bounds of the frustum shape.
- Clear Scene Compute Bounds: Before the game ends, you need to clear all bounds by calling Clear Scene Compute Bounds .
-
These bounding volumes are used to determine which scene components to include in the resulting scene.
data:image/s3,"s3://crabby-images/fffff/fffff178f93842628e4cf84f7537a2db18f4e727" alt="image4.png"
-
Controls the update speed of the scene and will affect the quality of the scene result
- This function will be trading off speed against the quality of the resulting scene.
-
- Set Scene Compute Consistency
data:image/s3,"s3://crabby-images/ed30a/ed30a719478b2ef0c94861fe836d4f46ea55c56d" alt="image5.png"
-
Identify the level of detail of meshes
- This function will identify the level of detail of visual mesh compute.
-
- Set Mesh Compute Lod
data:image/s3,"s3://crabby-images/593a7/593a72d85e8f9c1298e242f9ee9c35caf14c0804" alt="image6.png"
Show Scene Understanding scanned mesh in the game
-
Step1.
Essential Setup
-
- Creating an AR Session:
-
- The AR-related content needs to be set here because the OpenXR Scene Understanding uses OpenXRARTrackedGeometry to make the scanned meshes appear in the level. Unreal Setting up AR project Tutorial
- Create Data Asset: Content Browser > All > Content > click right mouse button > choose Miscellaneous > Data Asset
data:image/s3,"s3://crabby-images/1a1ff/1a1ffcd8faa0dcec22580f8cfbab67dc14693ca5" alt="image7.png"
-
- After choose Data Asset , it will pop out “ Pick Class For Data Asset Instance ” window:
-
-
- Choose “ ARSessionConfig ” and press “ Select ”.
-
data:image/s3,"s3://crabby-images/b5bdb/b5bdb4ea54f7210df708f4ff4afbb8b8ae4f7bb0" alt="image8.png"
-
-
Open
ARSessionConfig
and enable some settings under Details Panel > AR Settiongs > World Mapping
- Enable Generate Mesh Data from Tracked Geometry
- Enable Generate Collision for Mesh Data
-
Open
ARSessionConfig
and enable some settings under Details Panel > AR Settiongs > World Mapping
data:image/s3,"s3://crabby-images/d5344/d53440efff1c8e3579197363ff42d7ac13787c55" alt="image9.png"
-
Open Level Blueprint and add
Start AR Session
and
Stop AR Session
- Remember to set the “ARSessionConfig” as input to Start AR Session.
data:image/s3,"s3://crabby-images/7bb88/7bb88caca1f771c4401a12eeb540fcc1744c642a" alt="image11.png"
- Create a Blueprint for Scene Understanding and drag into the level.
data:image/s3,"s3://crabby-images/932ca/932ca7a9eaee9d65b1b4c278cdddec06ebcf7591" alt="image12.png"
data:image/s3,"s3://crabby-images/85c0e/85c0e90cbed36564e88b2b13d70f5dfd50ee3978" alt="image13.png"
Step2. BP_SceneUnderstanding: Display scanned mesh in the level
- In this tutorial we choose Actor as the parent class.
-
In Components panel:
- Add a Cube Static Mesh Component for Set Scene Compute Oriented Box Bounds .
data:image/s3,"s3://crabby-images/acff0/acff0abd814c680e77aa01cc4dd029d6de55a48e" alt="image14.png"
data:image/s3,"s3://crabby-images/dd0f4/dd0f497ba73b03a43f1f8891a6bdbdcc48de8554" alt="image14.png"
- Add ARTrackableNotify Component in Components panel.
data:image/s3,"s3://crabby-images/ac0d9/ac0d9f5d7d6808836aa9ef7d64f5cefe68af8564" alt="image16.png"
-
- Add a new variable and name it “ spatialMeshes ” with type “ ARTrackedGeometry Array ” in My Blueprint
data:image/s3,"s3://crabby-images/36903/369031c06b0760a3333565c5a3de6c86c8744093" alt="image17.png"
data:image/s3,"s3://crabby-images/31ce8/31ce808b16764a04181cce03a3eb7b6b39f25479" alt="image18.png"
- Add a function and name it “ StartSpatialMapping ” in My Blueprint In this function, we need to call “ Toggle ARCapture ” function and set input “ On Off ” bool to true and “ Capture Type” to Spatial Mapping.
data:image/s3,"s3://crabby-images/a34bb/a34bbfaeede3380da3b9595d3f5430b50e7c8915" alt="image18.png"
data:image/s3,"s3://crabby-images/3ce2c/3ce2c8fe28c1033c169b28007d7a37b9025f9678" alt="image20.png"
-
- Add a function and name it “ StopSpatialMapping ” in My Blueprint In this function, we need to call “ Toggle ARCapture ” function and set input “ On Off ” bool to false and “ Capture Type” to Spatial Mapping .
data:image/s3,"s3://crabby-images/557bc/557bc7da0ded3fb87ad51c897e12b91e849da8a0" alt="image20.png"
data:image/s3,"s3://crabby-images/2072c/2072c4a709d5769710ee879e2b197da396eae5f9" alt="image21.png"
-
- Event BeginPlay : We will add some functions that affect the quality and area of the scanned mesh.
data:image/s3,"s3://crabby-images/a58c7/a58c728d71e7df8ef8291be97c6db549f2ed0887" alt="image22.png"
-
-
On Add/Remove Tracked Geometry (ARTrackableNotify):
- These two Events will control the number of mesh currently scanned.
-
On Add/Remove Tracked Geometry (ARTrackableNotify):
- Event Tick: You can get the current Spatial Meshes and Set Material on them.
data:image/s3,"s3://crabby-images/d9b4b/d9b4b96484183e5ef98a3f42627e4ce995b278b5" alt="image24.png"
- Event BeginPlay: We will need to call Stop Spatial Mapping function and clear the bound you use at the beginning.
data:image/s3,"s3://crabby-images/b8b7c/b8b7cebb05db5ab4360e04aa6a10336b026e975f" alt="image25.png"
Result
Note:
- White Area: meshes representing the real-environment objects.
- Black Area: no objects in the space.
Spawn balls and interact with generated meshes
This sample is currently only supported Unreal Engine version: 5.0+ .
Because the physics system used by the meshes generated is Chaos Physics .
-
Create a Blueprint
- Create a Blueprint for the “Spawn ball” and drag it into the level.
- You can place as many as you want in the level.
data:image/s3,"s3://crabby-images/16adc/16adcd1c6aa3b0dabd521c87a0d82fdd1ff97675" alt="image28.png"
data:image/s3,"s3://crabby-images/7e4b7/7e4b739d686865a9cbc77f1fa63ff4d02cd0f996" alt="image29.png"
-
BP_SpawnBall: Make a sphere static mesh to simulate a physical fall.
- In Components panel: Add a Sphere Static Mesh Component to pretend the ball in Components panel.
data:image/s3,"s3://crabby-images/ff646/ff646cde6be18cc82ab3069adca6adece011f00e" alt="image30.png"
- In Details panel: Enable Simulate Physics and make sure the Collision Presets is “PhysicsActor”
data:image/s3,"s3://crabby-images/eaeae/eaeaeaa3388cff99639a7f59952dccdf50ae80bf" alt="image31.png"
-
In
My Blueprint
panel:
- Add a variable to hold the origin location of the ball.
data:image/s3,"s3://crabby-images/4d8dc/4d8dce8ba172e4f0502ba0917747eeb18f991186" alt="image32.png"
-
-
In
Event Graph
panel:
- Set the origin location of the ball when the game starts.
-
In
Event Graph
panel:
data:image/s3,"s3://crabby-images/b1308/b13082469991f1687efb294a10bb9de302efeb08" alt="image33.png"
-
-
- Track the height of the ball in each frame, and reset its position if it is below -600.
-
data:image/s3,"s3://crabby-images/a875a/a875a36516774551851aaecfca1128d16521b601" alt="image34.png"
Result
data:image/s3,"s3://crabby-images/da9c0/da9c01af2ec749c9911ac8e399dc7e6e2933e56b" alt="3.png"
Note:
- Red Balls: Virtual Objects.
- White Area: It means that there are scanned meshes .
- Black Area: It means that there are no objects in the space.