React-native-track-player 无法播放由 rn-fetch-blob 获取的本地文件
Posted
技术标签:
【中文标题】React-native-track-player 无法播放由 rn-fetch-blob 获取的本地文件【英文标题】:React-native-track-player can not play local files which is fetched by rn-fetch-blob 【发布时间】:2020-09-16 08:36:35 【问题描述】:使用 rn-fetch-blob 获取 .mp3 文件后,我输入了 console.log(filePathios) 并得到了如下路径:“/var/mobile/Containers/Data/Application/80D7496B-862A-44D6-9D3A -F0EF31B565CF/Documents/xxx.mp3"
我的曲目播放代码:
let filePathIos = `$fs.dirs.DocumentDir/$fileName`;
const thisSong = props.songs[0]
const track =
id: thisSong.id.toString(),
url: filePathIos,
title: thisSong.title,
artist: "xxx"
const togglePlayback = async () =>
setAudioStatus(!AudioStatus)
const currentTrack = await TrackPlayer.getCurrentTrack();
if (currentTrack == null)
await TrackPlayer.add(track);
await TrackPlayer.play();
else
if (AudioStatus)
await TrackPlayer.play();
else
await TrackPlayer.pause();
问题是:本地文件下载成功,可以在本地打开。但是上面的代码不起作用。当我尝试按下切换按钮时,xcode 显示一些日志为:“开始/恢复播放”但歌曲仍未播放。
如果我尝试在上面的代码中更改一点点(将 url 更改为在线音乐 url),如下所示:
const track =
id: thisSong.id.toString(),
url: 'https://audio-previews.elements.envatousercontent.com/files/103682271/preview.mp3',
title: thisSong.title,
artist: "xxx"
然后该应用程序就像一个魅力,它可以播放歌曲。
我正在使用这些包来构建应用程序,由于某些特定原因,我无法升级/降级这些包:
平台:为 IOS 做出原生反应 react-native-track-player@1.1.3 react-native@0.59.2 rn-fetch-blob@0.10.15我没有运气尝试的事情:
将 URL 从url: filePathIos
更改为 url: 'file://' + encodeURIComponent(filePathIos)
感谢您的任何想法!
【问题讨论】:
出于同样的原因我打开了一个错误...github.com/react-native-kit/react-native-track-player/issues/… 目前,如果您“要求”该文件,它可以工作,但如果您尝试使用“file:///.. ." url 它没有。 @PabloRomeu 此外,它可以使用 Document ("file://Users/Documents/xxx.mp3") 中的文件,但不能使用 rn-fetch-blob 文件路径。我不知道发生了什么 【参考方案1】:嗯,找到了。问题是 1.2.3 版本在 Track.swift 上有一个错误,在 Dev branch 上已修复:
func getSourceUrl() -> String
return url.isLocal ? url.value.path : url.value.absoluteString
在 1.2.3 版本中是:
func getSourceUrl() -> String
return url.value.absoluteString
这会阻止播放本地文件。
您可以使用“Dev”分支作为解决方法。我会填写一份错误报告。
【讨论】:
感谢您抽出宝贵时间!固定行后的url是否需要以'file://'开头?类似于 file://Users/thainq/Library/Developer/CoreSimulator/Devices/3A86BC22-C9D2-4284-9D23-2F8ED01D4AE9/data/Containers/Data/Application/0C16AE28-F358-4281-9AA1-8918BA24EBA0/Documents/RNFetchBlob_tmp/ RNFetchBlobTmp_fwh078gqndf0clxbxyu4mb.mp3 hmm,只是尝试修复上面的行,但它似乎不起作用....我试图安装dev分支但是编译文件时出现很多错误...... 这对我来说是个问题...他们在 getSourceUrl 方法中添加了一个额外的“file://”,这就是问题...以上是关于React-native-track-player 无法播放由 rn-fetch-blob 获取的本地文件的主要内容,如果未能解决你的问题,请参考以下文章
Android 12 崩溃最新 react-native-track-player 版本
无法跳到下一个曲目 - React-Native-Track-Player
使用 react-native-track-player 从 flatlist 播放选定的歌曲
react-native-track-player 不播放从 Express 服务器请求的歌曲