react-native-view-transformer
react-native-view-transformer
is a pure JavaScript RN component that makes ANY views transformable using gestures like pinch, double tap or pull, as below shows:
data:image/s3,"s3://crabby-images/8a7bd/8a7bde6fde16d620d125a78b84e683336aa9269f" alt=""
Demo project is here
Install
npm install --save react-native-view-transformer@latest
Usage
First, import:
import ViewTransformer from 'react-native-view-transformer';
Then, render:
<ViewTransformer>
//Your views here
</ViewTransformer>
Now, your views are transformable!
ViewTransformer.Image
The most common case is to transform an image, or a photo, which is famous as a PhotoView, or ImageViewer, so we provide a similar component ViewTransformer.Image, which is much like the official Image component, but transformable!
Just use it like the official Image component:
<ViewTransformer.Image
style={{width: width, height: height}}
source={{uri: 'xxx'}}
pixels={{width: 1920, height: 1080}} //this prop is important!
/>
But with an additional prop pixels, which tells image size in pixels.
The pixels prop is used to align the edge of the image content with the view's boundry and to determine the max scale.(We can actually use Image.getSize to get pixels info on iOS, but NOT on Android, so for now this prop is needed)
There may be a problem: How can I find the pixels info of a remote image without loading it? Well, you can ask your app's API server to provide it. For example, the API server may return a json like
image: {
url: 'xxx',
width: 1920,
height: 1080
}
demo
data:image/s3,"s3://crabby-images/dee47/dee47347340a1f64f926c5ae470e53774f0304f4" alt=""