要对图像进行编码,请使用
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服务器端。