我正在接收来自MQTT订阅的像素值数组(var image)中的一些图像,我希望在读取这些图像时将这些图像绘制在我的html网站上的画布上。我使用Javascript获取图像,使用OpenCV.js读取图像中的像素值数组并在画布上绘制,但我只得到一个黑色方块。守则如下:
function onMessageArrived(message) {
var data = JSON.parse(message.payloadString);
var image = data.image; //300x400x3
var metadata = data.metadata;
document.getElementById("metadata").innerHTML += '<span>Metadata: ' + metadata + '</span><br/>';
var width = image.length;
var height = image[0].length;
var c = document.getElementById("images_canvas");
let mat = cv.matFromArray(width, height, cv.CV_8UC3, image);
cv.cvtColor(mat, mat, cv.COLOR_BGR2BGRA);
//let dsize = new cv.Size(400, 400);
//cv.resize(mat, mat, dsize, 0, 0, cv.INTER_AREA);
cv.imshow("images_canvas", mat);
mat.delete();
如您所见,数组的形状为300x400x3 (三个通道),我正在尝试将其转换为画布所需的4个通道(RGBA),但我没有运气。是因为数组的形状吗?
我怎么才能解决这个问题?
干杯
发布于 2020-07-22 05:11:01
你的阅读效果如何?那可能是你的问题。是JSON中的Base64吗?
let src = cv.imread('canvasInput');
let dst = new cv.Mat();
cv.cvtColor(src, dst, cv.COLOR_BGR2RGBA, 0);
cv.imshow('canvasOutput', dst);
src.delete(); dst.delete();
https://stackoverflow.com/questions/61914911
复制相似问题