Ionic如何创建mp3文件?

时间:2014-12-20 09:19:15

标签: javascript html angularjs ionic

我正在编写一个带有Ionic框架的网络应用程序,我正在尝试管理记录和播放声音机制。我正在使用以下代码段作为服务:

.factory('MediaSrv', function ($q, $ionicPlatform, $window) {
    var service = {
        loadMedia: loadMedia,
        getStatusMessage: getStatusMessage,
        getErrorMessage: getErrorMessage
    };

    function loadMedia (src, onError, onStatus, onStop) {
        var defer = $q.defer();

        $ionicPlatform.ready(function () {
            var mediaSuccess = function () {
                if (onStop) { onStop(); }
            };

            var mediaError = function (err) {
                _logError(src, err);
                if (onError) { onError(err); }
            };

            var mediaStatus = function (status) {
                if (onStatus) { onStatus(status); }
            };

            if ($ionicPlatform.is('android')) {
                src = '/android_asset/www/' + src;
            }

            defer.resolve(new $window.Media(src, mediaSuccess, mediaError, mediaStatus));
        });

        return defer.promise;
    }

    ...

    return service;
});

我可以播放现有的.mp3文件,但我无法在不存在的文件上录制。我认为如果找不到文件,它会自己创建文件。如何创建空.mp3个文件进行录制?

2 个答案:

答案 0 :(得分:1)

创建文件是服务器功能。您需要使用fs的节点服务器来创建文件。

来自Ionic的网站:

  

将Ionic视为前端UI框架,可以处理应用程序所需的所有外观和UI交互,以便引人注目。有点像“Bootstrap for Native”,但支持广泛的常见原生移动组件,光滑的动画和漂亮的设计。

答案 1 :(得分:0)

Ionic可以使用Cordova插件,因为它建立在它之上。

您可以使用媒体捕获插件捕获音频,但我发现这些记录为AMR文件。

来自[文档] [1]:

// capture callback
var captureSuccess = function(mediaFiles) {
    var i, path, len;
    for (i = 0, len = mediaFiles.length; i < len; i += 1) {
        path = mediaFiles[i].fullPath;
        // do something interesting with the file
    }
};

// capture error callback
var captureError = function(error) {
    navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};

// start audio capture
navigator.device.capture.captureAudio(captureSuccess, captureError, {limit:2});


  [1]: http://docs.phonegap.com/en/edge/cordova_media_capture_capture.md.html