搭建一个phonegap环境,用eclipse+phonegap

 
 
 
今天想重新搭建一个phonegap环境,用eclipse+phonegap,使用的是corvada1.7.0版本,ADT是17,基于android2.2
第一次搭建失败,很奇怪,不知道哪里出错,总是无法正常运行。官方上的文档也不可全信啊。急死人了。
刚刚弄好了,可能是以前没有严格按照官方要求去做,顺序什么的有问题,又重新做了一遍,现在可以了。
下面是步骤,以后会尝试用dreaweav搭建一个phonegap环境:
1、打开 Eclipse,在文件菜单下面点击 New > Android Project

 

这里的packagename可以填写自己想要的名字,下面点击完成就可以了。
2、在项目的根目录, 创建两个目录:
                   /libs
                   /assets/www
                   从刚才下载的PhoneGap中复制cordava-1.7.0.js 到/assets/www目录
                   从刚才下载的PhoneGap中复制cordova-1.7.0.jar 到/libs目录
                   从刚才下载的PhoneGap中复制xml文到夹到/res 目录
                   对Eclipse的src文件夹中的主Java文件进行少量调整:(如下图)
              将class的继承类由 Activity改为DroidGap
              将setContentView() 这一行替换为super.loadUrl("file:///android_asset/www/index.html");
              添加import org.apache.cordova.*;
              移除 import android.app.Activity;
就像下面这样:

 

 

 
3、右键单击AndroidManifest.xml并选择   打开方式 > 文本编辑器
将下面的权限设置拷贝到versionName之后:(如下图)红色部分是需要自己添加的:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.cordova.test"
    android:versionCode="1"
    android:versionName="1.0" >
<supports-screens 
    android:largeScreens="true" 
    android:normalScreens="true" 
    android:smallScreens="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.READ_PHONE_STATE" />
<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.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" />
    <uses-sdk android:minSdkVersion="8" />
 
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".TestActivity"
            android:label="@string/app_name" 
            android:configChanges="orientation|keyboardHidden">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
</manifest>
4、写一个HelloWorld测试一下吧:
在 “/assets/www”目录中新建文件index.html ,并粘贴如下代码:
<!DOCTYPE HTML>
<html>
<head>
<title>PhoneGap</title>
<script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
</head>
<body>
<h1>Hello World</h1>
</body>
</html>
5、运行
可以在模拟器中运行,在项目名上右击,选择运行方式->运行配置,在target选项卡中选择Manual单选框,再点击应用

再点击运行,会弹出一个下图的对话框:

上面一部分是把项目部署到实际的手机中,需要将手机连接到电脑中,并且开启USB调试,而下面一个框,则是部署到模拟器中,这里需要新建过模拟器,
没有的话,可以点击Manager新建一个模拟器,再选中这个模拟器,确定即可
先部署到模拟器中试试:

 

 

 
成功了。
部署到手机:

 

 

 

 

确定之后,手机端显示如下:

又成功了。
posted @ 2013-01-28 20:32  残星  阅读(3553)  评论(0编辑  收藏  举报