package activity;
import java.util.ArrayList;
import java.util.List;
import model.City;
import model.County;
import model.Province;
import util.HttpCallbackListener;
import util.HttpUtil;
import util.Utility;
import android.app.Activity;
import android.app.ProgressDialog;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.view.Window;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import com.example.coolweather.R;
import db.CoolWeatherDB;
public class ChooseAreaActivity extends Activity {
public static final int LEVEL_PROVINCE = 0;
public static final int LEVEL_CITY = 1;
public static final int LEVEL_COUNTY = 2;
private ProgressDialog progressDialog;
private TextView titleText;
private ListView listView;
private ArrayAdapter<String> adapter;
private CoolWeatherDB coolWeatherDB;
private List<String> dataList = new ArrayList<String>();
private List<Province> provinceList;
/**
* 市列表
*/
private List<City> cityList;
/**
* 县列表
*/
private List<County> countyList;
/**
* 选中的省份
*/
private Province selectedProvince;
/**
* 选中的城市
*/
private City selectedCity;
/**
* 当前选中的级别
*/
private int currentLevel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.choose_area);
listView = (ListView) findViewById(R.id.list_view);
titleText = (TextView) findViewById(R.id.title_text);
adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,dataList);
listView.setAdapter(adapter);
coolWeatherDB = CoolWeatherDB.getInstance(this);
listView.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View view, int index,
long arg3) {
if (currentLevel == LEVEL_PROVINCE) {
selectedProvince = provinceList.get(index);
queryCities();
} else if (currentLevel == LEVEL_CITY) {
selectedCity = cityList.get(index);
queryCounties();
}
}
});
queryProvinces(); // 加载省级数据
}
/**
* 查询全国所有的省,优先从数据库查询,如果没有查询到再去服务器上查询。
*/
private void queryProvinces() {
provinceList = coolWeatherDB.loadProvinces();
if (provinceList.size() > 0) {
dataList.clear();
for (Province province : provinceList) {
dataList.add(province.getProvinceName());
}
adapter.notifyDataSetChanged();
listView.setSelection(0);
titleText.setText("中国");
currentLevel = LEVEL_PROVINCE;
} else {
queryFromServer(null, "province");
}
}
/**
* 查询选中省内所有的市,优先从数据库查询,如果没有查询到再去服务器上查询。
*/
private void queryCities() {
cityList = coolWeatherDB.loadCities(selectedProvince.getId());
if (cityList.size() > 0) {
dataList.clear();
for (City city : cityList) {
dataList.add(city.getCityName());
}
adapter.notifyDataSetChanged();
listView.setSelection(0);
titleText.setText(selectedProvince.getProvinceName());
currentLevel = LEVEL_CITY;
} else {
queryFromServer(selectedProvince.getProvinceCode(), "city");
}
}
/**
* 查询选中市内所有的县,优先从数据库查询,如果没有查询到再去服务器上查询。
*/
private void queryCounties() {
countyList = coolWeatherDB.loadCounties(selectedCity.getId());
if (countyList.size() > 0) {
dataList.clear();
for (County county : countyList) {
dataList.add(county.getCountyName());
}
adapter.notifyDataSetChanged();
listView.setSelection(0);
titleText.setText(selectedCity.getCityName());
currentLevel = LEVEL_COUNTY;
} else {
queryFromServer(selectedCity.getCityCode(), "county");
}
}
/**
* 根据传入的代号和类型从服务器上查询省市县数据。
*/
private void queryFromServer(final String code, final String type) {
String address;
if (!TextUtils.isEmpty(code)) {
address = "http://www.weather.com.cn/data/list3/city" + code + ".xml";
} else {
address = "http://www.weather.com.cn/data/list3/city.xml";
}
showProgressDialog();
HttpUtil.sendHttpRequest(address, new HttpCallbackListener() {
@Override
public void onFinish(String response) {
boolean result = false;
if ("province".equals(type)) {
result = Utility.handleProvincesResponse(coolWeatherDB,
response);
} else if ("city".equals(type)) {
result = Utility.handleCitiesResponse(coolWeatherDB,
response, selectedProvince.getId());
} else if ("county".equals(type)) {
result = Utility.handleCountiesResponse(coolWeatherDB,
response, selectedCity.getId());
}
if (result) {
// 通过runOnUiThread()方法回到主线程处理逻辑
runOnUiThread(new Runnable() {
@Override
public void run() {
closeProgressDialog();
if ("province".equals(type)) {
queryProvinces();
} else if ("city".equals(type)) {
queryCities();
} else if ("county".equals(type)) {
queryCounties();
}
}
});
}
}
@Override
public void onError(Exception e) {
// 通过runOnUiThread()方法回到主线程处理逻辑
runOnUiThread(new Runnable() {
@Override
public void run() {
closeProgressDialog();
Toast.makeText(ChooseAreaActivity.this,
"加载失败", Toast.LENGTH_SHORT).show();
}
});
}
});
}
/**
* 显示进度对话框
*/
private void showProgressDialog() {
if (progressDialog == null) {
progressDialog = new ProgressDialog(this);
progressDialog.setMessage("正在加载...");
progressDialog.setCanceledOnTouchOutside(false);
}
progressDialog.show();
}
/**
* 关闭进度对话框
*/
private void closeProgressDialog() {
if (progressDialog != null) {
progressDialog.dismiss();
}
}
/**
* 捕获Back按键,根据当前的级别来判断,此时应该返回市列表、省列表、还是直接退出。
*/
@Override
public void onBackPressed() {
if (currentLevel == LEVEL_COUNTY) {
queryCities();
} else if (currentLevel == LEVEL_CITY) {
queryProvinces();
} else {
finish();
}
}
}
package db;
import java.util.ArrayList;
import java.util.List;
import model.City;
import model.County;
import model.Province;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
public class CoolWeatherDB
{
public static final String DB_NAME = "cool_weather";
public static final int VERSION = 1;
private static CoolWeatherDB coolWeatherDB;
private SQLiteDatabase db;
private CoolWeatherDB(Context context){
CoolWeatherOpenHelper dbHelper = new CoolWeatherOpenHelper(context,DB_NAME,null,VERSION);
db = dbHelper.getWritableDatabase();
}
public synchronized static CoolWeatherDB getInstance(Context context){
if(coolWeatherDB !=null){
coolWeatherDB = new CoolWeatherDB(context);
}
return coolWeatherDB;
}
public void saveProvince(Province province){
if (province !=null){
ContentValues values = new ContentValues();
values.put("province_name", province.getProvinceName());
values.put("province_code",province.getProvinceCode());
db.insert("Province", null, values);
}
}
public List<Province> loadProvinces(){
List<Province>list = new ArrayList<Province>();
Cursor cursor = db.query("Province", null, null, null, null, null, null);
if(cursor.moveToFirst()){
do{
Province province = new Province();
province.setId(cursor.getInt(cursor.getColumnIndex("id")));
province.setProvinceName(cursor.getString(cursor.getColumnIndex("province_name")));
province.setProvinceCode(cursor.getString(cursor.getColumnIndex("province_code")));
list.add(province);
}while (cursor.moveToNext());
}
if(cursor !=null){
cursor.close();
}
return list;
}
public void saveCity(City city){
if(city !=null){
ContentValues values = new ContentValues();
values.put("city_name", city.getCityName());
values.put("city_code", city.getCityCode());
values.put("province_id", city.getProvinceId());
db.insert("city", null, values);
}
}
public List<City>loadCities(int provinceId){
List<City>list = new ArrayList<City>();
Cursor cursor = db.query("city", null, "provinceId=?", new String[]{String.valueOf(provinceId)}, null, null,null);
if(cursor.moveToFirst()){
do{
City city = new City();
city.setId(cursor.getInt(cursor.getColumnIndex("id")));
city.setCityName(cursor.getString(cursor.getColumnIndex("city_name")));
city.setCityCode(cursor.getString(cursor.getColumnIndex("city_code")));
city.setProvinceId(provinceId);
list.add(city);
}while(cursor.moveToNext());
}
if(cursor !=null){
cursor.close();
}
return list;
}
public void saveCounty(County county){
if(county !=null){
ContentValues values = new ContentValues();
values.put("county_name",county.getCountyName());
values.put("county_code",county.getCountyCode());
values.put("city_id", county.getCityId());
db.insert("county", null, values);
}
}
public List<County>loadCounties(int cityId){
List<County>list = new ArrayList<County>();
Cursor cursor = db.query("county", null, "city_id=?",new String[]{String.valueOf(cityId)}, null, null, null);
if(cursor.moveToFirst()){
do{
County county = new County();
county.setId(cursor.getInt(cursor.getColumnIndex("id")));
county.setCountyName(cursor.getString(cursor.getColumnIndex("county_name")));
county.setCountyCode(cursor.getString(cursor.getColumnIndex("county_code")));
county.setCityId(cityId);
}while(cursor.moveToNext());
}
if(cursor !=null){
cursor.close();
}
return list;
}
}
package db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class CoolWeatherOpenHelper extends SQLiteOpenHelper
{
public static final String CREATE_PROVINCE = "create table Province("
+ "id integer primary key autoincrement,"
+ "province_name text,"
+ "province_code text)";
public static final String CREATE_CITY = "create table City("
+ "id integer primary key autoincrement,"
+ "city_name text,"
+ "city_code text,"
+ "province_id integer)";
public static final String CREATE_COUNTY = "create table County("
+ "id integer primary key autoincrement,"
+ "county_name text,"
+ "county_code text,"
+ "city_id integer)";
public CoolWeatherOpenHelper(Context context,String name,CursorFactory factory,int version){
super(context,name,factory,version);
}
public void onCreate(SQLiteDatabase db){
db.execSQL(CREATE_PROVINCE);
db.execSQL(CREATE_CITY);
db.execSQL(CREATE_COUNTY);
}
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){
}
}
package model;
public class City
{
private int id;
private String cityName;
private String cityCode;
private int provinceId;
public int getId(){
return id;
}
public void setId(int id){
this.id = id;
}
public String getCityName(){
return cityName;
}
public void setCityName(String cityName){
this.cityName = cityName;
}
public String getCityCode(){
return cityCode;
}
public void setCityCode(String cityCode){
this.cityCode = cityCode;
}
public int getProvinceId(){
return provinceId;
}
public void setProvinceId(int provinceId){
this.provinceId = provinceId;
}
}
package model;
public class County
{
private int id;
private String countyName;
private String countyCode;
private int cityId;
public int getId(){
return id;
}
public void setId(int id){
this.id = id;
}
public String getCountyName(){
return countyName;
}
public void setCountyName(String countyName){
this.countyName = countyName;
}
public String getCountyCode(){
return countyCode;
}
public void setCountyCode(String countyCode){
this.countyCode = countyCode;
}
public int getCityId(){
return cityId;
}
public void setCityId(int cityId){
this.cityId = cityId;
}
}
package model;
public class Province
{
private int id;
private String provinceName;
private String provinceCode;
public int getId(){
return id;
}
public void setId(int id){
this.id = id;
}
public String getProvinceName(){
return provinceName;
}
public void setProvinceName(String provinceName){
this.provinceName = provinceName;
}
public String getProvinceCode(){
return provinceCode;
}
public void setProvinceCode(String provinceCode){
this.provinceCode = provinceCode;
}
}
package util;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
public class HttpUtil {
public static void sendHttpRequest(final String address,final HttpCallbackListener listener){
new Thread(new Runnable(){
public void run(){
HttpURLConnection connection = null;
try{
URL url = new URL(address);
connection = (HttpURLConnection)url.openConnection();
connection.setRequestMethod("GET");
connection.setConnectTimeout(8000);
connection.setReadTimeout(8000);
InputStream in = connection.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
StringBuilder response = new StringBuilder();
String line;
while((line = reader.readLine()) !=null){
response.append(line);
}
if(listener !=null){
listener.onFinish(response.toString());
}
}catch(Exception e){
if(listener!=null){
listener.onError(e);
}
}finally{
if(connection !=null){
connection.disconnect();
}
}
}
}).start();
}
}
package util;
import model.City;
import model.County;
import model.Province;
import android.text.TextUtils;
import db.CoolWeatherDB;
public class Utility {
public synchronized static boolean handleProvincesResponse(CoolWeatherDB coolWeatherDB,String response){
if(!TextUtils.isEmpty(response)){
String[] allProvinces = response.split(",");
if (allProvinces != null && allProvinces.length>0){
for(String p : allProvinces){
String[] array = p.split("\\|");
Province province = new Province();
province.setProvinceName(array[1]);
province.setProvinceCode(array[0]);
coolWeatherDB.saveProvince(province);
}
return true;
}
}
return false;
}
public static boolean handleCitiesResponse(CoolWeatherDB coolWeatherDB,String response,int provinceId){
if (!TextUtils.isEmpty(response)){
String[] allCities = response.split(",");
if(allCities != null && allCities.length>0){
for (String c:allCities){
String[] array = c.split("\\|");
City city = new City();
city.setCityCode(array[0]);
city.setCityName(array[1]);
city.setProvinceId(provinceId);
coolWeatherDB.saveCity(city);
}
return true;
}
}
return false;
}
public static boolean handleCountiesResponse(CoolWeatherDB coolWeatherDB,String response,int cityId){
if(!TextUtils.isEmpty(response)){
String[] allCounties = response.split(",");
if(allCounties != null && allCounties.length>0){
for(String c:allCounties){
String[] array = c.split("\\|");
County county = new County();
county.setCountyCode(array[0]);
county.setCountyName(array[1]);
county.setCityId(cityId);
coolWeatherDB.saveCounty(county);
}
return true;
}
}
return false;
}
}
没有报错也找不到是哪里出错了