大佬教程收集整理的这篇文章主要介绍了Expo av 播放对象的 onPlaybackStatusUpdate 仅在播放/停止时调用,而不是在progressUpdateIntervalMillis 的间隔时调用,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
onPlaybackStatusUpdate 应在每 100 毫秒后返回输出,但仅在播放或停止时返回。我的代码中是否缺少某些内容。 (我是 Expo 和 Expo AV 的新手)。 请参阅下面用于加载和播放音频文件的代码
if(!sound._loaded)
await sound.loadAsync(
require('./assets/Audio.mp3'),initialStatus,);
sound.setStatusAsync({progressUpdateIntervalMillis: 200});
sound.setonPlaybackStatusUpdate(onPlaybackStatusUpdate);
await sound.playAsync();
console.log(sound);
}
const initialStatus = (status) => {
console.log("initialStatus");
console.log(status);
}
let onPlaybackStatusUpdate = async (playbackStatus) => {
//if(!isNaN(playbackStatus.durationMillis))
//setTotalLength(playbackStatus.durationMillis/1000);
//setCurrentPos(playbackStatus.positionMillis.toString().split(".")[0]/1000);
//setIsPlaying(playbackStatus.isPlaying);
console.log("onPlaybackStatusUpdate");
console.log(playbackStatus);
}
对于声音实例,创建一个 ref
变量并使用它来触发暂停/播放以及加载。
Working Implementation Here
像这样,
const sound = React.useRef(new Audio.Sound());
用于加载音频,
const result = await sound.current.loadAsync(require('./test.mp3'),{},true);
if (result.isLoaded === false) {
console.log('Error in Loading Audio');
} else {
// Audio is loaded do whatever needed
}
暂停
const result = await sound.current.getStatusAsync();
if (result.isLoaded) {
if (result.isPlaying === true) {
// sound.current.pauseAsync();
// Pause Here
}
}
为了玩耍,
const result = await sound.current.getStatusAsync();
if (result.isLoaded) {
if (result.isPlaying === false) {
// sound.current.playAsync();
// play Here
}
}
以上是大佬教程为你收集整理的Expo av 播放对象的 onPlaybackStatusUpdate 仅在播放/停止时调用,而不是在progressUpdateIntervalMillis 的间隔时调用全部内容,希望文章能够帮你解决Expo av 播放对象的 onPlaybackStatusUpdate 仅在播放/停止时调用,而不是在progressUpdateIntervalMillis 的间隔时调用所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。