使用read()从VideoCapture对象获取图像

md1*_*nox 1 python opencv numpy

我正在逐帧阅读视频:

vc = cv2.VideoCapture('test.avi')

然后我检查是否frame已使用以下内容读取:

if vc.isOpened():
    rval,frame = vc.read()
else:
    rval = False
Run Code Online (Sandbox Code Playgroud)

现在的问题是,如果我尝试frame使用以下代码将其转换为numpy数组:

PILImage = Image.fromstring("L",cv.GetSize(frame),frame.tostring())
NumPyArray = np.array(PILImage)
Run Code Online (Sandbox Code Playgroud)

我收到一个错误说:

CvArr argument 'arr' must be IplImage, CvMat or CvMatND. Use fromarray() to convert numpy arrays to CvMat or cvMatND

VideoCapture :: read的文档我发现它返回两件事[retVal,Image].如何Image仅获取零件,如何将其转换为Numpy Array?

进一步的信息: 基本上这样做的重点在于,我正在尝试编写一个程序,它允许我通过按空格键来浏览视频的每个帧,并从任何帧中选择一个特定区域并将其保存为jpg.这是代码:

from ITMS import ITMS
import cv2
from cv2 import cv
import numpy as np
import matplotlib.pyplot as plt
import Image
import matplotlib.widgets as widgets

def onselect(eclick, erelease):
    if eclick.ydata>erelease.ydata:
        eclick.ydata,erelease.ydata=erelease.ydata,eclick.ydata
    if eclick.xdata>erelease.xdata:
        eclick.xdata,erelease.xdata=erelease.xdata,eclick.xdata
    ax.set_ylim(erelease.ydata,eclick.ydata)
    ax.set_xlim(eclick.xdata,erelease.xdata)
    fig.canvas.draw()

def subImager(arr):
    fig = plt.figure()
    ax = fig.add_subplot(111)

    plt_image=plt.imshow(arr,cmap="Greys_r")
    rs=widgets.RectangleSelector(
        ax, onselect, drawtype='box',
        rectprops = dict(facecolor='red', edgecolor = 'red', alpha=0.2, fill=True))
    plt.show()


cv2.namedWindow("preview")
vc = cv2.VideoCapture('test.avi')

if vc.isOpened():
    rval,frame = vc.read()
else:
    rval = False

while rval:
    key = cv2.waitKey(30)
        if key==32:
            cv2.imshow("preview", frame)
            NumPyArray=ITMS.CVtoNPArray(frame)
            subImager(NumPyArray)
            rval,frame = vc.read()
        elif key==27:
            break

cv2.destroyAllWindows()
Run Code Online (Sandbox Code Playgroud)

ITMS类:

from cv2 import cv
import cv2
import numpy as np
from PIL import Image

class ITMS:
    def __init__(self):
        pass

    def CVtoNPArray(CVImage):
        PILImage = Image.fromstring("L",cv.GetSize(CVImage),CVImage.tostring())
        NumPyArray = np.array(PILImage)
        return NumPyArray
        CVtoNPArray=staticmethod(CVtoNPArray)
Run Code Online (Sandbox Code Playgroud)

mmg*_*mgp 5

你的东西过于复杂,你frame名字中返回的图像已经是一个numpy数组.如果你想将其转换为PIL,只需这样做Image.fromarray(frame).