W-ZERO3による動画再生

2007/08/29W-ZERO3::Tips

・・・・・・この記事「 W-ZERO3による動画再生 」は書きかけだけど、でも勘違いしないでよねっ! べっ、別に、アナタに加筆して欲しいわけじゃ無いんだからねっ! まっ、まあ、アナタがどうしてもって言うのなら、ちょっとだけ書かせてあげてもいいけど・・・・・・

W-ZERO3[es]向けに動画なんかを作成しています。
比較的重めなリトバスのムービーをサンプルに色々試行錯誤しながらやっています。

使ったツールや方法などは徐々にまとめていきます。

W-ZERO3に適した動画形式の選択

TCPMPでは以下の動画形式に対応しています。

  • MPEG-4 (.mov, .mp4, .3gp)
  • H264 (.mp4)
  • Windows Media Video (.wmv)
  • ビデオファイル (.avi)
  • DivX圧縮ビデオファイル (.avi)
  • MPEG (.mpeg, .mpg)

このうち、ビデオファイルやMPEGデータはファイルサイズの観点からW-ZERO3での再生は困難と言えます。そうなると、MPEG-4系の圧縮動画形式が候補となりますが、このうちWMVに関しては元々が再生にパワーを要求する形式であるため、貧弱なW-ZERO3のCPUでは快適な再生は困難です。これまでの経験からDivX圧縮の動画はそれなりに快適に再生できることが分かっているため、今回はDivX及びH.264圧縮による動画を対象とします。

また、今回重点を置いているのは単に再生出来るという点ではなく、許容範囲の画質で出来る限り高い解像度での高フレームレート(30/24fps)の再生という点です。

中間報告

TCPMPベンチマークについて

一部を除いてTCPMP上で動画再生のベンチマークを行っています。TCPMPの動画再生ベンチマークでは、ドロップフレームなしで再生を行い、動画長/再生時間で結果を出力します。
TCPMPのベンチマークで100%となっていればコマ落ち無しで再生出来るように見えますが、実際には動きが多い部分には処理が重くなり、少ない部分は処理が軽くなります。ベンチマークの結果はあくまでも全体の平均ですので、実際の再生でコマ落ちが気にならない為にはだいたい110%以上のベンチマーク結果が必要となります。

H264 320x240 30fps (Video iPod向け設定) 384kbps

TCPMPベンチマーク: 66%
重すぎて使い物になりません。

DivX6.6.1 320x240 30fps 600kbps + MP3 128kbps

コマ落ち無しで再生出来ますがブロックノイズが目立つ…

DivX6.6.1 320x240 30fps 800kbps + MP3 128kbps

コマ落ち無しで再生出来ますが画質の荒さが目立つ…

DivX6.6.1 640x480 30fps 1150kbps + MP3 128kbps

TCPMPベンチマーク: 90%
一定間隔毎にコマ落ちが発生してしまう

DivX6.6.1 640x480 30fps 896kbps + MP3 128kbps

TCPMPベンチマーク: 110%
動きが激しい部分でコマ落ちが発生してしまう。520MHzにクロックアップでコマ落ちが許容範囲内になる。

DivX6.6.1 400x320 30fps 800kbps + MP3 128kbps

TCPMPベンチマーク: 110%
コマ落ち無しで再生可能だが画質の荒さが目立つ…

DivX6.6.1 640x480 24fps 800kbps + MP3 128kbps

TCPMPベンチマーク: 110%
コマ落ち無し、画質も許せる範囲。このあたりが限界か。

2007/02/10(土)W-ZERO3のアプリ

アプリケーションによってはW-ZERO3以外のプラットフォーム向けにビルドされた実行ファイルが含まれています。WindowsCEを扱ったことが無い人にはよくわからないと思われるのでまとめておきます。

プラットフォーム

  • HPC2.0
  • HPC Pro
  • HPC 2000
  • PsPC
  • PPC(PPC2000)
  • PPC2002
  • WM2003(WM2003SE)
  • WM5.0

W-ZERO3はWindows Mobile5.0プラットフォームですので、用意すればこれを利用するのが一番です。が、Windows Mobile 5.0プラットフォームは後方互換性をもっているのでWM2003(WM2003SE), PPC2002, PPC(PPC2000), HPC2000, HPC Pro向けにビルドされたものも(画面配置やなどの問題はありますが)大部分は動作させることが可能です。
基本的に、WM5.0>WM2003(SE)>PPC2002>PPC>HPC2000>HPC Proの順に選択すればいいでしょう。ただし、WM5.0以外のプラットフォームをターゲットとして開発されたアプリの実行にはMFCCExxx.dllが必要になる場合があります。

ターゲットCPU

上記のプラットフォームによる分類の他に、ビルドのターゲットとなるCPUのタイプが別れています。
WinCE向けのターゲットCPUタイプには以下のようなものがあります。

  • MIPS
  • SH-3/SH-4
  • ARM
    • ARMV4I
    • ARMV4T

W-ZERO3にはIntel XScale PXA270が採用されており、CPUのアーキテクチャ的にはARM系に属します。ARM系にはさらに、ARMV4IとARMV4Tに別れている場合があり、ARMV4Iは実行速度は速くなるがファイルサイズが大きくなる、ARMV4Tはファイルサイズは小さいが実行速度は遅くなるという特徴があります。

W-ZERO3の運用ポリシーにもよりますが、ARMV4Iを導入した方が幸せになれると思います。

2006/11/10(金)W-ZERO3[es]のテンキーを活用する

W-ZERO3[es]のテンキーは、半角数字入力時(_1)には仮想キーコード(0~9, #, *)を発生させます。
このため、W-ZERO3 Utility Plusを活用することで多くのソフトがスタイラスやキーボードを使用せずに、テンキーだけでの操作が可能となります。

あると便利なツール

文字キーで入力モードを選択することができますが、なかなか面倒です。
このため、起動すると指定した入力モードに切り替えてくれるソフト「ChgInputMode」を利用することで簡単に半角数字モードへ切り替えることが可能となります。

このChgInputModeの起動もW-ZERO3 Utility Plusで行うことができますので必要に応じて割り当てるといいでしょう。

一般的なキーバインドに関するTips

  • 左ソフトキーはF1、右ソフトキーはF2を発生させる
  • タップ&ホールド(右クリックメニュー): Alt+Ctrl
  • 元に戻す: Ctrl+Z
  • 切り取り: Ctrl+X
  • コピー: Ctrl+C
  • 貼り付け: Ctrl+V
  • 削除: Del
  • 戻る、1つ上の階層へ: BS
  • フォーカス移動: Tab
  • テンキー#にW-ZERO3 Utility Plusで機能を割り当てるには「同時押し:Shift+3」

戯言

以下、確証はもてませんが。

  • 入力モードが半角英数(_A)の時には「テンキー2」を一度押しで「A」、二度押しで「B」、三度押しで「C」を発生させている気がする
  • 入力モードによってカーソル中央のボタンは発生させる仮想キーコードが異なり、半角英数の場合「アクションボタン」でかな/カナ入力時には「#E5」を発生させている?
  • 「OK」ボタンの仮想キーコードは「Win+F6」
  • クリアボタンの仮想キーコードは「#08」
  • 音量Upボタンの仮想キーコードは「#21」
  • 音量Downボタンの仮想キーコードは「#22」
  • 画面回転ボタンの仮想キーコードは「App4 (A4)」

具体的な実装例