{"id":2284,"date":"2025-01-12T07:15:24","date_gmt":"2025-01-12T12:15:24","guid":{"rendered":"https:\/\/stepinto.vision\/?p=2284"},"modified":"2025-01-12T07:15:24","modified_gmt":"2025-01-12T12:15:24","slug":"spatial-swiftui-zstack","status":"publish","type":"post","link":"https:\/\/stepinto.vision\/example-code\/spatial-swiftui-zstack\/","title":{"rendered":"Spatial SwiftUI: ZStack"},"content":{"rendered":"\n<p>ZStack is a core container view in SwiftUI, but it really shines in visionOS where depth is real.<\/p>\n\n\n\n<p>The use cases for ZStack are too numerous to cover, so let&#8217;s just focus on three simple examples.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Space views evenly in the ZStack<\/h2>\n\n\n\n<p>Spacing is controlled by the parent ZStack. Each child view has a depth of 0. The stack adds space between them to create a 3D effect. <\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#000000;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" data-code=\"ZStack(spacing: spacing \/ 3) {\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepRed)\n        .frame(width: 200, height: 200)\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepGreen)\n        .frame(width: 150, height: 150)\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepBlue)\n        .frame(width: 100, height: 100)\n}\n.frame(depth: spacing)\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">spacing<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">) {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">.<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Use Spacers to fill all available space in the ZStack<\/h2>\n\n\n\n<p>We can push our first view to the back with a spacer. Then do the same thing with the last view. Adding two spaces between three views will result in a simple layout. <\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Back: first view is placed at a depth of 0<\/li>\n\n\n\n<li>Center: second view is placed at the halfway point<\/li>\n\n\n\n<li>Front: third view is paced a the max depth for the stack<\/li>\n<\/ul>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#000000;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" data-code=\"ZStack() {\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepRed)\n        .frame(width: 200, height: 200)\n\n    Spacer() \/\/ this spaces pushes the first view all the way to the back\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepGreen)\n        .frame(width: 150, height: 150)\n\n    Spacer() \/\/ this spacer pushes the last view all the way to the front\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepBlue)\n        .frame(width: 100, height: 100)\n}\n.frame(depth: spacing)\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">() {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">Spacer<\/span><span style=\"color: #000000\">() <\/span><span style=\"color: #008000\">\/\/ this spaces pushes the first view all the way to the back<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">Spacer<\/span><span style=\"color: #000000\">() <\/span><span style=\"color: #008000\">\/\/ this spacer pushes the last view all the way to the front<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">.<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Child views set their own depth<\/h2>\n\n\n\n<p>In this example, each child view takes up 1\/3 of the available depth.<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#000000;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" data-code=\"ZStack() {\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepRed)\n        .frame(width: 200, height: 200)\n        .frame(depth: spacing \/ 3)\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepGreen)\n        .frame(width: 150, height: 150)\n        .frame(depth: spacing \/ 3)\n\n    RoundedRectangle(cornerRadius: 12.0)\n        .foregroundStyle(.stepBlue)\n        .frame(width: 100, height: 100)\n        .frame(depth: spacing \/ 3)\n}\n.frame(depth: spacing)\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">() {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">.<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Video Demo<\/h2>\n\n\n\n\t\t<figure class=\"wp-block-jetpack-videopress jetpack-videopress-player\" style=\"\" >\n\t\t\t<div class=\"jetpack-videopress-player__wrapper\"> <div class=\"jetpack-video-wrapper\"><iframe title=\"VideoPress Video Player\" aria-label='VideoPress Video Player' width='720' height='540' src='https:\/\/videopress.com\/embed\/ovXH13lz?cover=1&amp;autoPlay=1&amp;controls=1&amp;loop=1&amp;muted=1&amp;persistVolume=0&amp;playsinline=0&amp;preloadContent=metadata&amp;useAverageColor=1&amp;hd=0' frameborder='0' allowfullscreen data-resize-to-parent=\"true\" allow='clipboard-write'><\/iframe><script src='https:\/\/v0.wordpress.com\/js\/next\/videopress-iframe.js?m=1725245713'><\/script><\/div><\/div>\n\t\t\t\n\t\t\t\n\t\t<\/figure>\n\t\t\n\n\n<h2 class=\"wp-block-heading\">Full example code<\/h2>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#000000;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span role=\"button\" tabindex=\"0\" data-code=\"struct Example036: View {\n\n    @State var spacing: CGFloat = 0.0\n    var body: some View {\n        VStack(spacing: 24) {\n            Slider(value: $spacing,\n                   in: 0...100,\n                   minimumValueLabel: Image(systemName: &quot;square.fill&quot;),\n                   maximumValueLabel: Image(systemName: &quot;square.stack.3d.down.forward.fill&quot;),\n                   label: {\n                Text(&quot;Spacing&quot;)\n            })\n            .frame(width: 300)\n\n            HStack {\n\n                \/\/ 1. Space views evenly in the ZStack. Spacing is controlled by the parent ZStack\n                ZStack(spacing: spacing \/ 3) {\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepRed)\n                        .frame(width: 200, height: 200)\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepGreen)\n                        .frame(width: 150, height: 150)\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepBlue)\n                        .frame(width: 100, height: 100)\n                }\n                .frame(depth: spacing)\n\n\n                \/\/ 2. Use Spacers to fill all available space in the ZStack\n                ZStack() {\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepRed)\n                        .frame(width: 200, height: 200)\n\n                    Spacer() \/\/ this spaces pushes the first view all the way to the back\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepGreen)\n                        .frame(width: 150, height: 150)\n\n                    Spacer() \/\/ this spacer pushes the last view all the way to the front\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepBlue)\n                        .frame(width: 100, height: 100)\n                }\n                .frame(depth: spacing)\n\n                \/\/ 3. Each child view has a depth value that takes up 1\/3 of the ZStack depth\n                ZStack() {\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepRed)\n                        .frame(width: 200, height: 200)\n                        .frame(depth: spacing \/ 3)\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepGreen)\n                        .frame(width: 150, height: 150)\n                        .frame(depth: spacing \/ 3)\n\n                    RoundedRectangle(cornerRadius: 12.0)\n                        .foregroundStyle(.stepBlue)\n                        .frame(width: 100, height: 100)\n                        .frame(depth: spacing \/ 3)\n                }\n                .frame(depth: spacing)\n\n            }\n\n            .padding()\n        }\n    }\n}\" style=\"color:#000000;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki light-plus\" style=\"background-color: #FFFFFF\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #0000FF\">struct<\/span><span style=\"color: #000000\"> <\/span><span style=\"color: #267F99\">Example036<\/span><span style=\"color: #000000\">: View {<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #0000FF\">@State<\/span><span style=\"color: #000000\"> <\/span><span style=\"color: #0000FF\">var<\/span><span style=\"color: #000000\"> spacing: CGFloat = <\/span><span style=\"color: #098658\">0.0<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    <\/span><span style=\"color: #0000FF\">var<\/span><span style=\"color: #000000\"> body: some View {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        <\/span><span style=\"color: #795E26\">VStack<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">spacing<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">24<\/span><span style=\"color: #000000\">) {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            <\/span><span style=\"color: #795E26\">Slider<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">value<\/span><span style=\"color: #000000\">: $spacing,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                   <\/span><span style=\"color: #795E26\">in<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">0<\/span><span style=\"color: #000000\">...<\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                   <\/span><span style=\"color: #795E26\">minimumValueLabel<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #795E26\">Image<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">systemName<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #A31515\">&quot;square.fill&quot;<\/span><span style=\"color: #000000\">),<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                   <\/span><span style=\"color: #795E26\">maximumValueLabel<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #795E26\">Image<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">systemName<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #A31515\">&quot;square.stack.3d.down.forward.fill&quot;<\/span><span style=\"color: #000000\">),<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                   <\/span><span style=\"color: #795E26\">label<\/span><span style=\"color: #000000\">: {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #795E26\">Text<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #A31515\">&quot;Spacing&quot;<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            })<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">300<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            HStack {<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #008000\">\/\/ 1. Space views evenly in the ZStack. Spacing is controlled by the parent ZStack<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">spacing<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">) {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #008000\">\/\/ 2. Use Spacers to fill all available space in the ZStack<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">() {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">Spacer<\/span><span style=\"color: #000000\">() <\/span><span style=\"color: #008000\">\/\/ this spaces pushes the first view all the way to the back<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">Spacer<\/span><span style=\"color: #000000\">() <\/span><span style=\"color: #008000\">\/\/ this spacer pushes the last view all the way to the front<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #008000\">\/\/ 3. Each child view has a depth value that takes up 1\/3 of the ZStack depth<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                <\/span><span style=\"color: #795E26\">ZStack<\/span><span style=\"color: #000000\">() {<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepRed<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">200<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepGreen<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">150<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                    <\/span><span style=\"color: #795E26\">RoundedRectangle<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">cornerRadius<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">12.0<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">foregroundStyle<\/span><span style=\"color: #000000\">(.<\/span><span style=\"color: #001080\">stepBlue<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">width<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">, <\/span><span style=\"color: #795E26\">height<\/span><span style=\"color: #000000\">: <\/span><span style=\"color: #098658\">100<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                        .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing \/ <\/span><span style=\"color: #098658\">3<\/span><span style=\"color: #000000\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">                .<\/span><span style=\"color: #795E26\">frame<\/span><span style=\"color: #000000\">(<\/span><span style=\"color: #795E26\">depth<\/span><span style=\"color: #000000\">: spacing)<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            }<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #000000\">            .<\/span><span style=\"color: #795E26\">padding<\/span><span style=\"color: #000000\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">        }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">    }<\/span><\/span>\n<span class=\"line\"><span style=\"color: #000000\">}<\/span><\/span><\/code><\/pre><\/div>\n","protected":false},"excerpt":{"rendered":"<p>ZStack is a core container view in SwiftUI, but it really shines in visionOS where depth is real.<\/p>\n","protected":false},"author":93705089,"featured_media":2286,"comment_status":"open","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"_kad_blocks_custom_css":"","_kad_blocks_head_custom_js":"","_kad_blocks_body_custom_js":"","_kad_blocks_footer_custom_js":"","advanced_seo_description":"","jetpack_seo_html_title":"","jetpack_seo_noindex":false,"_EventAllDay":false,"_EventTimezone":"","_EventStartDate":"","_EventEndDate":"","_EventStartDateUTC":"","_EventEndDateUTC":"","_EventShowMap":false,"_EventShowMapLink":false,"_EventURL":"","_EventCost":"","_EventCostDescription":"","_EventCurrencySymbol":"","_EventCurrencyCode":"","_EventCurrencyPosition":"","_EventDateTimeSeparator":"","_EventTimeRangeSeparator":"","_EventOrganizerID":[],"_EventVenueID":[],"_OrganizerEmail":"","_OrganizerPhone":"","_OrganizerWebsite":"","_VenueAddress":"","_VenueCity":"","_VenueCountry":"","_VenueProvince":"","_VenueState":"","_VenueZip":"","_VenuePhone":"","_VenueURL":"","_VenueStateProvince":"","_VenueLat":"","_VenueLng":"","_VenueShowMap":false,"_VenueShowMapLink":false,"_kadence_starter_templates_imported_post":false,"_kad_post_transparent":"","_kad_post_title":"","_kad_post_layout":"","_kad_post_sidebar_id":"","_kad_post_content_style":"","_kad_post_vertical_padding":"","_kad_post_feature":"","_kad_post_feature_position":"","_kad_post_header":false,"_kad_post_footer":false,"_kad_post_classname":"","_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":true,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","enabled":false},"version":2},"_wpas_customize_per_network":false,"jetpack_post_was_ever_published":false},"categories":[1365],"tags":[],"class_list":["post-2284","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-example-code"],"jetpack_publicize_connections":[],"taxonomy_info":{"category":[{"value":1365,"label":"Example Code"}]},"featured_image_src_large":["https:\/\/i0.wp.com\/stepinto.vision\/wp-content\/uploads\/2025\/01\/step-example-036-01.jpeg?fit=1024%2C768&ssl=1",1024,768,true],"author_info":{"display_name":"Joseph Simpson","author_link":"https:\/\/stepinto.vision\/author\/vrhermit\/"},"comment_info":0,"category_info":[{"term_id":1365,"name":"Example Code","slug":"example-code","term_group":0,"term_taxonomy_id":11,"taxonomy":"category","description":"Code snippets and examples of using common APIs throughout visionOS development","parent":0,"count":187,"filter":"raw","cat_ID":1365,"category_count":187,"category_description":"Code snippets and examples of using common APIs throughout visionOS development","cat_name":"Example Code","category_nicename":"example-code","category_parent":0}],"tag_info":false,"jetpack_featured_media_url":"https:\/\/i0.wp.com\/stepinto.vision\/wp-content\/uploads\/2025\/01\/step-example-036-01.jpeg?fit=2732%2C2048&ssl=1","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/posts\/2284","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/users\/93705089"}],"replies":[{"embeddable":true,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/comments?post=2284"}],"version-history":[{"count":10,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/posts\/2284\/revisions"}],"predecessor-version":[{"id":2298,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/posts\/2284\/revisions\/2298"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/media\/2286"}],"wp:attachment":[{"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/media?parent=2284"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/categories?post=2284"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/stepinto.vision\/wp-json\/wp\/v2\/tags?post=2284"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}