跨平台开发:初探PhoneGap移动开发框架

随着Google的Android手机和苹果的iPhone手机的逐渐普及,越来越多开发者加入到移动应用开发的大军当中。目前移动终端中的冠亚军Android,应用是基于Java语言基础上进行开发的;而苹果公司的iPhone则是基于C语言开发的。如果开发者编写的应用需要同时在不同的移动设备上运行的话,则必须要掌握多种开发语言,这已经成为开发团队的一大难题,在专访国内著名移动软件尚邮的首席架构师时也提到过跨平台软件开发的困难。而为了进一步简化移动应用的编程,很多公司推出解决方案,Adobe推出的“AIR for Android”,使Flash为Android开发本地应用成为可能。而Nitobi公司推也出了一套开源的移动应用解决方案PhoneGap。

创新互联公司从2013年成立,是专业互联网技术服务公司,拥有项目网站设计制作、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元塔什库尔干塔吉克做网站,已为上家服务,为塔什库尔干塔吉克各地企业和个人服务,联系电话:18980820575

移动开发推荐PhoneGap专题

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的官方网站下载

PhoneGap包(下载地址)。目前最新的版本是0.9.1,下载之后,解压缩后,会发现如下图所示的若干个文件夹:

这里,由于我们是构建Android应用,因此只有phonegap-android对我们是有用的。

由于PhoneGap是通过Ruby语言以及所开发的目标移动设备的SDK一起搭配工作的,因此除了下载PhoneGap外,开发者还必须安装如下的软件(以Android为例)

◆Android SDK,建议安装最新的版本,比如Android 2.1或者2.2

◆Eclipse IDE

◆Apache Ant 1.8.1

◆JDK 1.5以上

◆Android 的Eclipse开发插件ADT

◆Ruby 1.9.1,建议到官网直接下载1.9.1的版本直接安装。

此外,我们还要对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中,如:

 
 
 
 
  1. c:\ruby\bin;c:\jdk15\bin;d:\ant\bin;d:\androidsdk\tools  
  2.  

其中,下载Ruby 1.9.1的Windows版本后,直接选择安装到指定目录即可。

在完成上面的这些工作后,我们接下来就通过PhoneGap框架的脚手架功能,快速生成一个android的原型程序。

#p#

通过PhoneGap生成基于Android的原型程序

1 进入PhoneGap-Android目录,并进入MS-DOS方式,在命令行下,按如下格式执行该命令:

 
 
 
 
  1. ruby bin/droidgap "[android_sdk_path]" [name] [package_name] "[www]" "[path]"  
  2.  

上述参数说明如下:

其中android_sdk_path指定了android sdk的安装位置,比如:

d:/androidsdk,注意这里不要写成“\”,应该是“/”作为分隔符。

Name:要生成的android应用的名字。

Package_name:生成的android应用中源代码中的包名,注意必须至少有一层的包关系,即com.XXXX的形式。

WWW:这里指应用中存放HTML,Javascipt,CSS的位置目录名称。

PATH:这里指通过PhoneGap生成的项目原型工程的目录位置,注意的是,该目录位置不能指定为eclipse的workspace工作空间内。

下面是一个例子:

 
 
 
 
  1. ruby bin/droidgap “d:/androidsdk” HelloWorldGap com.phonegap www  
  2.   “d:/HelloWorldGap”  
  3.  

运行上述命令后,会发现在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页面,其中演示了其中的一些功能,大家可以尝试去试验一下。

#p#

编写HelloWorld程序

接下来,我们来在此基础上编写HelloWorld程序。我们切换到index.html中去,在代码模式下,删除原来phonegap生成的代码,写入如下代码:

 
 
 
 
  1. >    
  2.     
  3.         
  4.               
  5.     PhoneGap Android App title>    </li> <li>             <script type="text/javascript" charset="utf-8" src="phonegap.js"> script>            </li> <li>           <script type="text/javascript" charset="utf-8">    </li> <li>                      var showMessageBox = function() {     </li> <li>              navigator.notification.alert("Hello World of PhoneGap");     </li> <li>                      }     </li> <li>                        function init(){     </li> <li>            document.addEventListener("deviceready", showMessageBox, true);                    </li> <li>                      }     </li> <li>   script>    </li> <li>   head>    </li> <li><body onload="init();"  >    </li> <li>   body>    </li> <li> html>    </li> <li> </li> </ol></pre><p>可以看到,这其实是普通的HTML和Javascript代码。首先在onload触发的方法init中,通过Javascript的回调方法中调用了phonegap封装好的事件</p><p>deviceready,这个事件含义是当设备在将其应用程序加载完毕后触发的。在引入phonegap提供的API时,必须通过 的方式引入进行调用。在这里的回调函数showMessageBox中,就调用了phonegap封装好的方法 navigator.notification.alert,这个方法实际上是</p><p>显示了一个带文本的提示框,运行结果如下图:</p><p><p>#p#</p><p><strong>改进HelloWorld程序</strong></p><p>接下来我们改进下这个程序,实现的功能是我们可以在文本框里输入名字,然后点确定按钮后,弹出提示窗口显示Hello+你输入的名字。修改程序代码如下:</p><pre> <ol> <li>>    </li> <li>    </li> <li><html>    </li> <li>    </li> <li>  <head>    </li> <li>    </li> <li>    <meta name="viewport" content="width=320; user-scalable=no" />    </li> <li>    </li> <li>    <meta http-equiv="Content-type" content="text/html; charset=utf-8">    </li> <li>    </li> <li>    <title>PhoneGap title>    </li> <li>    </li> <li>              <script type="text/javascript" charset="utf-8" src="phonegap.js"> script>            </li> <li>    </li> <li>              <script type="text/javascript" charset="utf-8">    </li> <li>    </li> <li>              var displayHello = function() {     </li> <li>    </li> <li>                        var name =      document.getElementById("firstname").value;     </li> <li>    </li> <li>                        navigator.notification.alert("name" + name);     </li> <li>    </li> <li>            }     </li> <li>    </li> <li>    script>    </li> <li>    </li> <li>   head>    </li> <li>    </li> <li>  <body onload="init();" id="bdy" >    </li> <li>    </li> <li>            <div id="txt">    </li> <li>    </li> <li>            <input   type="text" name="firstname" id="firstname" />    </li> <li>    </li> <li>             div>    </li> <li>    </li> <li>            <div id ="btn">    </li> <li>    </li> <li>    <a href="#" class="btn" onclick="displayHello();">Say Hello a>    </li> <li>    </li> <li>             div>    </li> <li>    </li> <li>         div>    </li> <li>    </li> <li>   body>    </li> <li>    </li> <li> html>   </li> <li>   </li> </ol></pre><p>如果你懂得HTML和Javascript的话,上面的程序实在容易理解。其中我们添加了一个名为firstname的文本框,并且在按钮的onclick事件中调用的displayHello()方法中通过document.getElementById的Javascript方法获得了用户输入的名字,然后同样用navigator.notification.alert的方法输出结果,输入的界面和输出的结果如下图所示:</p><p><p><p><strong>总结</strong></p><p>通过PhoneGap这套开源框架对开发移动设备SDK的封装,我们今后在开发移动应用时,只需要调用PhoneGap封装好的API,结合已有的Java、HTML、CSS和Javascript技术,就可以很方便地进行开发了,更多的资料请查看PhoneGap的帮助文档。</p><p>了解Android开发更多内容请看</p><p>[[16032]]</p><p>【编辑推荐】</p><ol><li>Adobe AIR登陆Android 跨平台应用运行成现实</li><li>有效控制Android应用程序的耗电量</li><li>Android数据库事务浅析</li><li>nbandroid:NetBeans的Android插件</li></ol> <p> 文章标题:<a href="http://www.hantingmc.com/qtweb/news8/151108.html">跨平台开发:初探PhoneGap移动开发框架</a> <br> 转载来源:<a href="http://www.hantingmc.com/qtweb/news8/151108.html">http://www.hantingmc.com/qtweb/news8/151108.html</a> </p> <p> 网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等 </p> <p class="adpic"> <a href="https://www.cdcxhl.com/service/ad.html" target="_blank" class="ad">广告</a> <a href="" target="_blank" class="adimg"><img src=""></a> </p> <p class="copy"> 声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: <a href="https://www.cdcxhl.com/" target="_blank">创新互联</a> </p> </div> <div class="newsmorelb"> <p>猜你还喜欢下面的内容</p> <ul> <li> <a href="/qtweb/news7/151107.html">redis怎么更新字段</a> </li><li> <a href="/qtweb/news6/151106.html">Linux声音设置:一步步提高音效(linux声音设置)</a> </li><li> <a href="/qtweb/news5/151105.html">markdown做笔记优势</a> </li><li> <a href="/qtweb/news4/151104.html">想要利用CPU多核资源一Python中多进程(一)</a> </li><li> <a href="/qtweb/news3/151103.html">解决vue多余的报错</a> </li><li> <a href="/qtweb/news2/151102.html">怎么加入黑名单?(怎么加入黑名单微信)</a> </li><li> <a href="/qtweb/news1/151101.html">Azure扩展授权选项给予用户更多选择</a> </li><li> <a href="/qtweb/news0/151100.html">网络机顶盒可以当无线路由器</a> </li><li> <a href="/qtweb/news49/151099.html">写给开发者:记录日志的10个建议</a> </li> </ul> </div> </div> <div class="col-lg-3 noneb"> <div class="bkright" style="margin-top: 0"> <p><a href="https://www.cdcxhl.com/news/yxxwzjs/">营销型网站建设知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news4/95404.html">电脑怎样输IP地址?(服务器上如何添加ip地址)</a> </li><li> <a class="text_overflow" href="/qtweb/news37/235237.html">一篇文章带你了解CSSPseudo-classes(伪类)</a> </li><li> <a class="text_overflow" href="/qtweb/news27/177577.html">redis怎么实现数据同步</a> </li><li> <a class="text_overflow" href="/qtweb/news48/364248.html">微信写字颜色怎么设置?(微信如何设置字体风格,怎样设置微信聊天字体)</a> </li><li> <a class="text_overflow" href="/qtweb/news36/314536.html">基于K8S环境下实现MSSQL容器化部署(k8s mssql)</a> </li><li> <a class="text_overflow" href="/qtweb/news3/459353.html">Chrome 的网络钓鱼检测速度提高近 50 倍</a> </li><li> <a class="text_overflow" href="/qtweb/news45/450545.html">从Java走进Scala:使用元组、数组和列表</a> </li><li> <a class="text_overflow" href="/qtweb/news29/425779.html">Linux调整系统频率的实用经验(linux查看频率)</a> </li><li> <a class="text_overflow" href="/qtweb/news17/377817.html">如何用好百度推广?百度推广基本设置的要点是什么?</a> </li><li> <a class="text_overflow" href="/qtweb/news44/310594.html">现在哪里有便宜的云主机?阿里云怎么样?</a> </li><li> <a class="text_overflow" href="/qtweb/news19/203919.html">比较两个Linux文件的差异(两个文件比较linux)</a> </li><li> <a class="text_overflow" href="/qtweb/news39/391989.html">Oracle11提高字符集质量保障</a> </li><li> <a class="text_overflow" href="/qtweb/news44/287744.html">SQLServer重复数据删除的2个方案</a> </li><li> <a class="text_overflow" href="/qtweb/news42/500992.html">云服务器如何调用本地打印机「云服务器如何调用本地打印机设备」</a> </li><li> <a class="text_overflow" href="/qtweb/news48/187898.html">网站地图该如何设计?更利于SEO优化的网站地图设计方法</a> </li> </ul> </div> <div class="bkright tag"> <p><a href="https://www.cdcxhl.com/hangye/" target="_blank">行业网站建设</a></p> <ul> <li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/boligeduan/" target="_blank">玻璃隔断</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ldjbc/" target="_blank">履带搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/dibang/" target="_blank">地磅秤</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/xuanchuanpian/" target="_blank">宣传片制作</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bengche/" target="_blank">混凝土泵车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/opp/" target="_blank">OPP胶袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bolimo/" target="_blank">玻璃贴膜</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/gsdb/" target="_blank">工商代办</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zkj/" target="_blank">公路钻孔机</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/yangguangfang/" target="_blank">阳光房</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bangongkongjian/" target="_blank">办公空间设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/menlian/" target="_blank">门帘</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/fengyangtai/" target="_blank">封阳台</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/hwxxy/" target="_blank">户外休闲椅</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shachuang/" target="_blank">纱窗</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sdjbc/" target="_blank">隧道混凝土搅拌车</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="http://www.cdfuwuqi.com/" target="_blank">成都托管服务器</a>    <a href="http://www.cxjianzhan.com/mobile/" target="_blank">wap网站建设</a>    <a href="http://m.xwcx.net/phone/" target="_blank">做手机网站</a>    <a href="https://www.xwcx.net/" target="_blank">成都机柜租用</a>    <a href="http://chengdu.cdcxhl.cn/" target="_blank">成都网站营销推广</a>    <a href="http://www.cdxwcx.cn/tuoguan/guanghua.html" target="_blank">成都光华机房服务器托管</a>    <a href="http://www.kswsj.com/" target="_blank">成都网站制作</a>    <a href="http://www.xjjierui.cn/" target="_blank">新津网站运维</a>    <a href="http://www.ruijiemsc.com/" target="_blank">瑞杰管理</a>    <a href="http://www.bjlzdm.cn/" target="_blank">葆金莱自动门</a>    <a href="http://www.hongyifilm.cn/" target="_blank">鸿艺文化</a>    <a href="http://m.cdxwcx.com/" target="_blank">成都网站建设</a>    <a href="https://www.cdcxhl.com/link/" target="_blank">买链接</a>    <a href="http://chengdu.kswjz.com/" target="_blank">成都网站设计</a>    <a href="http://www.cdtuopan.cn/" target="_blank">成都木托盘</a>    <a href="https://www.xwcx.net/jigui.html" target="_blank">成都服务器机柜租用</a>    <a href="http://www.cxjianzhan.com/" target="_blank">网络营销推广</a>    <a href="https://www.cdcxhl.com/cqtuoguan.html" target="_blank">重庆服务器托管</a>    <a href="https://www.cdxwcx.com/tuiguang/zhenghe.html" target="_blank">全网营销</a>    <a href="http://chengdu.cdcxhl.com/xcx/" target="_blank">成都微信小程序开发</a>     </div> </div> <footer> <div class="carousel-inner footjz"> <div class="container"> <i class="icon iconfont zbw"></i> 高品质定制 <i class="icon iconfont"></i> 跨终端自动兼容 <i class="icon iconfont"></i> 节约开发成本 <i class="icon iconfont"></i> 开发周期短 <i class="icon iconfont"></i> 一体化服务 <button type="button" class="btn btn-default btn-lg" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 立即开始2800定制网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 2800定制网站建设</button> </div> </div> <div class="carousel-inner bqsy"> <div class="container"> <div class="lxfs"> <h4 class="yutelnone">028-86922220 13518219792</h4> <h4 class="yutelblock"><a href="tel:02886922220">028-86922220</a> <a href="tel:13518219792">13518219792</a></h4> <a class="btn btn-default" href="tencent://message/?uin=532337155&Site=&Menu=yes" role="button">网站建设<span>QQ</span>:532337155</a> <a class="btn btn-default" href="tencent://message/?uin=631063699&Site=&Menu=yes" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=532337155&version=1&src_type=web&web_src=oicqzone.com" role="button">网站制作<span>QQ</span>:532337155</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=631063699&version=1&src_type=web&web_src=oicqzone.com" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn-default nonea" href="tencent://message/?uin=1683211881&Site=&Menu=yes" role="button">售后QQ:1683211881</a> <div class="dz">创新互联建站专注: <a href="https://www.cdcxhl.com/" target="_blank">网站设计</a> <a href="https://www.cdcxhl.com/" target="_blank">网站制作</a> <a href="https://www.cdcxhl.com/" target="_blank">网站建设</a> <address>地址:成都太升南路288号锦天国际A幢10楼</address> </div> </div> <div class="bzdh dz"><img src="https://www.cdcxhl.com/imges/bottom_logo.png" alt="创新互联"> <p><a href="https://www.cdcxhl.com/menu.html" target="_blank">成都创新互联科技有限公司</a><br> Tel:400-028-6601(7x24h)</p></div> </div> </div> </footer> </body> </html> <script> $.getJSON ("../../qtwebpic.txt", function (data) { var jsonContent = { "featured":data } var random = jsonContent.featured[Math.floor(Math.random() * jsonContent.featured.length)]; $(".adpic .adimg").attr("href",random.link) $(".adpic img").attr("src",random.pic); }) </script>