HTC Vive XR Eliteの記事を書こう
書こうと思った動機は、
- 公式のマニュアルの情報がほぼゼロ
- 世間にも情報がない。
- トラブっても対処方法が全く分からん。
- 公式通り試してもまともに開発できない。
という経緯があり、触ってはイラっとしてほったらかしていた。
くそ高いハードウェアを使えない状態で死蔵させておくのはもったいなさすぎるというところ。
現時点での到達点はUE5.3でBuildしたXRアプリで真っ暗な画面が立ち上がった。
前提
UE5.3のAndroid環境設定は複雑で、エラーが発生した場合の修正は容易ではありません。
「なんかわからんけど、動かへん」場合のおススメは、AndroidStudio、SDK、NDKをすべてアンインストール、フォルダを削除して、UE5.xのエンジンも削除して再インストールすることです。
頑張るのは基本的に時間の無駄と思われます。
一番失敗しそうなのが環境設定ですが、自動的にバッチで設定してくれるらしく、すべて削除してからバッチを実行するのがよさそうですね。
トラブル その1 Platform Android is not a valid platform to build
NDKが複数入っていると正常に動作しない場合がある。
UnrealEngine5.3ではNDKは25bと記載されているが。インストール時には25bとは記載されておらず、複数インストールされていたため新しい方を指定してエラーが発生していた(私の環境では25b=25.1.8937393でした)。
AndroidStudioから削除した。
トラブル その2 minSdkVersion is higher than Android version
LogPlayLevel: UAT: Running: C:\Users\XXXXX\AppData\Local\Android\Sdk\platform-tools\adb.exe -s FA3373800154 install "K:\UE5\ViveOpenXRGame\Binaries/Android\ViveOpenXRGame-Android-Shipping-arm64.apk"
LogPlayLevel: UAT: adb: failed to install K:\UE5\ViveOpenXRGame\Binaries/Android\ViveOpenXRGame-Android-Shipping-arm64.apk: Failure [INSTALL_FAILED_OLDER_SDK: Failed parse during installPackageLI: /data/app/vmdl1053193675.tmp/base.apk (at Binary XML file line #8): Requires newer sdk version #33 (current version is #29)]
LogPlayLevel: UAT: Performing Streamed Install
LogPlayLevel: UAT: Took 1.44s to run adb.exe, ExitCode=1
LogPlayLevel: UAT: minSdkVersion is higher than Android version installed on device, possibly due to NDK API Level
LogPlayLevel: UAT: Installation of apk 'K:\UE5\ViveOpenXRGame\Binaries/Android\ViveOpenXRGame-Android-Shipping-arm64.apk' failed: [INSTALL_FAILED_OLDER_SDK: Failed parse during installPackageLI: /data/app/vmdl1053193675.tmp/base.apk (at Binary XML file line #8): Requires newer sdk version #33 (current version is #29)]
LogPlayLevel: UAT: Performing Streamed Install
UE5.3(Viveのサンプルが存在する最新バージョン)のSDKは推奨33。シッピングする最小のターゲットSDKは30のようだ。
が、Viveで設定されているのは ターゲット32、min 21のようだ。これをUE5 の推奨に合わせたのがまずかったようなので、元に戻す。(この値を何にするのが適切なのかViveのマニュアルにはないのだが…)
トラブル その3 Failed to open descriptor file
これはどうもUE5側のエラーらしいが、Viveで見たときにエラーが見えないのはどうにかしてほしい…
UE5.2 ではAndroid FileServerを無効にしたところなおったという報告を見たので試すが、これでは対処できなかった。
よく分からんが、
- Install LocationをAutoへ
- Packange game data inside .apk?
をキャプチャのように変更してエラーは出なくなった
ファイル権限がないので、追加すればよいという情報も見かけたが、コマンドが通らず断念。
>adb shell appops set --uid com.epicgames.ViveOpenXRGame MANAGE_EXTERNAL_STORAGE allow
Error: Unknown operation string: MANAGE_EXTERNAL_STORAGE
トラブル その4
起動後画面が真っ暗。
2023年10月09日 時点で対処不明。
2023年10月10日 ファームをUpdateしたことで解決!