Create add RNCamera doc
This commit is contained in:
parent
c45b0fbd99
commit
7c917cd5ed
|
@ -0,0 +1,348 @@
|
||||||
|
# RNCamera
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
All you need is to `import` `{ RNCamera }` from the `react-native-camera` module and then use the
|
||||||
|
`<RNCamera/>` tag.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
'use strict';
|
||||||
|
import React, { Component } from 'react';
|
||||||
|
import {
|
||||||
|
AppRegistry,
|
||||||
|
Dimensions,
|
||||||
|
StyleSheet,
|
||||||
|
Text,
|
||||||
|
TouchableHighlight,
|
||||||
|
View
|
||||||
|
} from 'react-native';
|
||||||
|
import { RNCamera } from 'react-native-camera';
|
||||||
|
|
||||||
|
class BadInstagramCloneApp extends Component {
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<View style={styles.container}>
|
||||||
|
<RNCamera
|
||||||
|
ref={ref => {
|
||||||
|
this.camera = ref;
|
||||||
|
}}
|
||||||
|
style={{
|
||||||
|
flex: 1,
|
||||||
|
}}
|
||||||
|
type={RNCamera.Constants.Type.back}
|
||||||
|
flashMode={RNCamera.Constants.FlashMode.on}
|
||||||
|
permissionDialogTitle={'Permission to use camera'}
|
||||||
|
permissionDialogMessage={'We need your permission to use your camera phone'}
|
||||||
|
/>
|
||||||
|
<TouchableOpacity
|
||||||
|
onPress={this.takePicture.bind(this)}
|
||||||
|
>
|
||||||
|
<Text> SNAP </Text>
|
||||||
|
</TouchableOpacity>
|
||||||
|
</View>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
takePicture = async function() {
|
||||||
|
if (this.camera) {
|
||||||
|
const options = { quality: 0.5, base64: true };
|
||||||
|
const data = await this.camera.takePictureAsync(options)
|
||||||
|
console.log(data.uri);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
const styles = StyleSheet.create({
|
||||||
|
container: {
|
||||||
|
flex: 1,
|
||||||
|
flexDirection: 'row',
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
AppRegistry.registerComponent('BadInstagramCloneApp', () => BadInstagramCloneApp);
|
||||||
|
```
|
||||||
|
|
||||||
|
## Properties
|
||||||
|
|
||||||
|
#### `autoFocus`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.AutoFocus.on` (default) or `RNCamera.Constants.AutoFocus.off`
|
||||||
|
|
||||||
|
Most cameras have a Auto Focus feature. It adjusts your camera lens position automatically depending on the pixels seen by your camera.
|
||||||
|
|
||||||
|
Use the `autoFocus` property to specify the auto focus setting of your camera. `RNCamera.Constants.AutoFocus.on` turns it ON, `RNCamera.Constants.AutoFocus.off` turns it OFF.
|
||||||
|
|
||||||
|
#### `iOS` `captureAudio`
|
||||||
|
|
||||||
|
Values: `true` (Boolean), `false` (default)
|
||||||
|
|
||||||
|
Specifies whether or not audio should be captured with the video. If `true`, app will request for microphone permission along with video permission.
|
||||||
|
|
||||||
|
#### `flashMode`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.FlashMode.off` (default), `RNCamera.Constants.FlashMode.on`, `RNCamera.Constants.FlashMode.auto` or `RNCamera.Constants.FlashMode.torch`.
|
||||||
|
|
||||||
|
Specifies the flash mode of your camera.
|
||||||
|
|
||||||
|
`RNCamera.Constants.FlashMode.off` turns it off.
|
||||||
|
|
||||||
|
`RNCamera.Constants.FlashMode.on` means camera will use flash in all photos taken.
|
||||||
|
|
||||||
|
`RNCamera.Constants.FlashMode.auto` leaves your phone to decide when to use flash when taking photos, based on the lightning conditions that the camera observes.
|
||||||
|
|
||||||
|
`RNCamera.Constants.FlashMode.torch` turns on torch mode, meaning the flash light will be turned on all the time (even before taking photo) just like a flashlight.
|
||||||
|
|
||||||
|
#### `focusDepth`
|
||||||
|
|
||||||
|
Value: float from `0` to `1.0`
|
||||||
|
|
||||||
|
Manually set camera focus. Only works with `autoFocus` off. The value 0 is minimum focus depth, 1 is maximum focus depth. For a medium focus depth, for example, you could use 0.5.
|
||||||
|
|
||||||
|
#### `Android` `ratio`
|
||||||
|
|
||||||
|
A string representing the camera ratio in the format 'height:width'. Default is `"4:3"`.
|
||||||
|
|
||||||
|
Use `getSupportedRatiosAsync` method to get ratio strings supported by your camera on Android.
|
||||||
|
|
||||||
|
## Component instance methods
|
||||||
|
|
||||||
|
#### `type`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.Type.front` or `RNCamera.Constants.Type.back` (default)
|
||||||
|
|
||||||
|
Use the `type` property to specify which camera to use.
|
||||||
|
|
||||||
|
#### `whiteBalance`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.WhiteBalance.sunny`, `RNCamera.Constants.WhiteBalance.cloudy`, `RNCamera.Constants.WhiteBalance.shadow`, `RNCamera.Constants.WhiteBalance.incandescent`, `RNCamera.Constants.WhiteBalance.fluorescent` or `RNCamera.Constants.WhiteBalance.auto` (default)
|
||||||
|
|
||||||
|
A camera’s white balance setting allows you to control the color temperature in your photos by cooling down or warming up the colors.
|
||||||
|
|
||||||
|
The idea is that you select the appropriate white balance setting for the type of light that you’re shooting in, and then your camera automatically adjusts the colors to eliminate any warm or cool color casts from your light source.
|
||||||
|
|
||||||
|
Use the `whiteBalance` property to specify which white balance setting the camera should use.
|
||||||
|
|
||||||
|
#### `zoom`
|
||||||
|
|
||||||
|
Value: float from `0` to `1.0`
|
||||||
|
|
||||||
|
Specifies the zoom of your camera. The value 0 is no zoom, 1 is maximum zoom. For a medium zoom, for example, you could pass `0.5`.
|
||||||
|
|
||||||
|
#### `Android` `permissionDialogTitle`
|
||||||
|
|
||||||
|
Starting on android M individual permissions must be granted for certain services, the camera is one of them, you can use this to change the title of the dialog prompt requesting permissions.
|
||||||
|
|
||||||
|
#### `Android` `permissionDialogMessage`
|
||||||
|
|
||||||
|
Starting on android M individual permissions must be granted for certain services, the camera is one of them, you can use this to change the content of the dialog prompt requesting permissions.
|
||||||
|
|
||||||
|
#### `notAuthorizedView`
|
||||||
|
|
||||||
|
By default a `Camera not authorized` message will be displayed when access to the camera has been denied, if set displays the passed react element instead of the default one.
|
||||||
|
|
||||||
|
#### `pendingAuthorizationView`
|
||||||
|
|
||||||
|
By default a <ActivityIndicator> will be displayed while the component is waiting for the user to grant/deny access to the camera, if set displays the passed react element instead of the default one.
|
||||||
|
|
||||||
|
### Native Event callbacks props
|
||||||
|
|
||||||
|
#### `onCameraReady`
|
||||||
|
|
||||||
|
Function to be called when native code emit onCameraReady event, when camera is ready.
|
||||||
|
|
||||||
|
#### `onMountError`
|
||||||
|
|
||||||
|
Function to be called when native code emit onMountError event, when there is a problem mounting the camera.
|
||||||
|
|
||||||
|
### Bar Code Related props
|
||||||
|
|
||||||
|
#### `onBarCodeRead`
|
||||||
|
|
||||||
|
Will call the specified method when a barcode is detected in the camera's view.
|
||||||
|
|
||||||
|
Event contains `data` (the data in the barcode) and `type` (the type of the barcode detected).
|
||||||
|
|
||||||
|
The following barcode types can be recognised:
|
||||||
|
|
||||||
|
- `aztec`
|
||||||
|
- `code128`
|
||||||
|
- `code39`
|
||||||
|
- `code39mod43`
|
||||||
|
- `code93`
|
||||||
|
- `ean13` (`iOS` converts `upca` barcodes to `ean13` by adding a leading 0)
|
||||||
|
- `ean8`
|
||||||
|
- `pdf417`
|
||||||
|
- `qr`
|
||||||
|
- `upce`
|
||||||
|
- `interleaved2of5` (when available)
|
||||||
|
- `itf14` (when available)
|
||||||
|
- `datamatrix` (when available)
|
||||||
|
|
||||||
|
The barcode type is provided in the `data` object.
|
||||||
|
|
||||||
|
#### `barCodeTypes`
|
||||||
|
|
||||||
|
An array of barcode types to search for. Defaults to all types listed above. No effect if `onBarCodeRead` is undefined.
|
||||||
|
Example: `<RNCamera barCodeTypes={[RNCamera.Constants.BarCodeType.qr]} />`
|
||||||
|
|
||||||
|
### Face Detection Related props
|
||||||
|
|
||||||
|
RNCamera uses the Google Mobile Vision frameworks for Face Detection, you can read more info about it [here](https://developers.google.com/android/reference/com/google/android/gms/vision/face/FaceDetector).
|
||||||
|
|
||||||
|
#### `onFacesDetected`
|
||||||
|
|
||||||
|
Method to be called when face is detected. Receives a Faces Detected Event object. The interesting value of this object is the `faces` value, which is an array with objects of the [Face](https://developers.google.com/android/reference/com/google/android/gms/vision/face/Face) properties.
|
||||||
|
|
||||||
|
#### `onFaceDetectionError`
|
||||||
|
|
||||||
|
Method to be called if there was an Face Detection Error, receives an object with the `isOperational` property set to `false` if Face Detector is NOT operational and `true`if it is.
|
||||||
|
|
||||||
|
#### `faceDetectionMode`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.FaceDetection.Mode.fast` (default) or `RNCamera.Constants.FaceDetection.Mode.accurate`
|
||||||
|
|
||||||
|
Specifies the face detection mode of the Face Detection API.
|
||||||
|
|
||||||
|
Use `RNCamera.Constants.FaceDetection.Mode.accurate` if you want slower but more accurate results.
|
||||||
|
|
||||||
|
#### `faceDetectionLandmarks`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.FaceDetection.Landmarks.all` or `RNCamera.Constants.FaceDetection.Landmarks.none` (default)
|
||||||
|
|
||||||
|
A landmark is a point of interest within a face. The left eye, right eye, and nose base are all examples of landmarks. The Face API provides the ability to find landmarks on a detected face.
|
||||||
|
|
||||||
|
#### `faceDetectionClassifications`
|
||||||
|
|
||||||
|
Values: `RNCamera.Constants.FaceDetection.Classifications.all` or `RNCamera.Constants.FaceDetection.Classifications.none` (default)
|
||||||
|
|
||||||
|
Classification is determining whether a certain facial characteristic is present. For example, a face can be classified with regards to whether its eyes are open or closed. Another example is whether the face is smiling or not.
|
||||||
|
|
||||||
|
#### `takePictureAsync([options]): Promise`
|
||||||
|
|
||||||
|
Takes a picture, saves in your app's cache directory and returns a promise.
|
||||||
|
|
||||||
|
Supported options:
|
||||||
|
|
||||||
|
- `quality` (float between 0 to 1.0). This property is used to compress the output jpeg file with 1 meaning no jpeg compression will be applied. If no value is specified `quality:1` is used.
|
||||||
|
|
||||||
|
- `base64` (boolean true or false) Use this with `true` if you want a base64 representation of the picture taken on the return data of your promise. If no value is specified `base64:false` is used.
|
||||||
|
|
||||||
|
- `exif` (boolean true or false) Use this with `true` if you want a exif data map of the picture taken on the return data of your promise. If no value is specified `exif:false` is used.
|
||||||
|
|
||||||
|
The promise will be fulfilled with an object with some of the following properties:
|
||||||
|
|
||||||
|
- `width`: returns the image's width (taking image orientation into account)
|
||||||
|
- `height`: returns the image's height (taking image orientation into account)
|
||||||
|
- `uri`: returns the path to the image saved on your app's cache directory.
|
||||||
|
- `base64`: returns the base64 representation of the image if required.
|
||||||
|
- `exif`: returns an exif map of the image if required.
|
||||||
|
|
||||||
|
#### `recordAsync([options]): Promise`
|
||||||
|
|
||||||
|
Records a video, saves it in your app's cache directory and returns a promise when stopRecording is called or either maxDuration or maxFileSize specified are reached.
|
||||||
|
|
||||||
|
Supported options:
|
||||||
|
|
||||||
|
- `quality`. This option specifies the quality of the video to be taken. The possible values are:
|
||||||
|
- `RNCamera.Constants.VideoQuality.2160p`.
|
||||||
|
- `ios` Specifies capture settings suitable for 2160p (also called UHD or 4K) quality (3840x2160 pixel) video output.
|
||||||
|
- `android` Quality level corresponding to the 2160p (3840x2160) resolution. (Android Lollipop and above only!).
|
||||||
|
- `RNCamera.Constants.VideoQuality.1080p`.
|
||||||
|
- `ios` Specifies capture settings suitable for 1080p quality (1920x1080 pixel) video output.
|
||||||
|
- `android` Quality level corresponding to the 1080p (1920 x 1080) resolution.
|
||||||
|
- `RNCamera.Constants.VideoQuality.720p`.
|
||||||
|
- `ios` Specifies capture settings suitable for 720p quality (1280x720 pixel) video output.
|
||||||
|
- `android` Quality level corresponding to the 720p (1280 x 720) resolution.
|
||||||
|
- `RNCamera.Constants.VideoQuality.480p`.
|
||||||
|
- `ios` Specifies capture settings suitable for VGA quality (640x480 pixel) video output.
|
||||||
|
- `android` Quality level corresponding to the 480p (720 x 480) resolution.
|
||||||
|
- `RNCamera.Constants.VideoQuality.4:3`.
|
||||||
|
- `ios` Specifies capture settings suitable for VGA quality (640x480 pixel) video output. (Same as RNCamera.Constants.VideoQuality.480p).
|
||||||
|
- `android` Quality level corresponding to the 480p (720 x 480) resolution but with video frame width set to 640.
|
||||||
|
|
||||||
|
If nothing is passed the device's highest camera quality will be used as default.
|
||||||
|
|
||||||
|
- `maxDuration` (float greater than 0). Specifies the maximum duration of the video to be recorded in seconds. If nothing is specified, no time limit will be used.
|
||||||
|
|
||||||
|
- `maxFileSize` (int greater than 0). Specifies the maximum file size, in bytes, of the video to be recorded. For 1mb, for example, use 1*1024*1024. If nothing is specified, no size limit will be used.
|
||||||
|
|
||||||
|
- `mute` (any value). If this flag is given in the option with any value, the video to be recorded will be mute. If nothing is specified, video will NOT be muted.
|
||||||
|
|
||||||
|
The promise will be fulfilled with an object with some of the following properties:
|
||||||
|
|
||||||
|
- `uri`: returns the path to the video saved on your app's cache directory.
|
||||||
|
|
||||||
|
#### `stopRecording: void`
|
||||||
|
|
||||||
|
Should be called after recordAsync() to make the promise be fulfilled and get the video uri.
|
||||||
|
|
||||||
|
#### `Android` `getSupportedRatiosAsync(): Promise`
|
||||||
|
|
||||||
|
Android only. Returns a promise. The promise will be fulfilled with an object with an array containing strings with all camera aspect ratios supported by the device.
|
||||||
|
|
||||||
|
## Subviews
|
||||||
|
This component supports subviews, so if you wish to use the camera view as a background or if you want to layout buttons/images/etc. inside the camera then you can do that.
|
||||||
|
|
||||||
|
## Example
|
||||||
|
|
||||||
|
To see more of the `RNCamera` in action, with Face Detection, you can check out the source in [RNCamera Example](https://github.com/react-native-community/rncamera-example) repository.
|
||||||
|
|
||||||
|
## Open Collective
|
||||||
|
We are just beginning a funding campaign for react-native-camera. Contributions are greatly appreciated. When we gain more than $250 we will begin distributing funds to core maintainers in a fully transparent manner. Feedback for this process is welcomed, we will continue to evolve the strategy as we grow and learn more.
|
||||||
|
|
||||||
|
### Backers
|
||||||
|
|
||||||
|
Support us with a monthly donation and help us continue our activities. [[Become a backer](https://opencollective.com/react-native-camera#backer)]
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/0/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/0/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/1/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/1/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/2/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/2/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/3/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/3/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/4/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/4/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/5/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/5/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/6/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/6/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/7/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/7/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/8/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/8/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/9/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/9/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/10/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/10/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/11/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/11/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/12/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/12/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/13/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/13/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/14/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/14/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/15/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/15/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/16/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/16/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/17/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/17/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/18/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/18/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/19/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/19/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/20/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/20/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/21/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/21/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/22/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/22/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/23/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/23/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/24/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/24/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/25/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/25/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/26/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/26/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/27/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/27/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/28/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/28/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/backer/29/website" target="_blank"><img src="https://opencollective.com/react-native-camera/backer/29/avatar.svg"></a>
|
||||||
|
|
||||||
|
|
||||||
|
### Sponsors
|
||||||
|
|
||||||
|
Become a sponsor and get your logo on our README on Github with a link to your site. [[Become a sponsor](https://opencollective.com/react-native-camera#sponsor)]
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/0/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/0/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/1/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/1/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/2/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/2/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/3/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/3/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/4/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/4/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/5/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/5/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/6/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/6/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/7/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/7/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/8/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/8/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/react-native-camera/sponsor/9/website" target="_blank"><img src="https://opencollective.com/react-native-camera/sponsor/9/avatar.svg"></a>
|
||||||
|
|
||||||
|
|
||||||
|
------------
|
||||||
|
|
||||||
|
Thanks to Brent Vatne (@brentvatne) for the `react-native-video` module which provided me with a great example of how to set up this module.
|
Loading…
Reference in New Issue