75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
| import React, { PureComponent } from 'react';
 | |
| import { RNCamera } from 'react-native-camera';
 | |
| 
 | |
| import Icon from 'react-native-vector-icons/dist/FontAwesome';
 | |
| import { TouchableOpacity, Alert, StyleSheet } from 'react-native';
 | |
| 
 | |
| 
 | |
| export default class Camera extends PureComponent {
 | |
|      constructor(props) {
 | |
|           super(props);
 | |
|           this.state = {
 | |
|                takingPic: false,
 | |
|           };
 | |
|      }
 | |
| 
 | |
|      takePicture = async () => {
 | |
|           if (this.camera && !this.state.takingPic) {
 | |
| 
 | |
|                let options = {
 | |
|                     quality: 0.85,
 | |
|                     fixOrientation: true,
 | |
|                     forceUpOrientation: true,
 | |
|                };
 | |
| 
 | |
|                this.setState({ takingPic: true });
 | |
| 
 | |
|                try {
 | |
|                     const data = await this.camera.takePictureAsync(options);
 | |
|                     this.props.onPicture(data);
 | |
|                } catch (err) {
 | |
|                     Alert.alert('Error', 'Failed to take picture: ' + (err.message || err));
 | |
|                     return;
 | |
|                } finally {
 | |
|                     this.setState({ takingPic: false });
 | |
|                }
 | |
| 
 | |
|           }
 | |
|      };
 | |
| 
 | |
|      render() {
 | |
|           return (
 | |
|                <RNCamera
 | |
|                     ref={ref => {
 | |
|                          this.camera = ref;
 | |
|                     }}
 | |
|                     captureAudio={false}
 | |
|                     style={{ flex: 1 }}
 | |
|                     type={RNCamera.Constants.Type.back}
 | |
|                     androidCameraPermissionOptions={{
 | |
|                          title: 'Permission to use camera',
 | |
|                          message: 'We need your permission to use your camera',
 | |
|                          buttonPositive: 'Ok',
 | |
|                          buttonNegative: 'Cancel',
 | |
|                     }}>
 | |
|                     <TouchableOpacity
 | |
|                          activeOpacity={0.5}
 | |
|                          style={styles.btnAlignment}
 | |
|                          onPress={this.takePicture}>
 | |
|                          <Icon name="camera" size={50} color="#fff" />
 | |
|                     </TouchableOpacity>
 | |
|                </RNCamera>
 | |
|           );
 | |
|      }
 | |
| }
 | |
| 
 | |
| const styles = StyleSheet.create({
 | |
|      btnAlignment: {
 | |
|           flex: 1,
 | |
|           flexDirection: 'column',
 | |
|           justifyContent: 'flex-end',
 | |
|           alignItems: 'center',
 | |
|           marginBottom: 20,
 | |
|      },
 | |
| });
 |