Converts an image in base64 format to it's grayscale version in base64 format.
npm install react-native-grayscaleA super lightweight react native package that converts an image
passed as a base64 string to a base64 string that represents
the grayscale version of that image.
:exclamation: Available for iOS only.
:exclamation: Tested on react-native>=0.60 only.
Support for android coming soon.
$ yarn add react-native-grayscale
or
$ npm install react-native-grayscale --save
then,
$ cd ios
$ pod install
done.
...
import getBase64Grayscale from "react-native-grayscale"
...
getBase64Grayscale(base64)
| Parameters | Required | Type | Description |
| ---------- | -------- | ------ | ------------------------------------------------------------------------------------- |
| base64 | required | string | the base64 string of the image. The prefix data:image/[format];base64, is optional. |
:exclamation: Note that if the base64 is without a prefix data:image/[format];base64, setting the uri property of the source prop at Image
will result in the image NOT beeing displayed.
| Returns | Description |
| ----------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| Promise<
``javascript
import React, { useEffect, useState } from "react";
import getBase64Grayscale from "react-native-grayscale";
import { Image, View } from "react-native";
const Test = props => {
const base64Icon =
"";
const [grayscaleBase64Img, setGrayscaleBase64Img] = useState("");
useEffect(() => {
const toGrayscale = async () => {
const grayscale = await getBase64Grayscale(base64Icon);
setGrayscaleBase64Img(grayscale);
};
toGrayscale();
}, []);
return (
width: 100,
height: 50,
borderWidth: 1,
borderColor: "black"
}}
source={{ uri: base64Icon }}
/>
width: 100,
height: 50,
borderWidth: 1,
borderColor: "black"
}}
source={{ uri: data:image/png;base64,${grayscaleBase64Img} }}
/>
);
};
``