0
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?

try! Swift Tokyoのライブ翻訳アプリのApple Vision Pro版を改善してみる

Last updated at Posted at 2025-04-19

先週、try! Swift Tokyo 2025が開催されました。

このイベントではライブ翻訳アプリが活用されました。各参加者が自身のデバイスにアプリをインストールして利用します。FlittoというサービスのSDKをtry! Swift公式アプリに組み込む形で導入されました。

スマホ版のビデオ

この公式アプリにはApple Vision Pro版があります。

Apple Vision Pro版のApp Storeのスクショ

ライブ翻訳機能はApple Vision Pro版でも利用できます。

Apple Vision Pro版のライブ翻訳のスクショ

実際に私がApple Vision Pro版でライブ翻訳機能を会場で利用してみました。
(iOS版と異なり)翻訳を見るために頭を下げる必要が無いので、非常に快適でした。

Apple Vision Pro版のライブ翻訳のビデオ

ただ、「Apple Vision Proアプリ」としては、いくつか改善する余地がありそうでした。
本記事では、Apple Vision Proの特性を活かす改善案を3つ挙げてみます。

3つの改善案

① 独立したウインドウとしてポップアウトできるようにする

visionOSでは、macOSのようにマルチウインドウを活用できます。
YouTube LiveのようにチャットUIを独立したウインドウとしてポップアウトできるようにすると良いでしょう。

YouTubeLiveのようなウインドウポップアウトのスクショ

これらのメリットがあります。

  • ユーザーがウインドウを配置しやすくなる。
  • ライブ翻訳を表示しながら、メインウインドウでタイムテーブルを確認することができる。
  • 複数の言語を見比べたり、最新情報を表示しつつ遡りやすくしたりできる。

ウインドウポップアウトのスクショ

WindowGroup(id: "liveTranslationOnly") {
  AppView(...)
}
.defaultWindowPlacement { _, context in
  .init(.trailing(context.windows.first!))
}
@Environment(\.openWindow) var openWindow

* * *

Button("Detach window") {
  self.openWindow(id: "liveTranslationOnly")
}

② 視線に自動的に反応するUIを非表示にする

ユーザーはライブ翻訳を利用する時に、ステージと翻訳ウインドウの間を繰り返し視線を移動させます。その際にvisionOSアプリに「視線に反応するUI」があるとユーザーにストレスを与えます。そのため、ライブ翻訳を表示している間は「視線に反応するUI」を非表示にした方が良いでしょう。
try! Swiftアプリにおいては「ウインドウバー」と「Tabバー」がその対象です。

視線に反応するウインドウバーの動画

視線に反応するTabバーの動画

ウインドウバー

ウインドウの下部に白いバーが表示されます。ユーザーはこれでウインドウの位置を変更できます。このウインドウバーは視線に反応してしまいます。

ウインドウバー非表示の比較のスクショ

以下のSwiftUIのコードでウインドウバーを非表示にできます。

@State var isWindowBarHidden: Bool = false

* * *

Toggle("Hide window bar", isOn: self.$isWindowBarHidden)
  .persistentSystemOverlays(self.isWindowBarHidden ? .hidden : .visible)

Tabバー

Tabバーも視線に反応してしまいます。

Tabバー非表示の比較のスクショ

以下のSwiftUIのコードでTabバーを非表示にできます。

@State var isTabBarHidden: Bool = false

* * *

Toggle("Hide tab bar", isOn: self.$isTabBarHidden)
  .toolbar(self.isTabBarHidden ? .hidden : .visible,
           for: .tabBar)

もしくは、アプローチ①のウインドウをポップアウトすることでも解決できます。

③ ガラスバックグラウンドを非表示にする

visionOSのウインドウにはガラスのようなバックグラウンドがあります。
「ユーザーの好み」や「会場の環境」次第では、このガラス調のバックグラウンドを透明にした方が使いやすくなる場合もあるでしょう。
オプトインのオプションとして、このガラス調のバックグラウンドの透明度を変更できるようにすると良いと思います。

ガラスバックグラウンド非表示の比較のスクショ

WindowGroup(id: "liveTranslationOnly") {
  AppView(...)
}
.windowStyle(.plain)
@State var isTransparentBackground: Bool = false

* * *

.background {
  Color.clear
    .glassBackgroundEffect()
    .opacity(self.isTransparentBackground ? 0.1 : 1)
}

① + ② + ③

結果のビデオ

「フルスペースは駄目」

visionOSのアプリ構成にはウインドウとフルスペースの2種類があります。
ウインドウの場合、ユーザーは複数のアプリを同時に立ち上げることができます。
フルスペースの場合、アプリ設計の自由度は上がりますが、ユーザーは同時に1つのアプリしか起動できません。

スクリーンショット 2025-04-16 22.12.11.png

現在のtry! Swiftの公式アプリは、シンプルな単一ウインドウのvisionOSアプリです。

visionOSにおけるライブ翻訳機能はウインドウで提供した方が良いでしょう。フルスペースは適していないと思います。理由は以下の2点です。

  • ユーザーがライブ翻訳を利用する際に、他のアプリを同時に立ち上げる可能性があります。例えば、Safariで調べ物したり、ノートアプリでメモをしたりするかもしれません。
  • ライブ翻訳のウインドウの「ベストなポジション」や「ベストなサイズ」は、ユーザーの好みや会場の環境によってケースバイケースでしょう。そのため、それらの調整はユーザーに任せた方が良いでしょう。標準のウインドウであれば、それらが容易に実現できます。

余談。visionOSだけでなくiOSやmacOSでも改善すべきこと。

  • テキストが更新されるたびに、UIが頻繁に上下に動く挙動がストレスなので、あまり動かないように最適化する。
  • 段落のソートを逆にするオプトインオプションを追加する。
  • フォントサイズやフォントデザイン、フォントウェイト、テキストの色などを変更するオプトインオプションを追加する。
  • 「(翻訳されていない)オリジナルの書き起こし」を見たい。
  • 「(翻訳されていない)オリジナルの書き起こし」と「翻訳」を同時に見たい。

リンク

try! Swift Tokyo公式アプリ(App Store)

try! Swift Tokyo公式アプリのソースコード(GitHub)

try! Swift Tokyo公式サイト

Flitto公式サイト

ライブ翻訳サービス「Flitto Live Translation」の紹介ページ

私が開発したvisionOS向け置き時計アプリ「SpatialClock」

今回のtry! Swift Tokyo 2025で私が登壇したトークの動画

0
0
2

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
0
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?