簡體   English   中英

在 React-Native(Expo 托管)中給定 base64 字符串,如何在圖像/位圖的特定坐標處獲取像素的顏色?

[英]How can I get a pixel's color at a specific coordinate of an Image/Bitmap given a base64 string in React-Native (Expo managed)?

我正在使用 React Native 創建一個 Expo 項目,並希望在 x 和 y 坐標處找到像素的顏色。 該圖像將是從以 base64 表示的Expo 相機模塊拍攝的照片。

<Camera ref={cR} style={{flex: 1}} type={type} onCameraReady={() => {
if (cR){ 
    cR.current.takePictureAsync({base64: true}).then((data) => {
        const source = `data:image/jpeg;base64,${data}`;
        //Is there a way to achieve something like below (note that Image is just a made-up function)?
        /* -----------------------------------------------
            var img = Image(source);
            console.log(img.getPixel(x, y)); // Should output an rgb object/array or hex code
             
        */ -----------------------------------------------
            
    });
}
}}>

有沒有一種簡單的方法來做評論中所示的事情?

注意:我已經嘗試過使用 3rd 方庫,例如

,但它們在 react native 中使用本機模塊,並且不適用於 Expo 管理的項目。

編輯

我現在使用 expo-gl 中的 GLView 並使用 Expo-2d-context 作為“畫布”類型的方法:

<GLView style={{flex: 1}} onContextCreate={(gl) => {
    var x = 50;
    var y = 50;
    var ctx = new Expo2DContext(gl);
    // how to define imag as an image that can be passed into drawImage?
    ctx.drawImage(imag, 0, 0, imag.props.width, imag.props.height);
    const imageData = ctx.getImageData(x, y, 1, 1);
    console.log(imageData);
}}/>

現在我唯一的問題是使用 drawImage 將圖像繪制到Expo2dCanvas 我不知道要為第一個參數(即資產)傳遞什么。

我讓它與這個庫get-pixels 一起工作 從我所看到的它適用於 JPEG 和 PNG 圖像,並且它不使用本機模塊。 希望對你有效。

這是代碼:

const getPixels = require("get-pixels");
const util = require("util");
const string =
  "data:image/png;base64, --- data ---";

const base64toBuffer = Buffer.from(string.substring(22), "base64");

async function getPixelAt(x, y, buffer, format) {
  const getPixelsPromisse = util.promisify(getPixels);

  pixels = await getPixelsPromisse(buffer, `image/${format}`);
  const pixelAt = [];

  for (let i = 0; i <= 3; i++) {
    pixelAt.push(pixels.get(x, y, i));
  }

  return pixelAt;
}

getPixelAt(0, 0, base64toBuffer, "png").then((pixel) => console.log(pixel));

這不是 React Native 特定的解決方案,但它應該適用於您擁有 JS 和 DOM 的任何地方。

  1. 創建一個<img>元素並將其src設置為 dataURI
  2. 創建一個<canvas>元素,並獲取其context
  3. <img>繪制到<canvas>
  4. <canvas>讀取像素數據

 const dataURI = ''; (async () => { async function pixelValue(dataURI, x, y) { const p = new Promise((resolve, reject) => { // Create an `<img>` to load the dataURI in const img = document.createElement('img'); img.onload = () => { // Get `natural` size of image const width = img.naturalWidth; const height = img.naturalHeight; // Create `<canvas>` and set it to the same dimensions as the image const canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; // Get the `<canvas>` `context` const ctx = canvas.getContext('2d'); // Draw the `<img>` onto the canvas ctx.drawImage(img, 0, 0, width, height); // Get the pixel data at `x` and `y` const imageData = ctx.getImageData(x, y, 1, 1); // Resolve the promise with the `imageData.data` array with pixel data represented as `[r,g,b,a]` resolve(imageData.data); } // Reject the promise if the image fails to load img.onerror = reject; // Invokes loading of the image img.src = dataURI; // NOT NEEDED document.body.appendChild(img); // Append to body }); return p; } const pixel = await pixelValue(dataURI, 130, 140); console.log(pixel); // Uint8ClampedArray(4) [192, 192, 0, 255] (rgba) })();

暫無
暫無

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

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