Phonegap Android - deviceready事件未触发。

13

我在网上搜索了解决我的问题的方法,并找到了许多相关的帖子,但不幸的是,这些解决方案都不适用于我的情况。我是 Android 开发的新手,并按照 Apache Cordova!中找到的文档进行配置。

问题:deviceready 事件没有触发,以下是我的代码和配置以及错误日志。请指导我做错了什么,谢谢!!!

模拟器

AVD Device: nexus 7
Target: Android 4.2
Memory RAM: 512

MainActivity.java

    package com.example.pollo;

    import android.os.Bundle;
    import org.apache.cordova.*;
    import android.app.Activity;

    public class MainActivity extends DroidGap {

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            super.loadUrl("file:///android_asset/www/index.html");
        }
    }

index.html

    <html>
      <head>
        <title></title>
        <script src="cordova-2.2.0.js"></script>
        <script>
                function onLoad(){
                   console.log("Now Loading");
                   document.addEventListener("deviceready", myDeviceReadyListener, false);  
                }


                function myDeviceReadyListener(){
                    console.log("Device ready");
                    navigator.notification.alert("Phone is ready!");

                    var myDiv = document.getElementById('props');
                    myDiv.innerHTML = 'Device Name: ' + device.name;
                }
            </script>
      </head>
      <body onload="onLoad()">
        <h1>X App V.11</h1>
        <p id="props">Loading device properties...</p>
      </body>
    </html>

AndroidManifest.xml

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.example.pollo"
        android:versionCode="1"
        android:versionName="1.0" >

        <uses-sdk
            android:minSdkVersion="7"
            android:targetSdkVersion="17" />

        <supports-screens
            android:largeScreens="true"
            android:normalScreens="true"
            android:smallScreens="true"
            android:xlargeScreens="true"
            android:resizeable="true"
            android:anyDensity="true"
            />    
        <uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.RECORD_VIDEO"/>
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />   
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />   
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.BROADCAST_STICKY" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale"
        android:name="com.example.pollo.MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

    </manifest>

配置

assets>www>cordova-2.2.0.js
assets>www>index.html
res>xml>config.xml
AndroidManifest.xml
libs>cordova-2.2.0.jar
libs>android-support-v13.jar

Logcat - 错误日志

 12-31 01:50:58.323: E/Trace(659): error opening trace file: No such file or directory (2)
 12-31 01:51:45.653: E/StrictMode(552): android.app.ServiceConnectionLeaked: Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40d1b278 that was originally bound here

onLoad() 被调用,但 myDeviceReadyListener() 没有被调用~ 这是否与我选择的模拟器有关?

2个回答

12
有趣的是,昨天我碰到了同样的问题。我花了好几个小时进行调试,但我的发现仅限于在cordova-2.2.0.js文件的第6016行中,应用程序似乎默默地停止执行。为什么?不知道……日志中没有错误。也许是新权限或类似的东西。
总之,在浪费了很多时间进行调试后,我从头开始使用PhoneGap教程。我注意到,在发布PhoneGap 2.2.0时,他们使用的API级别为16,而不是17(这是我使用和您使用的)。只要我将应用程序的目标设置为API级别16,一切都重新开始工作了。
经验教训:暂时将您的应用程序的目标API级别设置为16(Android 4.1.2),那么您的应用程序将收到deviceready事件。

3
API 17之前,Cordova 2.2.0已经发布。API 17引入了一项更改,破坏了Java和JavaScript层之间的通信。如果您使用API level 16进行构建,则不会遇到问题。该问题在2.3.0中得到修复,然后您就可以使用API level 17进行构建了。 - Simon MacDonald
嗨,感谢您的帮助!由于我正在开发一个封闭网络,因此我花了很长时间才找到Android 4.1.2,并花了很长时间将其加载到AVD中,最初无法超越启动屏幕。问题,问题,问题。无论如何,是的,您的解决方案有效,deviceready正在触发,再次感谢并祝您新年快乐! - Esoup Edwin Ang

0

请确保您已安装正确版本的Node。 在安装期间,Phonegap检查节点版本,但如果您稍后切换到其他(较旧)版本,则会在编译时悄无声息地失败,这会导致deviceready事件无法触发。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接