PhoneGap MediaCapture 插件不起作用

Posted

技术标签:

【中文标题】PhoneGap MediaCapture 插件不起作用【英文标题】:PhoneGap MediaCapture Plugins not working 【发布时间】:2015-07-23 17:54:44 【问题描述】:

我的 phoneGap 构建有问题,我正在尝试构建一个录音应用程序,我已准备好所有插件和代码,当我使用 phoneGap ios 模拟器并加载该应用程序时,它允许我录音。当我去 build.phonegap 并使用他们的工具构建 apk 包然后我在我的 iPhone 上安装了该应用程序并单击按钮启动录音机时,没有任何反应,录音界面没有像使用模拟器那样启动。任何帮助都会很棒

*****Index.html

<!DOCTYPE html>

<html>
<head>
<title>M title</title>

<link rel="stylesheet" type="text/css" href="style.css">
<script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
<script type="text/javascript" charset="utf-8" src="cordova.js"></script>
<script type="text/javascript" charset="utf-8" src="custom.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 onload="getTitle();">
<ul id="nav">
    <li><a href="index.html">&larr; Back</a></li>
    <li><a href="#" id="ct" onclick="location.reload();"></a></li>
</ul>
    <button onclick="captureAudio();">Capture Audio</button> <br>
</body>
</html>

*****Config.xml

<widget xmlns="http://www.w3.org/ns/widgets" xmlns:gap="http://phonegap.com/ns/1.0" id="com.phonegap.iriejam" version="1.0.0">
  <name>irieJam</name>
  <description>Hello World sample application that responds to the deviceready event.</description>
  <author href="http://phonegap.com" email="support@phonegap.com">PhoneGap Team</author>
  <content src="index.html"/>
  <preference name="permissions" value="none"/>
  <preference name="orientation" value="default"/>
  <preference name="target-device" value="universal"/>
  <preference name="fullscreen" value="true"/>
  <preference name="webviewbounce" value="true"/>
  <preference name="prerendered-icon" value="true"/>
  <preference name="stay-in-webview" value="false"/>
  <preference name="ios-statusbarstyle" value="black-opaque"/>
  <preference name="detect-data-types" value="true"/>
  <preference name="exit-on-suspend" value="false"/>
  <preference name="show-splash-screen-spinner" value="true"/>
  <preference name="auto-hide-splash-screen" value="true"/>
  <preference name="disable-cursor" value="false"/>
  <preference name="android-minSdkVersion" value="7"/>
  <preference name="android-installLocation" value="auto"/>
  <gap:plugin name="org.apache.cordova.battery-status"/>
  <gap:plugin name="org.apache.cordova.camera"/>
  <gap:plugin name="org.apache.cordova.media-capture"/>
  <gap:plugin name="org.apache.cordova.console"/>
  <gap:plugin name="org.apache.cordova.contacts"/>
  <gap:plugin name="org.apache.cordova.device"/>
  <gap:plugin name="org.apache.cordova.device-motion"/>
  <gap:plugin name="org.apache.cordova.device-orientation"/>
  <gap:plugin name="org.apache.cordova.dialogs"/>
  <gap:plugin name="org.apache.cordova.file"/>
  <gap:plugin name="org.apache.cordova.file-transfer"/>
  <gap:plugin name="org.apache.cordova.geolocation"/>
  <gap:plugin name="org.apache.cordova.globalization"/>
  <gap:plugin name="org.apache.cordova.inappbrowser"/>
  <gap:plugin name="org.apache.cordova.media"/>
  <gap:plugin name="org.apache.cordova.network-information"/>
  <gap:plugin name="org.apache.cordova.splashscreen"/>
  <gap:plugin name="org.apache.cordova.vibration"/>
  <gap:plugin name="org.apache.cordova.inappbrowser" />
  <icon src="icon.png"/>
  <icon src="www/res/icon/android/icon-36-ldpi.png" gap:platform="android" gap:qualifier="ldpi"/>
  <icon src="www/res/icon/android/icon-48-mdpi.png" gap:platform="android" gap:qualifier="mdpi"/>
  <icon src="www/res/icon/android/icon-72-hdpi.png" gap:platform="android" gap:qualifier="hdpi"/>
  <icon src="www/res/icon/android/icon-96-xhdpi.png" gap:platform="android" gap:qualifier="xhdpi"/>
  <icon src="www/res/icon/blackberry/icon-80.png" gap:platform="blackberry"/>
  <icon src="www/res/icon/blackberry/icon-80.png" gap:platform="blackberry" gap:state="hover"/>
  <icon src="www/res/icon/ios/icon-57.png" gap:platform="ios"  />
  <icon src="www/res/icon/ios/icon-72.png" gap:platform="ios"  />
  <icon src="www/res/icon/ios/icon-57-2x.png" gap:platform="ios"  />
  <icon src="www/res/icon/ios/icon-72-2x.png" gap:platform="ios"  />
  <icon src="www/res/icon/webos/icon-64.png" gap:platform="webos"/>
  <icon src="www/res/icon/windows-phone/icon-48.png" gap:platform="winphone"/>
  <icon src="www/res/icon/windows-phone/icon-173-tile.png" gap:platform="winphone" gap:role="background"/>
  <gap:splash src="www/res/screen/android/screen-ldpi-portrait.png" gap:platform="android" gap:qualifier="port-ldpi"/>
  <gap:splash src="www/res/screen/android/screen-mdpi-portrait.png" gap:platform="android" gap:qualifier="port-mdpi"/>
  <gap:splash src="www/res/screen/android/screen-hdpi-portrait.png" gap:platform="android" gap:qualifier="port-hdpi"/>
  <gap:splash src="www/res/screen/android/screen-xhdpi-portrait.png" gap:platform="android" gap:qualifier="port-xhdpi"/>
  <gap:splash src="www/res/screen/blackberry/screen-225.png" gap:platform="blackberry"/>
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait.png" gap:platform="ios"  />
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait-2x.png" gap:platform="ios"  />
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait-568h-2x.png" gap:platform="ios"  />
  <gap:splash src="www/res/screen/ios/screen-ipad-portrait.png" gap:platform="ios"  />
  <gap:splash src="www/res/screen/ios/screen-ipad-landscape.png" gap:platform="ios"  />
  <gap:splash src="www/res/screen/windows-phone/screen-portrait.jpg" gap:platform="winphone"/>
  <access origin="*"/>
  <plugin name="cordova-plugin-whitelist" version="1"/>
  <allow-intent href="http://*/*"/>
  <allow-intent href="https://*/*"/>
  <allow-intent href="tel:*"/>
  <allow-intent href="sms:*"/>
  <allow-intent href="mailto:*"/>
  <allow-intent href="geo:*"/>
  <platform name="android">
    <allow-intent href="market:*"/>
  </platform>
  <platform name="ios">
    <allow-intent href="itms:*"/>
    <allow-intent href="itms-apps:*"/>
  </platform>
</widget>

【问题讨论】:

【参考方案1】:

我遇到了这个问题,因为当您将 www 压缩文件夹上传到 build.phonegap 时,您必须包含 config.xml 以便 phonegap 使用适当的插件库生成应用程序。

【讨论】:

以上是关于PhoneGap MediaCapture 插件不起作用的主要内容,如果未能解决你的问题,请参考以下文章

PhoneGap 构建错误“不支持插件:...”

Phonegap蓝牙插件不起作用

Phonegap 构建错误“不支持插件:闪屏”

从 phonegap 中删除了平台,现在插件不起作用

PhoneGap 构建插件不起作用

Phonegap GPS 插件不起作用