react-native-vision-camera/docs/docs/ANIMATED.md

84 lines
3.0 KiB
Markdown
Raw Normal View History

---
id: animated
title: Zooming with Reanimated
sidebar_label: Zooming with Reanimated
---
2021-02-22 06:03:20 -07:00
<div>
<svg xmlns="http://www.w3.org/2000/svg" width="283" height="535" style={{ float: 'right' }}>
<image href="../img/demo.gif" x="18" y="33" width="247" height="469" />
<image href="../img/frame.png" width="283" height="535" />
2021-03-04 08:24:40 -07:00
</svg>
2021-02-22 06:03:20 -07:00
</div>
2021-02-19 08:07:53 -07:00
## Animations
Often you'd want to animate specific props in the Camera. For example, if you'd want to create a custom zoom gesture, you can smoothly animate the Camera's `zoom` property.
Note: The `<Camera>` component does provide a natively implemented zoom gesture which you can enable with the `enableZoomGesture={true}` prop. This does not require any additional work, but if you want to setup a custom gesture, such as the one in Snapchat or Instagram where you move up your finger while recording, continue reading.
### Installing reanimated
The following example uses [react-native-reanimated](https://github.com/software-mansion/react-native-reanimated) (v2) to animate the `zoom` property. Head over to their [Installation guide](https://docs.swmansion.com/react-native-reanimated/docs/installation) to install Reanimated if you haven't already.
### Implementation
2021-02-19 08:07:53 -07:00
```tsx
import Reanimated, {
useAnimatedProps,
useSharedValue,
withSpring,
2021-02-23 01:43:47 -07:00
} from "react-native-reanimated"
2021-02-19 08:07:53 -07:00
2021-02-23 01:43:47 -07:00
const ReanimatedCamera = Reanimated.createAnimatedComponent(Camera)
2021-02-19 08:07:53 -07:00
Reanimated.addWhitelistedNativeProps({
zoom: true,
2021-02-23 01:43:47 -07:00
})
2021-02-19 08:07:53 -07:00
2021-02-23 01:43:47 -07:00
export function App() {
2021-03-01 04:43:52 -07:00
const devices = useCameraDevices()
const device = devices.back
2021-02-23 01:43:47 -07:00
const zoom = useSharedValue(0)
2021-02-19 08:07:53 -07:00
const onRandomZoomPress = useCallback(() => {
2021-02-23 01:43:47 -07:00
zoom.value = withSpring(Math.random())
}, [])
2021-02-19 08:07:53 -07:00
const animatedProps = useAnimatedProps<Partial<CameraProps>>(
() => ({ zoom: zoom.value }),
[zoom]
2021-02-23 01:43:47 -07:00
)
2021-02-19 08:07:53 -07:00
2021-03-01 04:43:52 -07:00
if (device == null) return <LoadingView />
2021-02-19 08:07:53 -07:00
return (
<>
<ReanimatedCamera
style={StyleSheet.absoluteFill}
device={device}
isActive={true}
2021-02-23 01:43:09 -07:00
animatedProps={animatedProps}
2021-02-19 08:07:53 -07:00
/>
<TouchableOpacity
style={styles.zoomButton}
onPress={onRandomZoomPress}>
<Text>Zoom randomly!</Text>
</TouchableOpacity>
</>
)
}
```
### Implementation
1. The `Camera` is converted to a reanimated Camera using `Reanimated.createAnimatedComponent`
2. The `zoom` property is added to the whitelisted native props to make it animatable.
> Note that this might not be needed in the future, see: [reanimated#1409](https://github.com/software-mansion/react-native-reanimated/pull/1409)
3. Using [`useSharedValue`](https://docs.swmansion.com/react-native-reanimated/docs/api/useSharedValue), we're creating a shared value that holds the `zoom` property.
4. Using the [`useAnimatedProps`](https://docs.swmansion.com/react-native-reanimated/docs/api/useAnimatedProps) hook, we apply the shared value to the animated props.
2021-02-23 01:43:09 -07:00
5. We apply the animated props to the `ReanimatedCamera` component's `animatedProps` property.
<br />
#### 🚀 Next section: [Camera Errors](errors)