90
93

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

これからは動画だ!と考えているけどどうすればいいかわからないAndroiderへ

Last updated at Posted at 2015-10-29

動画を取り扱うアプリが増えてきて、ライブラリや開発情報が増えてきました。自分のために動画機能開発の導入部分を備忘録として残しつつ、Androidの動画機能開発者に貢献に役立つといいなぁ。逆に動画なんていらないだろという人にも、動画コンテンツを配信する興味を持ってもらうことも期待しています。

現状Qiitaでは、ExoPlayerというキーワードを使った記事が4つしかヒットしないので、もっと増えていけば心理的導入負担が少し減るかもしれないです。

動画というコンテンツの良さを自身の開発環境で考えてみる

人間はより短い時間で大量かつ良質の情報を消費、収集、ストックできることに利益を感じます。バイラルメディアが叩かれる昨今だけど、人はより冗長な情報を削いだ情報や適度にまとめられた密度の高い二次情報を欲しがっています。バイラルメディアのいいねが伸びることやGithubのAwesomeレポジトリのスター数を見れば一目瞭然です。

動画は相手に短時間に伝える情報が多く、漫画がアニメになると途端に面白くなるのは伝わらなかったニュアンスが急に伝わるからなのではないでしょうか。ユーザーの面白い体験、伝えたいメッセージなど今まではテキストや写真で伝わらなかったものが伝わる。そんな良さが動画にはあるはずです。サービスにとって「本当に伝えたい何か」を動画にするともしかしたらよくなるかもしれないですね。

  • 登録画面は動画にするとイメージがわくかも
  • チュートリアルは動画のほうがわかるかも
  • 料理の手順は動画のほうが一瞬でわかるかも
  • オークション出品物の使用感は動画のほうがわかるかも
  • 宿泊地の雰囲気は動画のほうがわかるかも

こんな風に一度考えてみてユーザーが本当に嬉しいものを作れたらいいです。

自分の環境に適した動画機能は何か見極める

動画の導入が進むことを願う記事だが、とりあえず動画にする!というのはちょっと待って、冷静に本当に動画であるべきかどうか考えましょう。それだけ動画はプロダクトの印象を変えるし、そこにかかるコストは割と大きいです。

  • コンテンツの作成者と消費者に明確な線引きがある動画の提供(テレビ、huluなど)
    • ストリーミング、HLSなどによる再生が必要
  • 誰でも気軽に動画を投稿、閲覧できるサービスの提供(Youtube、ニコ動、Amebaなど)
    • 投稿、再生が必要
  • ユーザーが映像作品としての動画を残していく良さを提供(Instagram、Mixchannelなど)
    • 投稿、編集、保存、再生が必要

動画機能を持つ参考アプリ

Instagram

insta_1.png insta_2.png

インスタグラムでは、撮影からエフェクトをかけて切り取りなどの編集も可能です。サムネイルを選択できるようになっているのは動画を作品として残すアプリにはマストかもしれないです。

Boomerang

boomerang.png

インスタグラムが出した1秒のループ動画を撮影可能なアプリ。Facebookへの投稿もバッチリです。現状、動画の編集はできませんが、できることの制約が逆にアプリの良さになっています。ユーザーの操作も非常に簡単です。

Ameba

ameba.png

Amebaブログの投稿が可能なプラットフォームアプリ。ブログ投稿時に1分以内へ切り取り可能になっています。

MixChannel

mix_1.png mix_3.png

主に中高生のカップルを対象とした動画共有SNSです。画面をタッチしている間に撮影し、それを繰り返して繋げていき一つの動画を完成させるようなデザインになっています。またサムネイル選択も0.01秒くらいのコマで調節可能です。

vine

vine.png

こちらも6秒以内の短い動画を撮影し投稿できるSNSサービス。動画の編集は切り取りに対応しています。

TwitterやFacebook

twitter.png facebook.png

この二つに関しては基本的な、撮影、投稿のみの機能になっています。

InstagramがAndroidのライブラリとか公開してくれたら楽しそうな気がする

Instagramの公開レポジトリの中にAndroidなものはない…これは結構悲しい。
素晴らしいノウハウがあるはずなので、是非ともAndroidコミュニティの活性化を手伝ってもらいたい。
ちなみに、僕はInstagramのAndroid betaテスターになっていて、誰でもここから参加できるのでおすすめです。時には起動した瞬間に落ちるバグなどもあったりしましたが、活発に更新されていて面白いのです。

実装やライブラリについて

導入記事なので実装に関しては詳しく書きません。詳しいことは公式のドキュメントを読むかデモアプリのコードを読むのが一番です。

再生の実装の注意点

動画の再生にはExoPlayer

ExoPlayerはGoogleI/Oの2014で紹介されていて、スタンダードになっているライブラリです。豊富なサンプルがついて実装の参考になると思います。メンテナンスを行っているのがなんと一人なので、みんなでバグを見つけてPRを出していくのが良さそうです。また、仕様変更がversionによって大きいので、イシューやリリースノートはこまめに確認したほうが良さそうです。

ローカルやURL先の動画を再生するにはここの以下の部分でプレイヤーを作成し、プレイヤーをコントロールするだけで可能です。

@Override
public void buildRenderers(DemoPlayer player) {
    Allocator allocator = new DefaultAllocator(BUFFER_SEGMENT_SIZE);

    // Build the video and audio renderers.
    DefaultBandwidthMeter bandwidthMeter = new DefaultBandwidthMeter(player.getMainHandler(),null);
    DataSource dataSource = new DefaultUriDataSource(context, bandwidthMeter, userAgent);
    ExtractorSampleSource sampleSource = new ExtractorSampleSource(uri, dataSource, allocator,BUFFER_SEGMENT_COUNT * BUFFER_SEGMENT_SIZE);
    MediaCodecVideoTrackRenderer videoRenderer = new MediaCodecVideoTrackRenderer(context,sampleSource, MediaCodec.VIDEO_SCALING_MODE_SCALE_TO_FIT, 5000, player.getMainHandler(),player, 50);
    MediaCodecAudioTrackRenderer audioRenderer = new MediaCodecAudioTrackRenderer(sampleSource,null, true, player.getMainHandler(), player, AudioCapabilities.getCapabilities(context));
    TrackRenderer textRenderer = new TextTrackRenderer(sampleSource, player,player.getMainHandler().getLooper());

    // Invoke the callback.
    TrackRenderer[] renderers = new TrackRenderer[DemoPlayer.RENDERER_COUNT];
    renderers[DemoPlayer.TYPE_VIDEO] = videoRenderer;
    renderers[DemoPlayer.TYPE_AUDIO] = audioRenderer;
    renderers[DemoPlayer.TYPE_TEXT] = textRenderer;
    player.onRenderers(renderers, bandwidthMeter);
}

ExoPlayer最大の注意は

ExoPlayer’s standard audio and video components rely on Android’s MediaCodec API, which was released in Android 4.1 (API level 16). Hence they do not work on earlier versions of Android.

なので、 API level 16以上でないと使えないこと です。古い端末のユーザーがいるサービスでは判定処理が必須になります。基本的な再生に関して日本語で書かれているドキュメントはこちらです。

アプリとSurfaceViewの相性が悪ければexoplayer-textureview

特に、SurfaceViewは回転などで再生がうまくいかなかったりするので、横画面での使用や編集時の回転などを考慮する場合に役立つと思います。内部の実装もとても参考になります。ですが、

This library is experimental. API and all codes will be changed without notice

と書いてあるように、APIに大きな変更が加わる可能性があるのでご注意ください。

対応形式

Androidは最近の端末ではmp4形式で保存されているのがほとんどだと思いますが、それ以外にも対応されています。詳しくはExoPlayer#SampleSource - Developer guideを参照してください。

編集機能の実装時の問題

動画の切り取りにはmp4parserを使うと良いでしょう。一年以上前の記事ですが、日本語であれば[Android Tips] mp4parser を使って動画ファイルを編集する | Developers.IOという記事があります。

基本的にここでは切り取りにmp4parserを使うことを考えているので、その他の形式については別途調べる必要があります。

ファイルサイズ

動画のサイズはピクセル数によりますが、Google Photoなどでいろんな端末から共有されたデータは1時間以上のものがある可能性もあります。動画のファイルサイズでの指定や、以下のように動画の時間を取得して、適切な長さの動画のみを編集対象にするのも一つの手です。

int duration = MediaPlayer.create(context, uri).getDuration();

一時ファイルをどうするか

動画のアップロードは時間がかかります。もしネットワーク環境が悪く失敗した場合などを考慮して、ファイルの一時保存、アップロード成功時の一時データ削除などを考えるべきだと思います。特に編集を行うアプリの場合、 「時間をかけて作った動画が一度失敗したら消えた… :scream_cat: みたいなのはユーザーが萎えます。

編集画面のレイアウト

ここは独自実装になります。サンプルライブラリも見当たらないので作成中です。近日公開。動画にエフェクトをかけるならGPUImageのAndroid版が良いでしょう。

動画に関連するライブラリですが、あまり種類は知りません。他にもあれば是非教えてもらいたいです!

最後に

実装に入る前にまず公式のドキュメントは読んでおくべきです。

サンプル作成中

ここまで書いてきた内容で頑張ってプロダクト導入はしたものの、他のAndroidエンジニアからの意見をもらったり、実装の参考として使ってもらえるようなサンプルを作成中です。ベースはInstagramのデザインですが、中身はExoPlayerで表示、mp4parserで切り取りを行うものです。依存ライブラリが二つあるのはあまり良くないですが、対応できるフォーマットを増やしつつ依存も解消していけるようにします。近日公開。

もしストックされた場合、公開後通知を飛ばします。
今後、需要があればHLSなどについても書いていきます。

90
93
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
90
93

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?