简体   繁体   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)?

I'm creating an Expo project using React Native and want to find the color of a pixel at x and y coordinates.我正在使用 React Native 创建一个 Expo 项目,并希望在 x 和 y 坐标处找到像素的颜色。 The image will be the picture taken from the Expo camera module represented in base64.该图像将是从以 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
             
        */ -----------------------------------------------
            
    });
}
}}>

Is there a simple way to do something as shown in the comment?有没有一种简单的方法来做评论中所示的事情?

Note: I have already tried using 3rd party libraries, such as注意:我已经尝试过使用 3rd 方库,例如

, but they use native modules in react native, and don't work with an Expo managed project. ,但它们在 react native 中使用本机模块,并且不适用于 Expo 管理的项目。

Edit编辑

I'm now using a GLView from expo-gl and using Expo-2d-context for a "canvas" type approach:我现在使用 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);
}}/>

Now my only problem is drawing an image to Expo2dCanvas using drawImage.现在我唯一的问题是使用 drawImage 将图像绘制到Expo2dCanvas I don't know what to pass for the first argument (which is the asset).我不知道要为第一个参数(即资产)传递什么。

I got it working with this library get-pixels .我让它与这个库get-pixels 一起工作 from what I saw it works with both JPEG and PNG images and it does not use native modules.从我所看到的它适用于 JPEG 和 PNG 图像,并且它不使用本机模块。 Hope it works for you.希望对你有效。

here is the code:这是代码:

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));

This isn't a React Native specific solution, but it should work anywhere you have JS and a DOM.这不是 React Native 特定的解决方案,但它应该适用于您拥有 JS 和 DOM 的任何地方。

  1. Create an <img> element and set its src to the dataURI创建一个<img>元素并将其src设置为 dataURI
  2. Create a <canvas> element, and get its context创建一个<canvas>元素,并获取其context
  3. Draw the <img> onto the <canvas><img>绘制到<canvas>
  4. Read the pixel data from <canvas><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.

相关问题 如何在 React-Native 中将 base64 url 转换为图像(png/jpg)文件? - How can I convert a base64 url to an image(png/jpg) file, in React-Native? React-Native:将图像 url 转换为 base64 字符串 - React-Native: Convert image url to base64 string 将图像转换为 expo 中的 base64 react-native(仅在前端):PayloadTooLargeError:请求实体太大 - convert image to base64 in expo react-native(only in the frontend): PayloadTooLargeError: request entity too large React-Native:下载映像并将其转换为Base64映像 - React-Native: Download Image and convert it to Base64 Image react-native:共享 api 将 base64 字符串而不是图像传递给 WhatsApp - react-native: share api passing base64 string instead of image to WhatsApp 我如何从 base64 字符串或文件 uri 或字节数组中获取实际文件类型? - how can i get actual file type from base64 String or file uri or bytearray in react native or js? 如何使用 base64 加密在 react-native 中加密密码,我是 react-native 的新手 - how do i encrypt the password in react-native using base64 encryption ,i am new to react-native 将位图字符串转换为 Base64 图像 - Convert Bitmap String into Base64 image 如何将图像缓冲区转换为字符串 base64? - How can I convert image buffer to string base64? React.js 如何将字符串 base64 转换为普通图像 - React.js How can I convert string base64 to normal image
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM