2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【Unity】UnityでVisionProのVolume(Bounded)コンテンツのxボタンは閉じるボタンではなかった件【VisionPro】

Posted at

Graffity でVisionPro + Unity でコンテンツ開発・技術研究を行っているcovaです。

今回はVisionPro の固有UIである VolumeApp(Bounded Volume) の独特の性質について解説します。

TL;DR

  • 開発用ツールである PlayToDevice 経由だと xボタンでVolumeを非表示にすると Closed ステートになる
  • 実機で動かすと Background のステート止まり。Closed ステートにはならない→CloseボタンではなくBackgroundボタン
    • VolumeCameraの OpenWindow/CloseWindow をコールしても何も起きない
    • Background は一旦ホームに戻って再度アプリを開くと自動的にForeground になる
      • 介入不能
  • Background ステートやClosed ステートになってもGameObject 自体はHierarchy上に残っているので注意

背景

VisionPro には Window モード と Volume モード, Immersive Space モードがあります。

05_mode.png

そしてWindow/Volume モードのコンテンツはOS側が提供するUIを操作することで現実での表示位置を制御する事ができます。
(UnityでいうところのBounded App)

06_mode_unity.png

また、xボタンを選択する事で、そのアプリを 閉じるような 操作ができます。

IMG_0157.PNG

後述しますが 一般的なUIのバツボタンと同じ挙動 (Quit) ではないので要注意です

この 閉じるような 挙動をする xボタンですが、Unityで開発する上ではかなり厄介な特性があったので、注意喚起も兼ねて紹介します

検証環境

項目 version等
Unity Unity6 (Unity6000.0.23f1)
PolySpatial 2.0.4
Xcode 16.0

xボタンの挙動について

Volume のState 定義について

公式Document にも記載されている通り、Volume は5つのStateが定義されています。

State.png

基本的には Opened → Resized→ ... → Backgrounded → Closed という流れだと推測できます。
ただし、後述の通り、xボタンを押しても 必ずしもClosedにはならない という挙動をするのがvisionOSです。

しかもClosed になったりならなかったりするので開発する上でも非常に扱いが難しいため、実際の挙動について調査してみました。

調査方法

Unity のVolumeCamera がついているObjectに対して以下のScriptを貼り付けてLogを調査します。

WindowEventObserver.cs

using Unity.PolySpatial;
using UnityEngine;

[RequireComponent(typeof(VolumeCamera))]
public class WindowEventObserver : MonoBehaviour
{
    [SerializeField] private VolumeCamera _volumeCamera;

    private void Reset()
    {
        TryGetComponent(out _volumeCamera);
    }

    // Start is called once before the first execution of Update after the MonoBehaviour is created
    void Start()
    {
        _volumeCamera.WindowStateChanged.AddListener(this.OnWindowStateChanged);
    }

    private void OnDestroy()
    {
        _volumeCamera?.WindowStateChanged.RemoveListener(this.OnWindowStateChanged);
    }

    private void OnWindowStateChanged(VolumeCamera cam, VolumeCamera.WindowState state)
    {
        Debug.Log($"OnWindowStateChanged: {state.WindowEvent}");
    }
}

Unityでの利用用途について

Unity での開発では使用する状況によって挙動が異なります
一つ目は想定アプリモードです。

  1. Volume App (Bounded Volumeコンテンツ) の場合
  2. Immersive App (Unbounded Volumeコンテンツ) 上で表示する Volume(Bounded)コンテンツの場合

また、いわゆるDebug モードなのか、実機なのかでも異なります。
具体的には

  1. PlayToDevice を用いてUnityEditor とVisionPro 実機を通信させてリアルタイムデバッグする場合
  2. VisionPro 実機にアプリを入れて確認する場合

という形です。

つまりは

ユースケース \ Mode VolumeApp Volume on ImmersiveApp
PlayToDevice
実機にInstall

といった表にまとめられます。

1. PlayToDevice で Volume mode

PlayToDevice ではUnity のConsole Window でLogを確認できるので
Logを確認しました。

02_Volume_P2D.png

上記を見ると、問題なくClosed ステートに切り替わっていることがわかります

2. PlayToDevice で Volume on ImmersiveApp mode

こちらも同様にログを確認します
01_MR_Volume_P2D.png

こちらも先ほど同様、問題なくClosed ステートに切り替わっていることがわかります

3. 実機にInstall で Volume mode

今度は実機Install なのでXcode 側に表示されるLog を確認します。
03_Volume_install.png

ちょっと長いので抜粋をすると Opend→Focused→Backgrounded までは表示されていますがClosed 判定がありませんでした。

また、一度Home画面に戻り、再度アプリを立ち上げたところ Focused になり閉じたはずのVolumeが再表示されました。

4. 実機にInstall で Volume on ImmersiveApp mode

こちらも同様にXcode のLogを確認します。
04_MR_Volume_install.png

結果は先ほど同様、やはりClosed のStateは確認されませんでした。
また、Homeに戻る→再度アプリを選択すると Immersive View は再度表示されませんでしたが消したはずのVolumeのみ再度表示されました。

StateもFocusedになることから 実機でのxボタンCloseボタン ではなく Backgroundedボタン ということがわかります。

ちなみに

APIを試してみたところ

VolumeCameraには OpenWindow()CloseWindow() というAPIがあります。
08_api.png

こちらをBackgrounded な状態で呼び出したり、強制的に CloseWindow()→OpenWindow() を呼ぶことで
ImmersiveSpace 上に自動的に再表示させようとしましたがダメでした。

どうやらOS側でBackgroundedになったUIは再度Foregdounded(Focused)になるタイミングで再表示させるようです。

Unity 上の挙動

xボタンを押してもOS側で非表示にしているだけで、Hierarchy上にはGameObjectはのこっています。
そのため、xボタンでStateがBackgrounded になったら自前でDestroy()をコールしないと存続しっぱなしになります。

開発者側で無理やり制御したい場合はBackgroundedStateになったらDestroyしてUIObjectがNullなら再度生成というフローを取るしかなさそうです(ImmersiveSpace 上のVolume コンテンツ表示のみ可能)

まとめ

ユースケース \ Mode VolumeApp Volume on ImmersiveApp
PlayToDevice Closeになる Closeになる
実機にInstall Backgrounded で止まる Backgrounded で止まる

ということで結論としては

xボタンは Closeボタンではなく Backgroundedボタン

ということになりそうです。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?