ios - 媒体未在 iOS phonegap 1.5 应用程序中播放
<p><p>我正在使用 phonegap 1.5 开发 iOS 应用程序。在这个应用程序中,我使用 phonegap 的媒体 API 播放 mp3 文件。但它不适用于iOS。相同的代码库在 Android 上运行没有任何问题。</p>
<p><strong>代码:</strong></p>
<p><strong>Audio.js</strong></p>
<pre><code> //
var my_media = null;
var mediaTimer = null;
function playAudio(src) {
//alert("inside");
//if (my_media == null) {
// Create Media object from src
my_media = new Media(src, onSuccess, onError);
//alert(my_media);
//} // else play current audio
// Play audio
my_media.play();
//alert("Played");
}
function onSuccess() {
console.log("playAudio():Audio Success");
}
// onError Callback
//
function onError(error) {
alert('code: ' + error.code + '\n' +
'message: ' + error.message + '\n');
}
</code></pre>
<p>我将 Audio.js 包含在我的 html 文件中,然后调用函数</p>
<p><code>playAudio("audio/welcome.mp3");</code></p>
<p>我所有的 mp3 文件都位于 <strong>www/audio</strong> 文件夹中。</p>
<p>我使用警报语句进行调试,调用到这行代码
<code>my_media = new Media(src, onSuccess, onError);</code></p>
<p>xcode 的控制台没有错误回调或没有错误。</p>
<p>我在这里遗漏了什么吗?可能是什么问题?</p></p>
<br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
<p><p>Phonegap 很难让东西表现得与它应该有的不同,尤其是在媒体和插件方面。您需要根据设备更改文件路径(使用 Cordova 设备插件):</p>
<pre><code>//Gets Device Platform
document.addEventListener("deviceready", getDevicePlatform, false);
function getDevicePlatform() {
$scope.devicePlatform = device.platform;
console.log(device.platform);
}
</code></pre>
<p>然后正确设置媒体播放器文件路径:</p>
<pre><code>if ($scope.devicePlatform == "Android") {
var songFilePath = '/android_asset/www/res/' + song.name + '.mp3';
}
else {
var songFilePath = 'res/' + song.name + '.mp3';
}
$scope.song = new Media(songFilePath);
</code></pre>
<p>歌曲 .name 很特别,我必须动态获取路径,但主要是对于 Android 设备,您需要/android_asset/,但对于 iOS 和 PhoneGap 等其他设备,您可以使用正常的文件路径到媒体在/www 文件夹中。</p></p>
<p style="font-size: 20px;">关于ios - 媒体未在 iOS phonegap 1.5 应用程序中播放,我们在Stack Overflow上找到一个类似的问题:
<a href="https://stackoverflow.com/questions/20854736/" rel="noreferrer noopener nofollow" style="color: red;">
https://stackoverflow.com/questions/20854736/
</a>
</p>
页:
[1]