簡體   English   中英

使用 OpenCV 和 Javascript 在 Canvas 上的像素陣列顯示圖像

[英]Display image from array of pixels on Canvas with OpenCV and Javascript

我從 MQTT 訂閱接收像素值數組 ( var image ) 中的一些圖像,我想在讀取這些圖像時在 canvas 的 html 網站上繪制這些圖像。 我正在使用 Javascript 來獲取圖像,並使用 OpenCV.js 來讀取圖像中的像素值數組並將其繪制在 canvas 上,但我只得到一個黑色方塊。 代碼如下:

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(三個通道),我正在嘗試將其轉換為 canvas 所需的 4 個通道(RGBA),但我沒有運氣。 是因為數組的形狀嗎?

我該如何解決這個問題?

干杯

你的圖像中的閱讀情況如何? 那可能是你的問題。 是 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();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM