複数の jpeg 画像を文字列としてメモリに保存しています。それらからビデオを生成したい(したがって、それらの写真はビデオのフレームになります)。
どうやってやるの?
それぞれ 1 つの画像を個別に表す文字列のコレクションがある場合は、 と組み合わせStringIO
てPIL
、ファイルに保存せずに読み取ることができます。PIL
次に、 を使用してイメージから OpenCV に変換しますnumpy
。また、新しい OpenCV バインディングを使用するようにコードを更新してください。
これは、あなたが持っているものを複製する例です(sys.argv [1]は出力ビデオファイルの名前であると想定されています)、ビデオコーデックを調整する必要があるかもしれません:
import sys
import numpy
import cv
import cv2
from cStringIO import StringIO
from PIL import Image
out_video = cv2.VideoWriter()
fourcc = cv.CV_FOURCC('D', 'I', 'V', 'X')
fps = 30
color = True
size = None
for fname in sys.argv[2:]:
data = open(fname).read() # Your String
s = StringIO(data)
img = Image.open(s)
if size and img.size != size:
img = img.resize(size)
else:
size = img.size
out_video.open(sys.argv[1], fourcc, fps, size, color)
out_video.write(cv2.cvtColor(numpy.array(img), cv2.COLOR_RGB2BGR))