首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用Cordova记录智能手机的音频

用Cordova记录智能手机的音频
EN

Stack Overflow用户
提问于 2016-03-07 13:28:48
回答 1查看 1.2K关注 0票数 0

我是科多瓦公司的非常新的,我正在尝试创建一个非常基本的应用程序来记录智能手机的音频。

所以我使用VS 2015添加了插件科多瓦-插件-媒体捕获

然后,从文档复制/粘贴这个完整的例子

代码语言:javascript
复制
<head>
<title>Capture Audio</title>

<script type="text/javascript" charset="utf-8" src="cordova.js"></script>
//I just remove the following line in MY code, I don't know what it corresponds
<script type="text/javascript" charset="utf-8" src="json2.js"></script> 

<script type="text/javascript" charset="utf-8">
    // Called when capture operation is finished
    function captureSuccess(mediaFiles) {
        var i, len;
        for (i = 0, len = mediaFiles.length; i < len; i += 1) {
            uploadFile(mediaFiles[i]);
        }
    }

    // Called if something bad happens.
    function captureError(error) {
        var msg = 'An error occurred during capture: ' + error.code;
        navigator.notification.alert(msg, null, 'Uh oh!');
    }

    // A button will call this function
    function captureAudio() {
        // Launch device audio recording application,
        // allowing user to capture up to 2 audio clips
        navigator.device.capture.captureAudio(captureSuccess, captureError, {limit: 2});
    }

    // Upload files to server
    function uploadFile(mediaFile) {
        var ft = new FileTransfer(),
            path = mediaFile.fullPath,
            name = mediaFile.name;

        ft.upload(path,
            "http://my.domain.com/upload.php",
            function(result) {
                console.log('Upload success: ' + result.responseCode);
                console.log(result.bytesSent + ' bytes sent');
            },
            function(error) {
                console.log('Error uploading file ' + path + ': ' + error.code);
            },
            { fileName: name });
    }
</script>
</head>
<body>
    <button onclick="captureAudio();">Capture Audio</button> <br>
</body>

但是,当我运行此代码并单击"Capture“按钮时,结果如下:

我还在控制台中出现了以下错误:

缺失exec:Capture.captureAudio TypeError:模拟器服务不是一个函数 在module.exports.exec (ripple.js:41) 在_capture (capture.js:52) 在Capture.captureAudio (capture.js:71) 在captureAudio (index.html:60) 在HTMLButtonElement.onclick (index.html:91)

我不太明白问题出在哪里..。

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-03-07 13:57:18

你试着用波纹仿真器来测试你的应用程序,它只是一个仿真器,并不能模拟所有的设备功能,比如录制音频文件。另见这个答案

尝试使用一个真正的设备来测试你的应用程序。

编辑:我不确定是否有任何模拟器可以通过你的电脑硬件捕捉声音。例如,Android仿真器不能。

Android模拟器不具备捕捉音频的能力,但实际设备很可能提供这些功能。

摘自adroid.developer.com MediaRecorder文档

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35845052

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档