目前,随着Google的Android手机和苹果的iphone手机的逐渐普及,愈来愈多开发者加入到移动应用开发的大军当中。其中,Android应用是基于Java语言基础上进行开发的,而苹果公司的iphone则是基于C语言开发的。若是开发者编写的应用须要同时在不一样的移动设备上运行的话,则必需要掌握多种开发语言。而为了进一步简化移动应用的编程,Nitobi公司推出了一套开源的移动应用解决方案PhoneGap(
http://www.phonegap.com)。
PhoneGap是一款开源的手机应用开发平台,它仅仅只用HTML和JavaScript语言就能够制做出能在多个移动设备上运行的应用。PhoneGap将移动设备自己提供的复杂的API进行了抽象和简化,提供了一系列丰富的API供开发者调用,只要你会HTML和Javascript或者Java语言,就能够利用PhoneGap提供的API去调用各类功能,PhoneGap就能让你能够制做出在各类手机平台上运行的应用,这对移动应用开发者来讲无疑是个福音。 目前,PhoneGap已实现对iPhone/ipad、Android、Symbian,Palm、黑莓各版本绝大部分功能的支持,其中官方文档中对其支持的详细说明以下图所示:

在本文中,将以一个简单的能在Android平台上运行的HelloWorld的示例,讲解如何安装PhoneGap的开发框架并配合Eclipse进行开发的过程。
基于Android SDK安装PhoneGap框架
首先,要明白一点,就是要利用PhoneGap框架开发移动应用时,也是必须在开发环境上安装对应移动设备应用的SDK的。好比你要开发一个运行在Android上的应用,则必须安装 Android的SDK包,开发iphone应用,就要安装iphone sdk。本文将介绍如何安装基于Android SDK下安装PhoneGap。
不管是开发基于哪一种平台的移动应用,首先要到PhoneGap的官方网站下载

这里,因为咱们是构建Android应用,所以只有phonegap-android对咱们是有用的。
因为PhoneGap是经过Ruby语言以及所开发的目标移动设备的SDK一块儿搭配工做的,所以除了下载PhoneGap外,开发者还必须安装以下的软件(以Android为例)
Android SDK,建议安装最新的版本,好比Android 2.1或者2.2
Eclipse IDE
JDK 1.5以上
此外,咱们还要对windows下的运行环境变量进行设置。首先咱们到控制面板-系统-环境变量中,增长以下几个系统环境变量。
JAVA_HOME:指向所安装的JDK的目录,好比c:\jdk15
ANT_HOME:指向所安装的Apache_ANT目录,好比d:\ant
ANDROID_HOME;指向所安装的Android SDK目录,好比d:\androidsdk
对Path进行设置,分别将ruby,jdk,android sdk,ant加入到原有的path中,如:
c:\ruby\bin;c:\jdk15\bin;d:\ant\bin;d:\androidsdk\tools
其中,下载Ruby 1.9.1的Windows版本后,直接选择安装到指定目录便可。
在完成上面的这些工做后,咱们接下来就经过PhoneGap框架的脚手架功能,快速生成一个android的原型程序。
经过PhoneGap生成基于Android的原型程序
1 进入PhoneGap-Android目录,并进入MS-DOS方式,在命令行下,按以下格式执行该命令:
ruby bin/droidgap "[android_sdk_path]" [name] [package_name] "[www]" "[path]"
上述参数说明以下:
其中android_sdk_path指定了android sdk的安装位置,好比:
d:/androidsdk,注意这里不要写成“\”,应该是“/”做为分隔符。
Name:要生成的android应用的名字。
Package_name:生成的android应用中源代码中的包名,注意必须至少有一层的包关系,即com.XXXX的形式。
WWW:这里指应用中存放HTML,Javascipt,CSS的位置目录名称。
PATH:这里指经过PhoneGap生成的项目原型工程的目录位置,注意的是,该目录位置不能指定为eclipse的workspace工做空间内。
下面是一个例子:
ruby bin/droidgap “d:/androidsdk” HelloWorldGap com.phonegap www
“d:/HelloWorldGap”
运行上述命令后,会发如今D盘会生成一个HelloWolrdGap的工程目录,phonegap已经为咱们生成了项目的框架了。
将工程导入到ECLIPSE中
若是安装了Android for eclipse的插件ADT后,咱们能够将PhoneGap生成的工程导入到Eclipse中去。首先咱们打开Eclipse,新建一个Android Project,以下图

其中输入Project name的名称为HelloGapAndroid,其中在Create project from existing source中选择上文中用PhoneGap生成的项目的目录。以后在Eclipse中则会看到以下结构的

能够看到其中assets下的www目录存放了工程中须要用到的HTML、Javascript和CSS文件。此外,还要确认工程的lib目录下面,存在phonegap.jar文件。
接下来咱们试着运行下这个工程,会在模拟器中看到以下效果:

运行的结果是显示了PhoneGap中默认显示的index.html页面,其中演示了其中的一些功能,你们能够尝试去试验一下。
编写HelloWorld程序
接下来,咱们来在此基础上编写HelloWorld程序。咱们切换到index.html中去,在代码模式下,删除原来phonegap生成的代码,写入以下代码:
- <!DOCTYPE HTML>
- <html>
- <head>
- <meta name="viewport" content="width=320; user-scalable=no" /> <meta http-equiv="Content-type" content="text/html; charset=utf-8">
- <title>PhoneGap Android App</title>
- <script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
- <script type="text/javascript" charset="utf-8">
- var showMessageBox = function() {
- navigator.notification.alert("Hello World of PhoneGap");
- }
- function init(){
- document.addEventListener("deviceready", showMessageBox, true);
- }
- </script>
- </head>
- <body onload="init();" >
- </body>
- </html>
复制代码javascript
能够看到,这实际上是普通的HTML和Javascript代码。首先在onload触发的方法init中,经过Javascript的回调方法中调用了phonegap封装好的事件
deviceready,这个事件含义是当设备在将其应用程序加载完毕后触发的。在引入phonegap提供的API时,必须经过 的方式引入进行调用。在这里的回调函数showMessageBox中,就调用了phonegap封装好的方法 navigator.notification.alert,这个方法其实是
显示了一个带文本的提示框,运行结果以下图:

改进HelloWorld程序
接下来咱们改进下这个程序,实现的功能是咱们能够在文本框里输入名字,而后点肯定按钮后,弹出提示窗口显示Hello+你输入的名字。修改程序代码以下:
- <!DOCTYPE HTML>
- <html>
- <head>
- <meta name="viewport" content="width=320; user-scalable=no" />
- <meta http-equiv="Content-type" content="text/html; charset=utf-8">
- <title>PhoneGap</title>
- <script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
- <script type="text/javascript" charset="utf-8">
- var displayHello = function() {
- var name = document.getElementById("firstname").value;
- navigator.notification.alert("name" + name);
- }
- </script>
- </head>
- <body onload="init();" id="bdy" >
- <div id="txt">
- <input type="text" name="firstname" id="firstname" />
- </div>
- <div id ="btn">
- <a href="#" onclick="displayHello();">Say Hello</a>
- </div>
- </div>
- </body>
- </html>
复制代码html
若是你懂得HTML和Javascript的话,上面的程序实在容易理解。其中咱们添加了一个名为firstname的文本框,而且在按钮的onclick事件中调用的displayHello()方法中经过document.getElementById的Javascript方法得到了用户输入的名字,而后一样用navigator.notification.alert的方法输出结果,输入的界面和输出的结果以下图所示:


总结
经过PhoneGap这套开源框架对开发移动设备SDK的封装,咱们从此在开发移动应用时,只须要调用PhoneGap封装好的API,结合已有的Java、HTML、CSS和Javascript技术,就能够很方便地进行开发了,更多的资料请查看PhoneGap的帮助文档。