首先在编码之前,我们要对程序进行需求分析:它要实现什么功能,怎么实现。对酷欧天气而言,他至少应该具备以下4点功能:1、罗列出全国的省、市、县。2、可以查看全国任意城市的天气信息。3、可以切换城市,查看其他城市的天气信息。4、可以手动更新以及后台定时自动更新天气信息。分析完需求后,就可以进行技术可行性分析了。首先需要考虑的问题是如何获得全国省市县的天气信息,这个可以通过接入免费的API接口,如中国天气网,新浪天气,雅虎天气等(在《第一行代码》中介绍的是接入中国天气网的API,但是好像存在数据错误的情况)。第一如何罗列出全国的省市县信息:访问如下地址:http://www.weather.com.cn/data/list3/city.xml,服务器会返回给我们一段XML文本信息,我们会发现它的格式是代号|城市,这样会利于我们解析和处理这段文本信息。获取到了城市代号,就可以访问:http://www.weather.com.cn/data/cityinfo/+城市代号+.html来获取相应的天气信息。这时我们发现发现服务器返回给我们的是这样的一段JSON数据:{"weatherinfo":{"city":城市名字,"cityid":xxxx,"temp1":"xx℃","temp2":"xx℃","weather":多雨转晴,“img1”:"d1.gif","img2":"d2.gif","ptime":"11:00"}}。根据这段JSON信息我们可以在显示天气信息的界面设置相应的UI控件。

第一阶段:首先我们要建几个包:存放Activity的代码、存放数据库(SQLite)的、存放BroadcastReceiver的,存放Service的,存放工具类的(如网络请求等),这样规范的写代码有助于我们不会乱了思路,有助于形成明确清晰严谨的思路。首先第一阶段我们要建好数据库和表,这样我们从服务器获取到的信息才能存储到本地。建三张表:Province,City,Country.表中有id,xxx_name(名字),xxx_code(代号);特别注意在City表中有provinced_id,它是City表关联Pronvince表的外键,同样的,在Country表中有city_id,它是Country表关联City表的外键。注意点:写完建表语句后要在onCreate()中调用execSQL()创建。接下来还需在这个包中创建一个类,将一些常用数据库操作封装(如储存数据,读取数据)起来,以便在程序中调用:编写完数据库,获取它的实例,再调用getWritableDatabase()创建数据库。关于储存和读取数据都是SQLiteDatabase的insert()和query()方法。

第二阶段:加入遍历全国省市县数据的功能。和服务器的交互是必不可少的,所以在工具包下建一个类用来访问网络。在这里我们使用HttpURLConnection的方式。注意点:调用getInputStream()获取到服务器返回的输入流,然后利用BufferedReader对输入流进行读取。接下来要新建一个类用来解析和处理服务器返回的数据。接下来在活动包中编写遍历省市县数据的活动:初始化工作:在onCreate()中获取一些控件的实例,初始化ArrayAdapeter并设置为ListView的适配器,获取CoolWeatherDB的实例,设置ListView的点击事件,在最后调用qureyProvinces()即在这里开始加载省级数据。在queryProvinces()中优先从数据库查询,如果没有再去服务器上查询,queryFromServer()中根据传入的参数来拼装查询地址。注意点:在解析和处理完数据后,我们再次调用queryProvinces()来重新加载数据,牵涉了UI操作(Android不允许在子线程中进行UI操作),因此必须在主线程中调用,这里借助了runOnUiThread()来实现从子线程切换到主线程。

第三阶段:查询天气并把天气信息显示出来。在技术分析时我们已经知道服务器返回的天气信息是JSON格式,因此我们需要在工具包中添加几个方法用来解析和处理服务器返回的JSON数据。注意点:实例化JSONObject对象,调用getJSONObject()取出数据,然后调用getString()获取各个元素的信息。接着要添加一个方法用来存储服务器返回的天气信息(采取SharedPreferences存储方式)。我们需要建一个Activity用来显示天气信息。注意点:同样是初始化工作,然后尝试从Intent中取出县级代号(getIntent().getStringExtra("")),如果取得到就调用queryWeatherCode(),否则调用showWeather()。

第四阶段:增加切换城市和手动更新天气功能。第五阶段:后台自动更新天气。需要创建一个长期在后台运行的定时任务,这边我们采取Alarm机制。最后修改图标和名称。

最后附上源代码[Github](https://github.com/Ucoon/coolweather.git)