原文:Getting Started with Sencha Touch 2: Build a Weather Utility App (Part 3)
作者:Lee Boonstra
Lee is a technical trainer at Sencha. She’s located in Amsterdam and has experience in both front-end and back-end development. Lee spends her spare time developing web and mobile apps. She is writing a cookbook for O'Reilly about Sencha Touch.
在三部分的Sencha Touch教程中,将创建“需要带伞吗”这个简单的而实用的应用程序,该应用将 从worldweatheronline.com提供的Web服务中加载天气信息。基于天气代码,该应用程序可以预测需要不需要带伞。
在本教程的最后一部分,将讨论生成,而这 需要使用Sencha Cmd和PhoneGap/Cordova。
对于原生应用程序,可是有原生API来检索设备的位置,还可以使用PhoneGap/Cordova将应用程序发布为iOS、Android、BlackBerry10或Windows Phone的原生移动应用程序。
注意:如果希望在iOS、BlackBerry或Windows Phone设备上 测试应用程序,需要授权密钥和开发人员账号。此外,如果是使用Cordova,还不能在Windows操作系统上生成iOS的应用程序 ,也不能在Mac OS X上生成Windows的应用程序。
为了参照,可以查看本教程的第一、二部分。
可以在本教程第二部分下载解决方案代码——完整的解决方案。
本教程的要求:
还可以选择安装以下软件来生成本地应用程序:
使用Sencha Cmd,看可以创建用于生产或测试的生产包。生产用的生成包将Sass样式表编译成为生产准备的CSS(精简包)。它还会复制静态图片以及将JavaScript(Sencha Touch框架类加上自己定义的类)生成为一个单一的精简、连接的文件,以便于文件下载和缓存。生产生成还将包括要启用本地缓存的缓存清单文件。
测试包则不包含这文件。在测试生成,在测试包中的Javascript和CSS文件将不会被精简且是可读的。
下面先来创建天气应用程序的生产生成。现在做的并不是创建本地生成。如果要将天气应用程序部署到自己的服务器上,就需要将生产生成的文件夹复制到web服务器上。
在命令中输入以下命令就可创建一个生产生成:
sencha app build production
sencha app build testing
查看一下文件夹结构,会发现,如果决定通过在线URL访问移动应用程序,这是一个可以直接在Web服务器上使用的文件夹结构。
可能你已经发现,字体并没有被复制到build文件夹,这可以通过手动复制或通过可以编辑生成过程来实现。下面来看看如何去实现。
Sencha Cmd会使用了Apache的ANT来执行生成过程。在隐藏的.sencha文件夹内,可以找到所有使用的任务。
如果希望自己修改生成过程,可以打开位于应用程序文件夹根目录的build.xml文件,并在文件结尾添加以下Ant任务:
<target name="-after-build"/> <target name="build" depends="init,-before-build,-build,-after-build" description="Copy over the font/dinmu folder and remove temp files"/> <copy todir="${basedir}/resources/css/stylesheets/fonts/dinmu" overwrite="true"> <fileset dir="${basedir}/resources/sass/stylesheets/fonts/dinmu"> <include name="**/*" /> </fileset> </copy> <copy todir="${build.dir}/resources/css/stylesheets/fonts/dinmu" overwrite="true"> <fileset dir="${basedir}/resources/sass/stylesheets/fonts/dinmu"> <include name="**/*" /> </fileset> </copy> <delete dir="${basedir}/${build.dir}"/>
sencha app build
有想过在设备上将应用程序作为原生应用程序来执行吗?使用诸如Adobe PhoneGap或Apache Cordova,就可以将应用程序发布为混合应用程序。
一旦有了混合应用程序,就可以使用设备API,如地理定位。地理定位会基于设备的GPS传感器或网络信号的推断提供定位数据访问。
在编辑器打开app\utils\Functions.js,并查看101行:
Ext.device.Geolocation.getCurrentPosition({ timeout: 5000, maximumAge: 10000, success: function(position) { var place = position.coords.latitude + "," + position.coords.longitude; Dinmu.utils.Functions.getWeather(place); Ext.Viewport.unmask(); }, failure: function() { Ext.Viewport.unmask(); Ext.Msg.alert('Timeout', 'Can not retrieve position, please retry.'); } });
当应用程序运行时,该类会根据设备自动选择正确的实现。
在生成需要带伞吗(Dinmu)应用程序之前,需要做以下两个检查:
都设置好了吧?真棒!现在只剩下使用PhoneGap或Cordova来生成一个原生应用程序了。
基于Sencha Touch的代码,有三种产品可以使用来创建原生应用程序:Sencha移动包、Adobe PhoneGap和Apache Cordova。所有这些产品都支持通过Sencha设备API来访问设备的硬件资源。
下面来了解一下这三个解决方案之间的差异:
使用packager.json来生成iOS或安卓生成本地包,可以通过安卓市场或苹果App Store进行分发。
可以使用PhoneGap Build云服务来(远程)打包应用程序并通过安卓市场、黑莓App World、Windows Phone Store或者苹果App Store来分发。它是最简单的解决方案,可以通过扫描QR代码在设备上测试应用程序。还可以生成本地应用程序。它是一个商业产品,免费版本只限于一个专用的应用程序。
Apache Cordova是阿帕奇软件基金会的一个顶层项目。Cordova是免费的、开源的、社区驱动的Adobe PhoneGap版本。Cordova可以打包本地应用程序,并通过安卓市场、黑莓App World、Windows Phone Store或者苹果App Store来分发。
通过命令行生成本地包需要安装XCode、安卓开发工具、BlackBerry 10 SDK或带有Visual Studio的Windows 8 Pro。
通过PhoneGap来生成包需要(免费)Adobe(PhoneGap Build)账号:https://build.phonegap.com/apps。
注意:本教程将使用PhoneGap Build。如果更喜欢使用Cordova,可以使用在本教程使用的相同的命令,不过需要在命令行将将phonegap替换为ccordova。
生成混合应用程序的第一步是在项目目录使用以下命令来启用它:
sencha phonegap init <APP-ID> <APP-NAME>
注意:如果希望发布iOS应用程序,需要确保app Id是在苹果门户网站注册的哪个。
以下是用来启用PhoneGap支持的命令:
sencha phonegap init com.sencha.dinmu Dinmu
MyApp/phonegap包含了完整的PhoneGap文件结构。如果使用Cordova来初始化项目,文件夹会被命名为cordova。
phonegap.platforms=ios android blackberry10 wp8
phonegap.build.remote=true # Username for PhoneGap Build phonegap.build.remote.username={username} # Password for PhoneGap Build phonegap.build.remote.password={password}
默认的Cordova/PhoneGap的config.xml文件包含了应用程序的元数据,下面来修改这个文件。
修改应用程序名称、应用程序说明和作者信息:
<name>Dinmu</name> <description> Do I need my Umbrella today? </description> <author email="[email protected]" href="http://www.mydomain.com"> Your name </author>
<preference name="EnableLocation" value="true" />
<preference name="fullscreen" value="false" />
<access origin="*" />
<icon src="icon.png" /> <icon src="resources/icons/Icon.png" /> <icon gap:platform="ios" height="57" src="resources/icons/Icon.png" width="57" /> <icon gap:platform="ios" height="72" src="resources/icons/Icon~ipad.png" width="72" /> <icon gap:platform="ios" height="114" src="resources/icons/[email protected]" width="114" /> <icon gap:platform="ios" height="144" src="resources/icons/[email protected]" width="144" /> <gap:splash gap:platform="ios" height="480" src="res/screen/ios/screen-iphone-portrait.png" width="320" /> <gap:splash gap:platform="ios" height="960" src="res/screen/ios/screen-iphone-portrait-2x.png" width="640" /> <gap:splash gap:platform="ios" height="1024" src="res/screen/ios/screen-ipad-portrait.png" width="768" /> <gap:splash gap:platform="ios" height="768" src="res/screen/ios/screen-ipad-landscape.png" width="1024" />
使用PhoneGap或Cordova初始化应用程序后,就可以在命令行运行以下命令来创建一个本地生成了:
sencha app build -run native
如果使用PhoneGap Build,在安卓设备上测试应用程序会相当容易。只需要扫描QR代码或下载、拖放.apk文件到手机的内存卡就行了。
对于iOS,需要配置和代码签名,从而保证应用程序来源于已知用户以及自从最后一次签名后没再修改过。Windows Phone开发人员和iOS开发人员需要一个付费的开发着账号。
一旦拥有一个iOS开发者账号,就需要设置证书、标识符和配置文件。要了解更多相关信息,请参阅苹果开发人员工具和Sencha Touch文档中的《 Packaging Native iOS Applications》。
当所有都设置好以后,就可以使用PhoneGap在命令行生成应用程序:
sencha app build native
要确保电话已连接到Mac OS X,以及在XCode生成和运行。
恭喜你,已经从零开始完成了一个Sencha Touch实用应用程序的构建。如果跟随本系列三个教程,就已经使用Sencha Cmd创建了应用程序,并为需要带伞吗应用程序创建所有的视图、模型、存储和控制器。还是用Sass创建了自定义主题,且创建了一个生产生成来发布到Web服务器或使用Adobe PhoneGap/Cordova生成一个混合应用程序。按照这个流程,就可以创建任何自己喜欢的应用程序了。
喜欢这一系列教程吗?参加培训吧……