こんにちは。
OpenCVのVideoCaptureで得られた動画の一部領域をトリミングし、再びVideoCaptureオブジェクトを作成したいです。
このコードの最終行のようなことをやりたいです。
ご教授いただければ幸いです。よろしくお願いいたします。
Python
1#元動画 2video = cv2.VideoCapture("input.mp4") 3 4#video_outの内容を書き換えていく 5video_out = video 6 7if not video.isOpened(): 8 print("Error: video path is not correct", file=sys.stderr) 9 sys.exit(1) 10 11while video.isOpened(): 12 #フレームの読み込み 13 ret, frame = video.read() 14 15 #現在のフレーム番号 16 current_frame = int(video.get(cv2.CAP_PROP_POS_FRAMES)) 17 18 #動画が終わると終了 19 if not ret: 20 break 21 22 #トリミング 23 trimmed = frame[200:400,200:400,:] 24 25 #このtrimmedをVideoCaptureクラスのオブジェクトのフレームにしたい 26 video_out.frame[current_frame] = trimmed #のような感じ?
「再びVideoCaptureオブジェクトを作成したい」とはどのような意味でしょうか?トリミング画像を扱いたいのであればそのままtrimmedを用いれば良いはずです。ファイル出力をしたいのであればVideoWriterが候補になりえます。
トリミングの出力がNumpy配列だと、次の処理の内容をNumpy配列用に書き換えなくてはならなくなりプログラムが複雑になるので、できればVideoCaputureオブジェクトを入力としてVideoCaputureオブジェクトを返す関数にしたいです。
出力をVideoCaputureオブジェクトで固定すれば、処理をモジュール化でき、直列に追加したり減らしたりが簡単にできると思っています。
ただ、あまり経験がないので自分の考えが正しいかもよくわかりません。
ご指摘を受けてよく考えたらNumpy配列の入ったクラスをまた作り直せばいいだけな気がしてきました。
ありがとうございます。
回答1件
あなたの回答
tips
プレビュー