How to open and close windows and volumes programmatically in VisionOS
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/dd6e8/dd6e8069a7333dc2ac83eacf02b24026a94ac0fd" alt="A flower that represents VisionOS with the text “Open and Close Windows & Volumes” beneath it."
To open and close windows and volumes, add them to the app and use the openWindow and dismissWindow environment variables within a button.
The code for this tutorial can be found in the repository linked below on the 101/opening-and-closing-windows branch.
Please note that this tutorial focuses on closing windows and volumes through buttons external to the window or volume.
You can always use the x button at the bottom of a window or volume to close it.
Step One: Setup the Entities
data:image/s3,"s3://crabby-images/0ece3/0ece3f92dd5a7d456ae3bbc2aed037335932e3d9" alt="A screenshot of the simulator showing multiple windows and volumes."
Follow the tutorial below to learn how to open volumes and windows.
Step Two: Create a Dynamic Button
data:image/s3,"s3://crabby-images/7da42/7da4273a404c14c7703b2d054f64bc632a638802" alt="A screenshot of XCode showing the code for the dynamic button."
Create a new file that holds a button that opens and dismisses windows depending on the id that is passed in.
Please note that this functionality opens and closes volumes too.
Step Three: Update the Main Window
data:image/s3,"s3://crabby-images/2eafb/2eafb891c347ff88f69ead90f360589acdb4fec5" alt="A screenshot of XCode showing the updated code for the main window which now features the dynamic button."
Update the window to use the button created in Step Two.
Step Four: Test
data:image/s3,"s3://crabby-images/a08de/a08de7dc07e125fe57cd68efd74adf3efd8c86bf" alt="A screenshot of the simulator showing that a second window is open and the button says "close window" instead of "open window"."
The simulator can now open windows.
Run the code and make sure you can open and close windows and volumes.
data:image/s3,"s3://crabby-images/4c389/4c3890271303df5bc3b2c1a6c2119b323169a468" alt="A screenshot of the simulator showing that the window is now closed and the button says "open window" instead of "close window"."
The simulator can now close windows.
Looking to learn more about VisionOS, Spatial Computing, Design and Technology?
Search our blog to learn more about visionOS, spatial computing, design and technology.