停止音频 expo-av - React Native Expo
Stop Audio expo-av - React Native Expo
我在 react-native-expo.
中使用来自 expo-av 的 Audio
我可以 运行 在 Audio.sound 构造器上使用 loadAsync 方法播放音频。
虽然当我试图停止声音时它并没有停止声音。
以下是最简单的代码片段。这是停止声音的正确方法吗?我找不到解决方案。
import React, {useState, useEffect} from 'react';
import { Button } from 'react-native';
import { Audio } from 'expo-av';
export default function App() {
const [audioStatus, setAudioStatus] = useState(false)
const sound = new Audio.Sound();
useEffect(()=>{
(async () => {
console.log('status', audioStatus)
if (audioStatus) {
await sound.loadAsync('https://www.soundhelix.com/examples/mp3/SoundHelix-Song-1.mp3')
try {
await sound.playAsync()
} catch (e) {
console.log(e)
}
}else {
await sound.stopAsync()
await sound.unloadAsync()
}
})()
},[audioStatus])
return (
<Button color={audioStatus ? 'red' : 'green'} title={'play'} onPress={()=>setAudioStatus(!audioStatus)} />
);
}
提前致谢
这是一个 React 问题。每次您的组件呈现时,sound
变量都会被重置为一个新的、尚未加载的 Audio.Sound
对象。这里,sound
应该是组件状态的一部分。您可以更改行:
const sound = new Audio.Sound();
到
const [sound, setSound] = useState(new Audio.Sound());
它会起作用。
我在 react-native-expo.
中使用来自 expo-av 的 Audio我可以 运行 在 Audio.sound 构造器上使用 loadAsync 方法播放音频。
虽然当我试图停止声音时它并没有停止声音。
以下是最简单的代码片段。这是停止声音的正确方法吗?我找不到解决方案。
import React, {useState, useEffect} from 'react';
import { Button } from 'react-native';
import { Audio } from 'expo-av';
export default function App() {
const [audioStatus, setAudioStatus] = useState(false)
const sound = new Audio.Sound();
useEffect(()=>{
(async () => {
console.log('status', audioStatus)
if (audioStatus) {
await sound.loadAsync('https://www.soundhelix.com/examples/mp3/SoundHelix-Song-1.mp3')
try {
await sound.playAsync()
} catch (e) {
console.log(e)
}
}else {
await sound.stopAsync()
await sound.unloadAsync()
}
})()
},[audioStatus])
return (
<Button color={audioStatus ? 'red' : 'green'} title={'play'} onPress={()=>setAudioStatus(!audioStatus)} />
);
}
提前致谢
这是一个 React 问题。每次您的组件呈现时,sound
变量都会被重置为一个新的、尚未加载的 Audio.Sound
对象。这里,sound
应该是组件状态的一部分。您可以更改行:
const sound = new Audio.Sound();
到
const [sound, setSound] = useState(new Audio.Sound());
它会起作用。