媒体不在iOS phonegap 1.5 app中播放

时间:2013-12-31 09:07:49

标签: ios audio cordova media

我正在使用phonegap 1.5开发iOS应用程序。在这个应用程序中我使用phonegap的Media API来播放mp3文件。但它不适用于iOS。相同的代码库在Android上运行时没有任何问题。

代码:

Audio.js

 //
    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');
    }

我在我的html文件中包含Audio.js然后调用函数

playAudio("audio/welcome.mp3");

我的所有mp3文件都位于 www / audio 文件夹中。

我使用alert语句调试,调用直到这行代码 my_media = new Media(src, onSuccess, onError);

xcode控制台中没有错误回调或没有错误。

我在这里遗漏了什么吗?可能是什么问题?

1 个答案:

答案 0 :(得分:1)

Phonegap相当困难,因为它的行为应该是不同的,特别是涉及媒体和插件时。您需要根据设备更改文件路径(使用Cordova设备插件):

//Gets Device Platform
document.addEventListener("deviceready", getDevicePlatform, false);
function getDevicePlatform() {
    $scope.devicePlatform = device.platform;
    console.log(device.platform);
}

然后正确设置媒体播放器文件路径:

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);

歌曲.name是我必须动态获取路径的特别之处,但主要的是,对于Android设备,您需要/ android_asset /,但对于iOS和PhoneGap等其他设备,您可以使用普通文件路径到媒体在/ www文件夹中。