頭と尻尾はくれてやる!

iOSアプリなどの開発日記です


動画から画像を切り出す時の処理時間を計測した

macOSで動画ファイルから画像を切り出す時にAVFoundationのAVAssetImageGeneratorクラスの
func generateCGImagesAsynchronously(forTimes requestedTimes: [NSValue], completionHandler handler: @escaping AVAssetImageGeneratorCompletionHandler)
を使っている。
この最初の引数に欲しい画像の時刻に相当する値の配列を渡せばまるっとまとめてcompetionHandlerでくれる。
長い動画に対して処理をするとそこそこの時間、Macが固まることになる!
描画のタイミングはないからNSProgressIndicatorを書き換えることもできない。
ユーザーからすると、ちゃんと処理は進んでいるんだろうか?と心配になってしまう。

なのでなんとか途中で描画のタイミングを作って少しずつ画像を作成していくという方法を考えた。
心配なのはどのくらい時間のロスが発生するんだろうか?ということだ。

ということで一定枚数ごとに分割して画像を作成したらどうなるかを計測してみた。

全部で35枚の動画を作成する処理をn枚ごとに行った。
5枚ごとなら7回のループでちょうどだけど、
10枚ごとなら4回のループになり、4回目は枚数が少ない。

XCTest(ユニットテスト)のmeasureというのを使うとデフォルトで10回処理してその平均などを出してくれる。

結果をグラフにするとこんな感じ。
処理時間の結果のグラフ

そりゃ、まあ1回(横軸が35のところ)が最速になるよな。これを基準にすると、、、

処理時間の結果の表

1枚ごとなら15%ほど余計に時間がかかるけど、progress indicatorを書き換えるのなら1枚ごとじゃなくてもいいだろう。
10枚ごとなら4%ほどのロスだがこれで時々進捗を描けるならこっちの方がいいかな。


NSProgressIndicator
↑NSProgressIndicator。描画タイミングなくても逐次書き換えてくれるようになったらいいのにな。SwiftUIに期待?!



macOS 10.15.5 Catalina
Xcode 11.5
Swift 5.2.4
スポンサーサイト






Number Formatter付きのNSTextFieldで入力を数値だけにする

人様が公開してるmacOSアプリのサンプルコードを眺めてたらNSTextFieldの設定画面に何やらNumber Formatterが接続されている、、、?

Xcodeのoutlet設定画面

でもなんだか表示が通常のと違って薄いし、どこのファイルにもそのようなoutletの宣言もない、、、?
これ何?と調べたところ、storyboardでNSTextFieldを追加する時にText Field with Number Formatterなんて選択肢もあったのだ(気付かなかったなあ)。

UI追加画面

↑これを選択してstoryboard上で設置する。
ところがText Fieldを選択してもinspector(Xcodeの右の方に出てくる詳細設定画面)には数値に関する設定画面がない、、、?
散々探した結果、storyboardやxibファイル選択時にXcodeのメイン画面の左の部品構成一覧のところで

パーツの構成画面

↑このようにText Fieldの下の階層にNumber Formatterとあるのでここをクリックすると

Number Formatterの設定画面

↑inspectorに設定画面が出てきた!


ここを設定すればtext fieldが数値しか受け付けない、とかできた。



macOS 10.15.4 Catalina
Xcode 11.5


  TopPage  



Copyright ©頭と尻尾はくれてやる!. Powered by FC2 Blog. Template by eriraha.