Реагировать на родную камеру не получится при втором вызове - PullRequest
0 голосов
/ 27 декабря 2018

React собственная камера не будет работать при втором вызове в Android.При втором вызове приложение вылетает.Я использую реагирующий-родной: 0.56.0 реагирующий-родной-камеры: 1.6.4 То же самое, когда я использую последнюю версию реагирующей-родной-камеры.Я не могу обновить реактивную версию до последней, поскольку у меня есть другой пакет, несовместимый с последней версией, и На эмуляторе он работает нормально, проблема только с реальными устройствами

Результат --scan:

Экран моей камеры

class CameraScreen extends Component {
  constructor(props) {
    super(props);
    this.state = {
      boltIconIsPressed: false,
    };
  }

  renderError() {
    Alert.alert(
      'Error',
      'Something went wrong, Try again!',
      [
        { text: 'Ok', style: 'cancel' },
      ],  
    );
    this.props.navigation.goBack();
  }

render() {
    if (this.props.isFocused) {
    return (
      <View style={styles.container}>
        <RNCamera
          ref={ref => {
            this.camera = ref;
          }}
          style={styles.preview}
          type={RNCamera.Constants.Type.back}
          flashMode={this.state.boltIconIsPressed ? RNCamera.Constants.FlashMode.off : RNCamera.Constants.FlashMode.on}
          onMountError={this.renderError.bind(this)}
          permissionDialogTitle={'Permission to use camera'}
          permissionDialogMessage={'We need your permission to use your camera phone'}
        />
        <View 
          style={{ flex: 0, 
                   flexDirection: 'row', 
                   justifyContent: 'center',
                   backgroundColor: 'transparent' }}
        >
          <Button
             outline
             rounded
             style={styles.capture}
             onPress={() => this.props.navigation.navigate('gallery')}
          >
            <Icon
              type='Entypo'
              name='image'
              style={{ color: '#862d59', }}
            />
        </Button>

          <Button
            outline
            rounded
            onPress={this.takePicture.bind(this)}
            style={styles.capture}
          >
            <Icon
              type='SimpleLineIcons'
              name='camera'
              style={{ color: '#862d59', }}
            />
          </Button>

          <Button
            outline
            rounded
            style={styles.capture}
            onPress={() => this.setState({ boltIconIsPressed: 
                       !this.state.boltIconIsPressed })}
          >
            <Icon
              type='MaterialCommunityIcons'
              name={this.state.boltIconIsPressed ? "flash-off" : "flash"}
              style={{ color: '#862d59', }}
            />
          </Button>
          </View>
         </View>
    );
   }
    return (
        <View />
      );
  }
  takePicture = async function () {
    let data = null;
    if (this.camera) {
      const options = { 
        width: 1800,
        base64: true,
      };
      console.log(data);
      data = await this.camera.takePictureAsync(options);
      this.props.navigation.navigate('uploadscreen', {
        image: data,
      });
    }
  };
}
export default withNavigationFocus(CameraScreen);

Заранее спасибо

1 Ответ

0 голосов
/ 31 декабря 2018

Я получил эту ошибку, потому что у меня нет хранилища для сохранения снятого изображения.Чтобы это работало, добавьте это в файл AndroidManifest.xml

android: largeHeap = "true"

...