当前位置:文档之家› Android手机天气预报项目报告

Android手机天气预报项目报告

开发目标现有的3 G技术和移动互联网技术的快速发展,智能手机功能的不断增强,让基于An droid平台的查询需求越来越多。

本软件就是利用现有的网络快速获取网络上的天气信息并显示到手机终端上,为用户提供实时的天气查询和近期天气查询服务,为工作、出行等带来便利。

通过Web Service等技术让用户体验到前所未有的移动计算。

第2章项目设计项目总体设计本软件是一个App Widget应用程序,启动程序后可以进行城市、更新频率的设置,可以通过图片和文字显示当前和未来的天气状况,包括温度、湿度、风向和雨雪情况等。

这些天气数据是通过后台服务获取的,这个后台服务可以按照一定的时间间隔,通过Google提供的服务获取天气预报信息,并将天气信息保存在数据库中。

该软件的基本功能需求有:(1)启动App Widget应用程序;(2)设置界面:对要显示天气预报的城市及更新频率进行设置;(3)显示界面:通过文字和图片显示当前的天气情况,包括日期、时间、城市、最高温度、最低温度、当前温度等。

(4)详细界面:在显示出“显示界面”上所有信息的同时用列表的形式显示今后四天的天气情况。

技术框架设计开发环境An droid的上层应用程序是用Java语言开发的,一般情况下是基于Dalvik虚拟机的,所以Google公司推荐使用主流的Java集成开发环境Eclipse。

而用Java语言进行开发,需要用到SUN公司提供的Java SDK(其中包括JRE Java Run time En viro nment) 。

此外,An droid 的应用程序开发和Java开发有较大区别的,需要使用Google提供的An droid SDK。

同时,要在Eclipse上安装ADT为An droid开发提供开发工具的升级或者变更,是Eclipse下开发工具的升级或下载的工具。

简言之,需要以下软件,才能搭建An droid开发环境,从而进行An droid 应用程序的开发。

(1)Java SDK(2)Eclipse(3)An droid SDK⑷ADT技术支持本软件使用基于SOAP简单对象访问协议)的Web Service技术来实现与服务器端的信息交互,获取网络上的数据。

Web Service使用基于XM技术的消息处理,作为基本的数据通讯方式。

WebService建立在一些通用协议的基础上,如HTTR SOAP XML WSDJ_ UDD等。

各应用程序通过网络协议和规定的一些标准数据格式(HTTR XML SOAR来访问Web Service。

而所有的SOA消息都使用XM编码。

一条SOA消息就是一个包含有一个必需的SOA 的封装包,一个可选的SOA标头和一个必需的SOAI体块的XM文档。

XM文档在An droid平台上的解析可以通过SAX勺方式方便快速的完成。

解析An droid应用程序中获得的列表数据XM文件,对XM文件中的数据实现分离,得到指定的所需要的信息,然后执行存入数据库或显示到页面等相应的处理。

An droid 的开发组Activity 、Intent Receiver 、Service、ContentProvider等,可以实现不同页面之间的跳转;数据的获取和实现与数据库的实时交互;不同页面和进程间数据的共享。

数据库设计本软件中有两部分数据需要存储,一个是显示页面的数据,另一个是详细页面的数据。

但是数据量都不是很大,因此可以选择SQLite数据库作为存储数据的方法,建立数据库,并且建立两张表weather_widget和weather_forecast,分别存储显示页面的数据和详细页面的数据。

表2-1详细页面的数据库表weather_forecast 的结构表2-2显示页面的数据库表weather_widget的结构表2-2显示页面的数据库表weather_widget的结构功能模块设计从功能需求上分析可以看出,整个应用程序应划分为4个模块,分别是程序启动、用户界面、后台服务和数据库适配器,各模块之间的关系如图2-1 所示。

图2-1各功能模块间的关系从模块结构图中不难看出,后台服务是整个应用程序的核心,主要是“数据获取模块”,负责周期性的从Google获取天气信息。

后台服务在程序启动时就由AppWidgetProvider启动,也可由用户界面通过startService() 进行启动,启动后的后台服务将一直保持运行状态。

用户界面是从数据库中获取天气信息,而没有直接通过网络访问Google 的天气数据。

这样设计,一方面可以避免因网络通信不畅而造成界面失去响应;另一方面,后台服务可以及时更新数据,以保证数据的准确性。

数据库适配器封装了所有对SQLite数据库操作的方法,用户界面和后台服务会调用它来实现对数据库的操作。

第3章项目功能描述系统主要功能本软件要完成在an droid手机上实现天气的即时预报。

所涉及的功能有:1.启动程序后可以进行城市、更新频率的设置;2.可以通过图片和文字显示当前和未来的天气状况,包括温度、湿度、风向和雨雪情况等。

使用效果图实现与相应天气的结合。

3.这些天气数据是通过后台服务获取的,这个后台服务可以按照一定的时间间隔,通过Google提供的公共接口获取天气预报信息,并将天气信息保存在本地数据库中。

系统各模块具体实现321文件结构与用途在程序开发阶段,首先确定“ An droid手机天气预报软件”的工程名为ty-weather,据程序模块设计的内容,建立ty-weather工程。

工程源代码的结构如图3-1所示。

-ty-wsatKerto anim为了使源代码文件的结构更加清晰, Weather 工程设置了多个命名空间, 分别用来保存用户界面、数据库、后台服务和工具实体的源代码文件。

源代码文件的名称以及说明如表3-1所示。

表3-1 ty-weather 工程的文件用途说明- 击 dim. ty.E |J C«n£i curtAfiUritr. jm + ]7j DitiilForscistActirity. jwi + JF :r«c«tJroviitr.jacv^ +> [j_ Forec45tStrvic4.java #1 血 Forx 总HTim 需EHvi w, + |J F MEC 盜tlhd 窈t*+ jceHelper.- dt cflm. ty.util+ J_ ForneasLEntity.java Etl 血 PorecastUtil. j ava +1 [j_ Hi dge tEntity 」聊& 由 l2z?gen [Generated Java Files] IT M Ainh-oid 1.5沙 assets-resX f o t a t e curr entw e a ther. xmJ.X tr azts 1 :iteclLoudJ.e £t . x血M tr an slaters inO3A ^«nl.X tr all 1 it fer ai rJD4 - ^fnlX tr ansi atarain05_ 我ml田drawableB [S? layout世i 0ur 卸甜ml ■nL~fc>.(jf1. x-ml巨 LKX de I till t^rns. Mffiil. X we atlteir. xm]_一valuesX cel OT .xml[if str izv^s. xmlB HTD !|X' *电蚯tktrwi dg«t. Mml图 3-1 ty-weather 工程的源代码文件结构-ty-wsatKer to animAn droid的资源文件保存在/res 的子目录中。

其中、/res/a nim 目录中保存的是产生动画效果的XML文件,/res/drawable/目录中保存的是图像文件,/res/values 目录中保存的是用来自定义字符串和颜色的文件,/res/xml目录中保存的是XML格式的数据文件。

所有在程序开发阶段可以被调用的资源都保存在这些目录中,具体每个资源文件的用途可以参考表3-2 :表3-2资源文件名称与用途数据提供者数据提供者ForecastProvider 继承ContentProvider,是在应用程序间共享数据的一种接口机制。

应用程序在不同的进程中运行,因此,数据和文件在不同的应用程序之间是不能够直接进行访问的。

而Co nte ntProvider为程序员提供了较高级的数据共享方法,应用程序可以指定需要共享的数据,而其他应用程序则可以在不知数据来源、路径的情况下,对共享数据进行查询、添加、删除和更新等操作。

在创建ForecastProvider时,首先需要使用数据库、文件系统或网络实现底层存储功能,这里我们采用数据库建立了数据库设计中的两张表,从而实现了底层存储功能。

然后在继承Co nte ntProvider的类中实现基本数据操作的接口函数,包括添加、删除、查找和更新等功能。

(1)创建数据库:DatabaseHelper 类继承SQLiteOpenHelper,SQLiteOpenHelper 这个类可以辅助建立、更新和打开数据库。

DatabaseHelper在建立数据库时,同时建立了两个数据库表weather_widget和weather_forcast,并对保存配置信息的表进行了初始化。

(2)URI 设置:ContentProvider可以提供多个数据集,调用者使用URI (通用资源标识符)对不同的数据集的数据进行操作。

URI用来定位任何远程或本地的可用资源。

ContentProvider 使用的URI语法结构,我们就需要先来对URI进行设置。

(3)查询功能:执行数据的查询功能主要用到SQLiteQueryBuilder 的query()方法。

Query(SQLiteDatabase db,Stri ng[] projectio nln ,Stri ng selecti on, Stri ng[] selectio nArgs,Stri ng groupBy,Stri ng having,String sortOrder,String limit), 参数说明如下表3-3 所示:表3-3 query()方法的参数说明String having 相当于SQL语句当中的having部分(4)添加、删除、更新功能,对数据库表中存放的天气等信息进行有效的管理。

添加功能:public Uri insert(Uri uri, ContentValues values){}删除功能:public int delete(Uri uri,String selection,String[] selectio nArgs){}。

相关主题