Gha*_*Haq 5 audio mobile-application hybrid-mobile-app react-native
我正在尝试使用包react-native-audio-recorder-player在反应本机应用程序中录制音频。录音成功开始,但即使在调用stopRecorder()后仍继续录音。
尝试了 gitHub 上的许多解决方案,但没有任何帮助。这是我的代码
import React from 'react';
import { View, TouchableOpacity, Text} from 'react-native';
import AudioRecorderPlayer from 'react-native-audio-recorder-player';
export const Recorder = () => {
const audioRecorderPlayer = new AudioRecorderPlayer();
const onStartRecord = async () => {
await audioRecorderPlayer.startRecorder();
audioRecorderPlayer.addRecordBackListener(e => {
console.log('Recording . . . ', e.current_position);
return;
});
};
const onStopRecord = async () => {
const audio = await audioRecorderPlayer.stopRecorder();
audioRecorderPlayer.removeRecordBackListener();
};
return (
<View style={{flex: 1, justifyContent: 'center', alignItems: 'space-between'}}>
<TouchableOpacity onPress={onStartRecord}>
<Text>Start</Text>
</TouchableOpacity>
<TouchableOpacity onPress={onStopRecord}>
<Text>Stop</Text>
</TouchableOpacity>
</View>
);
};
Run Code Online (Sandbox Code Playgroud)
即使按下 Stop 后,控制台仍会进行Recording 。。。,以下是我的控制台。
Gha*_*Haq 18
对于这项工作,需要添加const audioRecorderPlayer = new AudioRecorderPlayer();外部组件。所以,组件看起来像这样。
import React from 'react';
import { View, TouchableOpacity, Text} from 'react-native';
import AudioRecorderPlayer from 'react-native-audio-recorder-player';
const audioRecorderPlayer = new AudioRecorderPlayer();
export const Recorder = () => {
const onStartRecord = async () => {
await audioRecorderPlayer.startRecorder();
audioRecorderPlayer.addRecordBackListener(e => {
console.log('Recording . . . ', e.current_position);
return;
});
};
const onStopRecord = async () => {
const audio = await audioRecorderPlayer.stopRecorder();
audioRecorderPlayer.removeRecordBackListener();
};
return (
<View style={{flex: 1, justifyContent: 'center', alignItems: 'space-between'}}>
<TouchableOpacity onPress={onStartRecord}>
<Text>Start</Text>
</TouchableOpacity>
<TouchableOpacity onPress={onStopRecord}>
<Text>Stop</Text>
</TouchableOpacity>
</View>
);
};
Run Code Online (Sandbox Code Playgroud)
进行此更改后,我的 stopRecorder 工作得非常顺利。
| 归档时间: |
|
| 查看次数: |
5184 次 |
| 最近记录: |