JavaScript image processing in React Native using Jimp
I was trying to make an app that gets the color of an image captured by the camera with react native with expo. I used Jimp, a JavaScript image-processing library but it's showing this error.
Look at this code.
import { StatusBar } from 'expo-status-bar';
import React, { useState, useEffect, useRef } from 'react';
import { StyleSheet, Text, View, Button, TouchableOpacity, ScrollView, Modal, Image } from 'react-native';
import { Camera } from 'expo-camera';
import { FontAwesome } from '@expo/vector-icons';
import Jimp from 'jimp';
export default function App() {
const camRef = useRef(null);
const [type, setType] = useState(Camera.Constants.Type.back);
const [hasPermission, setHasPermission] = useState(null);
const [capturedPhoto, setCapturedPhoto] = useState();
const [visible, setVisible] = useState(false)
useEffect(() => {
(async () => {
const { status } = await Camera.requestPermissionsAsync();
setHasPermission(status === 'granted');
})();
}, []);
if (hasPermission === null) {
return <View />
}
if (hasPermission === false) {
return <Text>Acesso negado!</Text>
}
async function takePicture() {
if (camRef) {
const options = { quality: 0.5, base64: true };
const data = await camRef.current.takePictureAsync(options);
setCapturedPhoto(data.uri);
setVisible(true)
GetColor()
}
}
async function GetColor() {
try {
const image = await Jimp.read(capturedPhoto);
const hex = image.getPixelColor(40, 40);
console.log(Jimp.intToRGBA(hex));
} catch (error) {
console.error(error)
}
}
return (
<View style={styles.container}>
<Camera
style={{ flex: 1 }}
type={type}
ref={camRef}
>
//...restante do codigo
</Camera>
<TouchableOpacity style={styles.button} onPress={takePicture}>
<FontAwesome name="camera" size={23} color="#fff" />
</TouchableOpacity>
{capturedPhoto &&
<Modal
animationType="slide"
transparent={false}
visible={visible}
>
<View style={{ flex: 1, justifyContent: 'center', alignItems: 'center', margin: 20 }}>
<TouchableOpacity style={{ margin: 10 }} onPress={() => setVisible(false)}>
<FontAwesome name="window-close" size={50} color="#FF0000"></FontAwesome>
</TouchableOpacity>
<Image
style={{ width: '100%', height: 300, borderRadius: 20 }}
source={{ uri: capturedPhoto }}
/>
</View>
</Modal>
}
<StatusBar style="auto" />
</View>
);
}
O error:
Event {
"isTrusted": false,
"methodName": "constructor",
}
* [native code]:null in __expoConsoleLog
- node_modules\react-native\Libraries\LogBox\LogBox.js:33:4 in console.error
- node_modules\react-native\Libraries\YellowBox\YellowBox.js:169:6 in registerError
- node_modules\react-native\Libraries\YellowBox\YellowBox.js:84:8 in errorImpl
- node_modules\react-native\Libraries\YellowBox\YellowBox.js:63:4 in console.error
- node_modules\expo\build\environment\muteWarnings.fx.js:27:4 in error
- node_modules\regenerator-runtime\runtime.js:63:36 in tryCatch
- node_modules\regenerator-runtime\runtime.js:293:29 in invoke
- node_modules\regenerator-runtime\runtime.js:63:36 in tryCatch
- node_modules\regenerator-runtime\runtime.js:154:27 in invoke
- node_modules\regenerator-runtime\runtime.js:166:18 in PromiseImpl.resolve.then$argument_1
- node_modules\promise\setimmediate\core.js:37:13 in tryCallOne
- node_modules\promise\setimmediate\core.js:123:24 in setImmediate$argument_0
- node_modules\react-native\Libraries\Core\Timers\JSTimers.js:135:14 in _callTimer
- node_modules\react-native\Libraries\Core\Timers\JSTimers.js:183:16 in _callImmediatesPass
- node_modules\react-native\Libraries\Core\Timers\JSTimers.js:446:30 in callImmediates
* [native code]:null in callImmediates
- node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:396:6 in __callImmediates
- node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:144:6 in __guard$argument_0
- node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:373:10 in __guard
- node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:143:4 in flushedQueue
* [native code]:null in flushedQueue
* [native code]:null in callFunctionReturnFlushedQueue
4 ответа
Похоже, вы пытаетесь использовать jimp.read() для строки base64. В этом случае вам нужно сначала удалить префикс: «data:image/;base64». Попробуйте сначала сделать это с capturePhoto:
Теперь вы сможете запустить jimp.read() для newCapturedPhoto, и все должно работать.
Причина, по которой вы столкнулись с этой ошибкой, заключается в том, что jimp не является библиотекой, оптимизированной для реагирования на native ... это библиотека javascript, предназначенная для использования с node.js
Jimp поддерживает серверную часть, то есть: - в node.js он работает нормально, в противном случае выдает ошибку.
Причина в том, что у вас есть пользователь Console.error. Если вы измените его на console.log, вы не увидите эту ошибку в разработке.