react-native-svg-pan-zoom
Pan-zoom for react-native-svg via "Google Maps"-style pinch and drag gestures.
Getting Started
Installing
npm install --save react-native-svg-pan-zoom
Usage
Simply use SvgPanZoom as a wrapper and begin dropping components. Plain react-native-svg components will not react to clicks per default. To make things clickable, use the react-native PanResponder or wrap them in the included SvgPanZoomElement as shown below
;;; { return <View style = width: '100%' height:'100%' > <SvgPanZoom canvasHeight = 500 canvasWidth = 500 minScale = 05 initialZoom = 07 onZoom = { console } canvasStyle = backgroundColor: 'yellow' viewStyle = backgroundColor: 'green' > /* Doesn't consume or respond to clicks */ <Circle cx = 100 cy = 100 r = 42 stroke = "red" strokeWidth = "2.5" fill = "blue" /> /* Responds to clicks */ <SvgPanZoomElement x =50 y =50 onClick = { console } onClickCanceled = { console } onClickRelease = { console } onDrag = { console } > <Circle cx = 42 cy = 42 r = 42 stroke = "blue" strokeWidth = "2.5" fill = "red" /> </SvgPanZoomElement> </SvgPanZoom> </View> ; }
Additional notes
The drag and zoom gestures are constrained to never leave the SvgPanZoom canvas. It's size as well as scaling constraints can be set through props as shown in the above example.
It is recommended not to set maxScale above 1 as this results in blurred react-native-svg elements. Instead, increase your SVG element dimensions and set minScale lower.
License
This project is licensed under the MIT License - see the LICENSE.md file for details