react-native-camera-kit/README.md

195 lines
5.6 KiB
Markdown
Raw Normal View History

2017-04-10 19:47:35 +00:00
2016-04-13 11:56:29 +00:00
# react-native-camera-kit
2016-04-17 12:46:49 +00:00
2016-07-14 14:18:58 +00:00
Native camera control.
2016-04-17 12:46:20 +00:00
2016-08-01 13:05:55 +00:00
![](img/crazyUnicorn.png) ![](img/zoom.png)
## Installation
2016-04-18 09:40:16 +00:00
2017-04-10 19:47:35 +00:00
#### Install using npm or yarn:
```bash
npm install react-native-camera-kit --save
```
Or if you're using yarn:
```bash
yarn add react-native-camera-kit
```
#### iOS
2016-04-18 09:40:16 +00:00
2016-07-14 14:18:58 +00:00
- Locate the module lib folder in your node modules: `PROJECT_DIR/node_modules/react-native-camera-kit/lib`
- Drag the `ReactNativeCameraKit.xcodeproj` project file into your project
2017-04-10 19:47:35 +00:00
- Add `libReactNativeCameraKit.a` to all your target **Linked Frameworks and Libraries** (prone to be forgotten)
#### Android
2016-04-18 09:40:16 +00:00
2017-04-10 19:47:35 +00:00
Add the following to your project's `settings.gradle` file:
2016-04-18 09:40:16 +00:00
2016-07-26 14:21:51 +00:00
2017-04-10 19:47:35 +00:00
```diff
+ include ':rncamerakit'
+ project(':rncamerakit').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-camera-kit/android/')
```
2016-07-26 14:21:51 +00:00
2017-04-10 19:47:35 +00:00
Then add to your app `app/build.gradle` in the `dependencies` section:
2016-07-26 14:21:51 +00:00
2017-04-10 19:47:35 +00:00
```diff
+ compile project(":rncamerakit")
2017-04-10 19:47:57 +00:00
```
2016-07-26 14:21:51 +00:00
Then in `MainActivity.java` add:
2017-04-10 19:47:35 +00:00
```diff
+ import com.wix.RNCameraKit.RNCameraKitPackage;
```
2016-07-26 14:21:51 +00:00
2017-04-10 19:47:35 +00:00
And in the package list in the same file (e.g. `getPackages`) add:
2016-07-26 14:21:51 +00:00
2017-04-10 19:47:35 +00:00
```diff
+ new RNCameraKitPackage()
```
2016-07-26 14:21:51 +00:00
2016-08-01 13:05:55 +00:00
## How to use
2016-04-18 09:40:16 +00:00
### CameraKitCamera inside the `render` function
2017-04-10 19:47:35 +00:00
```js
2016-07-14 14:18:58 +00:00
<CameraKitCamera
2017-04-10 19:47:35 +00:00
ref={cam => this.camera = cam}
style={{
flex: 1,
backgroundColor: 'white'
}}
cameraOptions={{
flashMode: 'auto', // on/off/auto(default)
focusMode: 'on', // off/on(default)
zoomMode: 'on', // off/on(default)
2017-04-10 19:47:35 +00:00
ratioOverlay:'1:1', // optional, ratio overlay on the camera and crop the image seamlessly
ratioOverlayColor: '#00000077' // optional
}}
2016-08-01 13:05:55 +00:00
/>
```
### CameraKitCamera cameraOptions
2016-08-01 13:05:55 +00:00
2017-04-10 19:47:35 +00:00
Attribute | Values | Description
----------------- | ---------------------- | -----------
flashMode |`'on'`/`'off'`/`'auto'` | camera flash mode (default is `auto`)
focusMode | `'on'`/`'off'` | camera focus mode (default is `on`)
zoomMode | `'on'`/`'off'` | camera zoom mode
ratioOverlay | `['int':'int', ...]` | overlay on top of the camera view (crop the image to the selected size) Example: `['16:9', '1:1', '3:4']`
ratioOverlayColor | Color | any color with alpha (default is ```'#ffffff77'```)
2016-08-01 13:05:55 +00:00
### CameraKitCamera API
2016-08-01 13:05:55 +00:00
#### checkDeviceCameraAuthorizationStatus
2017-04-10 19:47:35 +00:00
```js
2016-08-01 13:05:55 +00:00
const isCameraAuthorized = await CameraKitCamera.checkDeviceCameraAuthorizationStatus();
```
2017-04-10 19:47:35 +00:00
2016-08-01 13:05:55 +00:00
return values:
2016-07-14 14:18:58 +00:00
2016-08-01 13:05:55 +00:00
`AVAuthorizationStatusAuthorized` returns `true`
`AVAuthorizationStatusNotDetermined` returns `-1`
otherwise, returns ```false```
#### requestDeviceCameraAuthorization
2017-04-10 19:47:35 +00:00
```js
2016-08-01 13:05:55 +00:00
const isUserAuthorizedCamera = await CameraKitCamera.requestDeviceCameraAuthorization();
2016-07-14 14:18:58 +00:00
```
2017-04-10 19:47:35 +00:00
2016-08-01 13:05:55 +00:00
`AVAuthorizationStatusAuthorized` returns `true`
otherwise, returns `false`
#### capture
2016-08-01 13:05:55 +00:00
2016-07-14 14:18:58 +00:00
Capture image
2017-04-10 19:47:35 +00:00
```js
2016-07-14 14:18:58 +00:00
const image = await this.camera.capture(true);
```
#### setFlashMode
2016-07-14 14:18:58 +00:00
Set flash mode (`auto`/`on`/`off`)
2016-07-14 14:18:58 +00:00
2017-04-10 19:47:35 +00:00
```js
2016-07-14 14:18:58 +00:00
const success = await this.camera.setFlashMode(newFlashData.mode);
```
#### changeCamera
2016-07-14 14:18:58 +00:00
Change to fornt/rear camera
2017-04-10 19:47:35 +00:00
```js
2016-07-14 14:18:58 +00:00
const success = await this.camera.changeCamera();
```
### CameraKitGalleryView
2016-04-18 09:40:16 +00:00
2016-08-01 13:05:55 +00:00
Native Gallery View (based on `UICollectionView`)
2016-08-08 08:22:22 +00:00
2017-03-01 16:45:50 +00:00
![](img/camerakitgalleryview.png)
2017-04-10 19:47:35 +00:00
```js
2016-07-14 14:18:58 +00:00
<CameraKitGalleryView
2017-04-10 19:47:35 +00:00
ref={gallery => this.gallery = gallery}
style={{flex: 1, marginTop: 20}}
minimumInteritemSpacing={10}
minimumLineSpacing={10}
albumName={<ALBUM_NAME>}
columnCount={3}
2017-04-10 19:47:35 +00:00
onTapImage={event => {
// result.nativeEvent.selected - ALL selected images Photos Framework ids
}}
selectedImages={<MAINTAIN_SELECETED_IMAGES>}
selectedImageIcon={require('<IMAGE_FILE_PATH>'))}
unSelectedImageIcon={require('<IMAGE_FILE_PATH>')}
2016-08-01 13:05:55 +00:00
/>
2016-04-18 09:40:16 +00:00
```
2017-03-01 16:41:32 +00:00
2017-03-01 16:52:30 +00:00
Attribute | Values | Description
2017-03-01 16:41:32 +00:00
-------- | ----- | ------------
2017-04-10 19:47:35 +00:00
minimumInteritemSpacing | Float | Minimum inner Item spacing
minimumLineSpacing | Float | Minimum line spacing
imageStrokeColor | Color | Image stroke color
albumName | String | Album name to show
columnCount | Integer | How many clumns in one row
onTapImage | Function | Callback when image tapped
selectedImages | Array | Selected images (will show the selected badge)
selectedImageIcon | `require(_PATH_)` | - _DEPRECATED_ use Selection - Selected image badge image
unSelectedImageIcon | `require(_PATH_)` | - _DEPRECATED_ use Selection - Unselected image badge image
selection | Object | See Selection section
getUrlOnTapImage | Boolean | iOS only - On image tap return the image internal (tmp folder) uri (intead of `Photos.framework` asset id)
customButtonStyle | Object | See Custom Button section
onCustomButtonPress | Function | Callback when custom button tapped
contentInset (iOS) | Object | The amount by which the gellery view content is inset from its edges (similar to `ScrollView` contentInset)
2017-03-01 16:41:32 +00:00
#### Custom Button
2017-04-10 19:47:35 +00:00
2017-03-01 16:52:30 +00:00
Attribute | Values | Description
2017-03-01 16:41:32 +00:00
-------- | ----- | ------------
image | `require(_PATH_)` | Custom button image
backgroundColor | Color | Custom button background color
#### Selection
2017-03-01 16:52:30 +00:00
Attribute | Values | Description
2017-03-01 16:41:32 +00:00
-------- | ----- | ------------
selectedImage |`require(_PATH_)`|Selected image badge image
unselectedImage |`require(_PATH_)`|Unselected image badge image
imagePosition |`bottom/top-right/left` / `center`| Selected/Unselected badge image position (Default:`top-right`)
overlayColor |Color| Image selected overlay color
imageSizeAndroid |`large`/`medium`| Android Only - Selected badge image size