2

我正在尝试构建一个简单的音频播放器,从我们的服务器加载文件并播放它。目前此代码适用于 Android,但 iOS 不起作用,抛出错误

AVPlayerItem 实例失败,错误代码 -11850 和域“AVFoundationErrorDomain”

根据我收集到的信息,这是 iOS 在尝试加载音频文件时需要文件扩展名的问题。我们在我们的 React Web 应用程序上使用完全相同的服务器路由没有问题,它能够在一个简单的音频 html 元素中加载文件。Android 也可以使用下面的 React Native 代码运行:

const loadNewPlaybackInstance = async playing => {
  const source = { uri: url } // defined as `${api}/api/v1/voicemail?s3_email_id=${s3_email_id}`
  // This returns a voicemail.wav file 

  const initialStatus = {
    shouldPlay: playing,
    rate: 1.0,
    volume: volume,
    isMuted: false,
  }

  try {
    const { sound } = await Audio.Sound.createAsync(
      source,
      initialStatus,
      onPlaybackStatusUpdate,
    )
    setPlaybackInstance(sound)

    updateScreenForLoading(false)
  } catch (error) {
    console.error(error.message)
  }
}

我发现了另一个 SO question,但没有真正的答案。

Github 上还有一个未解决的问题,似乎被遗忘了,我也试图恢复。

有没有人知道如何解决这个问题?让我知道是否需要帮助的更多细节/上下文。

4

1 回答 1

0

更改 setAudioModeAsync 音频开始在扬声器上播放后,我遇到了同样的问题。

配置是这样的:

await Audio.requestPermissionsAsync();
await Audio.setAudioModeAsync({
  staysActiveInBackground: true,
  interruptionModeAndroid: Audio.INTERRUPTION_MODE_ANDROID_DO_NOT_MIX,
  shouldDuckAndroid: false,
  playThroughEarpieceAndroid: false,
  allowsRecordingIOS: false,
  interruptionModeIOS: Audio.INTERRUPTION_MODE_IOS_DO_NOT_MIX,
  playsInSilentModeIOS: true,
});
于 2021-12-30T15:07:48.190 回答