プロダクト ニュース

Media3 1.9.0 - 新機能

所要時間: 6 分
Kristina Simakova
エンジニアリング マネージャー

Media3 1.9.0 がリリースされました。今回の最新リリースには、通常のバグ修正とパフォーマンスの改善に加えて、4 つの新しいモジュールまたは大幅に書き直されたモジュールが含まれています。

  • media3-inspector - 再生以外のメタデータとフレームを抽出
  • media3-ui-compose-material3 - わずか数ステップで基本的な Material3 Compose メディア UI を構築する
  • media3-cast - Cast とローカル再生間の切り替えを自動的に処理
  • media3-decoder-av1 - dav1d ライブラリに基づく書き換えられた拡張機能デコーダによる一貫した AV1 再生

また、PreloadManager にキャッシュ保存とメモリ管理の改善を追加し、いくつかの新しい ExoPlayerTransformerMediaSession の簡素化を提供しました。

また、このリリースでは、メディア編集をプレビューするための CompositionPlayer への試験運用版のアクセスも初めて提供されます。


詳細については、以下をお読みください。また、このリリースの変更点の概要については、リリースノートをご覧ください。

再生以外のメタデータとフレームを抽出

再生を開始せずにメディアを検査したい場合も多くあります。たとえば、含まれている形式や再生時間を確認したり、サムネイルを取得したりできます。

新しい media3-inspector モジュールでは、再生せずにメディアを検査するすべてのユーティリティが 1 か所にまとめられています。

  • MediaItem から再生時間、形式、静的メタデータを読み取るための MetadataRetriever
  • FrameExtractor: アイテムからフレームまたはサムネイルを取得します。
  • MediaExtractorCompat を Android プラットフォームの MediaExtractor クラスの直接の代替として使用して、ファイル内のサンプルに関する詳細情報を取得します。

MetadataRetrieverFrameExtractor はシンプルな AutoCloseable パターンに従います。詳しくは、新しいガイドページをご覧ください。

suspend fun extractThumbnail(mediaItem: MediaItem) {

  FrameExtractor.Builder(context, mediaItem).build().use {

    val thumbnail = frameExtractor.getThumbnail().await()

  } 

}

数ステップで基本的な Material3 Compose メディア UI を構築する

以前のリリースでは、Compose UI 要素と Player インスタンス間のコネクタコードの提供を開始しました。Media3 1.9.0 では、完全にスタイル設定された Material3 ボタンとコンテンツ要素を含む新しいモジュール media3-ui-compose-material3 を追加しました。これにより、スタイルをカスタマイズする柔軟性をすべて備えながら、数ステップでメディア UI を構築できます。独自の UI スタイルを構築する場合は、すべての更新と接続ロジックを処理するビルディング ブロックを使用できるため、UI 要素の設計に集中できます。Compose UI モジュールについては、拡張ガイドページをご覧ください。

また、組み込みのシークバー、PlayerView の完全な代替となるコンポーネント、字幕と広告の統合など、さらに多くの Compose コンポーネントの開発にも取り組んでいます。

@Composable
fun SimplePlayerUI(player: Player, modifier: Modifier = Modifier) {
  Column(modifier) {
    ContentFrame(player)  // Video surface and shutter logic
    Row (Modifier.align(Alignment.CenterHorizontally)) {                 
      SeekBackButton(player)   // Simple controls
      PlayPauseButton(player)
      SeekForwardButton(player)
    }
  }
}

 

image.png

すぐに使える要素を備えたシンプルな Compose プレーヤー UI

キャストとローカル再生間の切り替えを自動的に処理する

media3-cast モジュールの CastPlayer が書き直され、ローカル再生(ExoPlayer など)とリモートの Cast 再生間の切り替えが自動的に処理されるようになりました。

MediaSession を設定するときは、ExoPlayer の周りに CastPlayer を構築し、UI に MediaRouteButton を追加するだけで完了です。

// MediaSession setup with CastPlayer 

val exoPlayer = ExoPlayer.Builder(context).build()

val castPlayer = CastPlayer.Builder(context).setLocalPlayer(exoPlayer).build()

val session = MediaSession.Builder(context, castPlayer).build()

// MediaRouteButton in UI 

@Composable fun UIWithMediaRouteButton() {

  MediaRouteButton()

}
image.png

Media3 セッション デモアプリでの新しい CastPlayer の統合

dav1d ベースの書き換えられた拡張機能による一貫した AV1 再生

1.9.0 リリースには、人気の dav1d ライブラリに基づいて完全に書き直された AV1 拡張モジュールが含まれています。

すべての拡張デコーダ モジュールと同様に、関連するネイティブ コードを正しくバンドルするには、ソースからビルドする 必要があります。デコーダをバンドルすると、すべてのデバイスで一貫性と形式のサポートが提供されますが、デコードがプロセス内で実行されるため、信頼できるコンテンツに最適です。

キャッシュ保存とメモリ管理を PreloadManager に統合

PreloadManager もさらに改善されました。すでに、再生以外のメディアをメモリにプリロードし、必要に応じてプレーヤーにシームレスに渡すことが可能になっていました。パフォーマンスはかなり優れていましたが、誤ってプリロードしすぎてメモリ上限を超えないように注意する必要がありました。そこで、Media3 1.9.0 では、この作業を大幅に簡素化し、安定性を高める 2 つの機能が追加されました。

  1. キャッシュ保存のサポート - プリロードする範囲を定義する際に、プリロードされたアイテムのターゲット状態として PreloadStatus.specifiedRangeCached(0, 5000) を選択できるようになりました。これにより、指定した範囲がメモリに読み込まれるのではなく、ディスク上のキャッシュに追加されます。これにより、現在のアイテムから離れたアイテムがメモリを占有する必要がなくなるため、プリロードするアイテムの範囲を大幅に拡大できます。これには、DefaultPreloadManager.BuilderCache を設定する必要があります。
  2. 自動メモリ管理 - LoadControl インターフェースも更新し、プリロードのケースをより適切に処理できるようになりました。これにより、メモリ内のすべてのプリロード アイテムに明示的なメモリ上限を設定できるようになりました。デフォルトでは 144 MB ですが、DefaultLoadControl.Builder で上限を構成できます。DefaultPreloadManager は、上限に達するとプリロードを自動的に停止し、必要に応じて優先度の低いアイテムのメモリを自動的に解放します。

ExoPlayer の新しい簡素化されたデフォルトの動作に依存する

今回も、ExoPlayer に多くの改善が加えられています。以下にその一部をご紹介します。

  • ミュートとミュート解除 - setVolume メソッドはすでにありましたが、mute メソッドと unmute メソッドが追加され、自分で音量を追跡しなくても以前の音量を簡単に復元できるようになりました。
  • プレーヤーの停止検出 - コーデックの問題や設定ミスなどにより、プレーヤーがバッファリング状態や再生状態のまま進まなくなることがあります。ユーザーは不快に感じますが、アナリティクスにはこのような問題は表示されません。この問題をより明確にするため、プレーヤーが停止状態を検出すると StuckPlayerException が報告されるようになりました。
  • デフォルトでウェイクロック - 以前はウェイクロック管理はオプトインでしたが、バックグラウンドで実行中に再生の進行が大幅に遅れるエッジケースを見つけるのが困難でした。この機能はオプトアウトになったため、この点を心配する必要がなくなり、再生に関する手動のウェイクロック処理をすべて削除することもできます。
  • 字幕ボタンのロジックの設定を簡素化 - TrackSelectionParameters を「字幕のオン/オフを切り替える」に変更するのは意外と難しかったため、このユースケース用にシンプルなブール値 selectTextByDefault オプションを追加しました。

MediaSession でメディアボタンの設定を簡素化

これまで、Android Auto または WearOS のメディア通知ドロワーに表示するボタンの優先順位を定義するには、標準のプレーヤー メソッドをトリガーするだけであっても、カスタム コマンドとボタンを定義する必要がありました。

Media3 1.9.0 には、この処理を大幅に簡素化する新機能が追加されました。標準のプレーヤー コマンドでメディアボタンの設定を定義できるようになり、カスタム コマンド処理は一切必要ありません。

session.setMediaButtonPreferences(listOf(
    CommandButton.Builder(CommandButton.ICON_FAST_FORWARD) // choose an icon
      .setDisplayName(R.string.skip_forward)
      .setPlayerCommand(Player.COMMAND_SEEK_FORWARD) // choose an action 
      .build()
))
image.png

早送りボタン付きのメディアボタンの設定

リアルタイム プレビュー用の CompositionPlayer

1.9.0 リリースでは、新しい @ExperimentalApi アノテーションの下に CompositionPlayer が導入されています。このアノテーションは、この機能が試験運用版として利用可能であり、現在も開発中であることを示します。

CompositionPlayer は、メディア編集のリアルタイム プレビュー用に設計された Media3 編集 API の新しいコンポーネントです。使い慣れた Media3 Player インターフェースをベースに構築された CompositionPlayer を使用すると、ユーザーはエクスポート プロセスを確定する前に変更内容を確認できます。エクスポート用に Transformer に渡すのと同じ Composition オブジェクトを使用し、プレビューとエクスポートのデータモデルを統合することで編集ワークフローを効率化します。

CompositionPlayer の使用を開始し、フィードバックをお寄せください。詳細については、今後の投稿やドキュメントの更新にご注目ください。

Transformer のデフォルトの muxer として InAppMuxer を使用

Transformer は、メディア コンテナ ファイルの書き込みに InAppMp4Muxer をデフォルトの多重化ツールとして使用するようになりました。内部的には、InAppMp4Muxer は Media3 の Muxer モジュールに依存しており、すべての API バージョンで一貫した動作を提供します。

Transformer はデフォルトで Android プラットフォームの MediaMuxer を使用しなくなりましたが、ユースケースで必要な場合は、setMuxerFactory を介して FrameworkMuxer.Factory を提供できます。

新しい速度調整 API

1.9.0 リリースでは、メディア編集用の速度調整 API が簡素化されました。EditedMediaItem.Builder に速度を制御する新しいメソッドが直接導入され、API がより直感的になりました。EditedMediaItem.BuildersetSpeed(SpeedProvider provider) を呼び出すことで、クリップの速度を変更できるようになりました。

val speedProvider = object : SpeedProvider {
    override fun getSpeed(presentationTimeUs: Long): Float {
        return speed
    }

    override fun getNextSpeedChangeTimeUs(timeUs: Long): Long {
        return C.TIME_UNSET
    }
}

EditedMediaItem speedEffectItem = EditedMediaItem.Builder(mediaItem)
    .setSpeed(speedProvider)
    .build()

この新しいアプローチは、以前の Effects#createExperimentalSpeedChangingEffects() の使用方法に代わるものです。Effects#createExperimentalSpeedChangingEffects() は非推奨となり、今後のリリースで削除される予定です。

EditedMediaItemSequence のトラック タイプを導入

1.9.0 リリースでは、EditedMediaItemSequence でシーケンスの作成時に必要な出力トラック タイプを指定する必要があります。この変更により、コンポジション全体でトラック処理がより明確かつ堅牢になります。

これは、一連のトラックタイプ(C.TRACK_TYPE_AUDIO, C.TRACK_TYPE_VIDEO など)を受け取る新しい EditedMediaItemSequence.Builder コンストラクタを介して行われます。

作成を簡素化するため、新しい静的コンビニエンス メソッドを追加しました。

  • EditedMediaItemSequence.withAudioFrom(List<EditedMediaItem>)
  • EditedMediaItemSequence.withVideoFrom(List<EditedMediaItem>)
  • EditedMediaItemSequence.withAudioAndVideoFrom(List<EditedMediaItem>)

より明確で信頼性の高いシーケンス定義のために、新しいコンストラクタまたはコンビニエンス メソッドに移行することをおすすめします。

動画のみのシーケンスを作成する例:

EditedMediaItemSequence videoOnlySequence =
    EditedMediaItemSequence.Builder(setOf(C.TRACK_TYPE_VIDEO))
        .addItem(editedMediaItem)
        .build()

バグが発生した場合や、ご質問や機能リクエストがある場合は、Media3 Issue Tracker からお問い合わせください。皆様からのフィードバックをお待ちしております。

作成者:

続きを読む