2

複数の jpeg 画像を文字列としてメモリに保存しています。それらからビデオを生成したい(したがって、それらの写真はビデオのフレームになります)。

どうやってやるの?

4

1 に答える 1

4

それぞれ 1 つの画像を個別に表す文字列のコレクションがある場合は、 と組み合わせStringIOPIL、ファイルに保存せずに読み取ることができます。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))
于 2013-01-21T13:13:32.093 に答える