代码之家  ›  专栏  ›  技术社区  ›  Dong Nguyen

解码python编码的视频帧显示在基于节点的webapp中

  •  1
  • Dong Nguyen  · 技术社区  · 6 年前

    我使用python 3和opencv读取视频,并通过socket将帧发送到基于node.js的网页。

    让我们想象一下这样的情况:

    cap = cv2.VideoCapture(video_path)
    while cap.isOpened():
        ret, frame = cap.read()
        send(frame)
    

    send() 函数,在实际发送之前,我将帧传递到 normalize() 函数将其转换为Socket IO的可交付格式。这个 规范化() 如下所示:

    def normalize(frame):
        d = frame.flatten()
        s = d.tostring()
        b = b64encode(s)
        return b.decode('ascii')
    

    数据也被发送了。在node.js应用程序中,我收到如下消息:

    Encoded image data

    如何将此编码字符串转换为普通视频,甚至图像?

    谢谢。

    1 回复  |  直到 6 年前
        1
  •  2
  •   alkasm Anuj Gautam    6 年前

    要对图像进行编码,请使用 cv2.imencode() 是的。然后,您可以将缓冲区写入一个64进制字符串,然后直接用html或您想用它做的任何事情来显示它。

    下面是一个基本的例子。首先,巨蟒:

    import cv2
    import base64
    
    def encode_img(img):
        """Encodes an image as a png and encodes to base 64 for display."""
        success, encoded_img = cv2.imencode('.png', img)
        if success:
            return base64.b64encode(encoded_img).decode()
        return ''
    

    这将为您提供64进制的编码图像。返回的字符串可以直接用html显示,方法是将该字符串用作 src 如果你事先准备好 data:image/png;base64, 为了它。

    例如…

    import numpy as np
    img = np.uint8(255 * np.random.rand(50, 50))
    encoded_img = encode_img(img)
    b64_src = 'data:image/png;base64,'
    img_src = b64_src + encoded_img
    

    用这张随机的照片 img_src 变成:

    ''
    

    然后,在一个简单的html文件中,使用这个作为图像标记的源:

    <html>
    <body>
        <img src="">
    </body>
    </html>
    

    你应该能看到图像。

    您还可以使用此格式将它们直接保存为节点服务器上的图像。你可以用 fs.writeFile() 例如,通过指定options对象 {encoding: 'base64'} 是的。例如,来自 this tutorial 以下内容:

    import fs from 'fs';
    fs.writeFile('image.png', base64Image, {encoding: 'base64'}, function(err) {
        console.log('File created');
    });
    

    当然,如果使用node中的其他库来播放图像,则需要使用该库中的某些函数来解码图像。从b64到字节的交换可能不太困难,但是您需要将这些字节解码成一个映像,无论您使用的是什么lib服务器端。