//创建数据库
public class MyHelper extends SQLiteOpenHelper {
public MyHelper(Context context) {
super(context, "bawei.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
//创建表
sqLiteDatabase.execSQL("create table jsoncache(id integer primary key autoincrement,json text not null,url text not null)");
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
//增删改查
public class JsonDao {
private MyHelper myHelper;
public JsonDao(Context context) {
myHelper = new MyHelper(context);
}
/**
* 插入数据的操作
*/
public void insertJson(String json,String url){
SQLiteDatabase database = myHelper.getWritableDatabase();
//现根据url删除json
database.delete("jsoncache","url = ?",new String[]{url});
//再去添加
ContentValues values = new ContentValues();
values.put("json",json);
values.put("url",url);
database.insert("jsoncache",null,values);
//关闭
database.close();
}
/**
* 查询数据库的操作....根据传入url获取存的json字符串
*/
public String getJson(String url){
SQLiteDatabase writableDatabase = myHelper.getWritableDatabase();
Cursor cursor = writableDatabase.query("jsoncache", new String[]{"json"}, "url = ?", new String[]{url}, null, null, null);
if (cursor.moveToNext()){
String json = cursor.getString(cursor.getColumnIndex("json"));
return json;
}
return null;
}
}
//添加数据查询数据
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
jsonDao = new JsonDao(getContext());
//1.先读取数据库中存的数据....有数据,解析展示....无数据,网络获取数据
String json = jsonDao.getJson("http://gank.io/api/data/Android/10/" + page_num);
if (json != null){
//解析 显示
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//往后面添加...
list.addAll(dataDataBean.getResults());
//设置适配器
setAdapter();
}else {
//1.设置listView的适配器
getDataFromNet();
}
//2.设置刷新模式
/*设置pullToRefreshListView的刷新模式,BOTH代表支持上拉和下拉,PULL_FROM_END代表上拉,PULL_FROM_START代表下拉 */
refreshListView.setMode(PullToRefreshBase.Mode.BOTH);
//3.通过getLoadingLayoutProxy 方法来指定上拉和下拉时显示的状态的区别(也就是设置向下拉的时候头部里面显示的文字)
//此时这里设置的是下拉刷新的时候显示的文字,所以第一个设置true表示现在是刷新,第二个设置为false
startLabels = refreshListView.getLoadingLayoutProxy(true, false);
startLabels.setPullLabel("下拉刷新");
startLabels.setRefreshingLabel("正在刷新...");
startLabels.setReleaseLabel("放开刷新");
ILoadingLayout endLabels = refreshListView.getLoadingLayoutProxy(false, true);
endLabels.setPullLabel("上拉刷新");
endLabels.setRefreshingLabel("正在载入...");
endLabels.setReleaseLabel("放开刷新...");
//4.设置监听事件
/**
* 如果Mode设置成Mode.BOTH,需要设置刷新Listener为OnRefreshListener2,并实现onPullDownToRefresh()、
* onPullUpToRefresh()两个方法。
如果Mode设置成Mode.PULL_FROM_START或Mode.PULL_FROM_END,需要设置刷新Listener为OnRefreshListener,
同时实现onRefresh()方法。
当然也可以设置为OnRefreshListener2,但是Mode.PULL_FROM_START的时候只调用onPullDownToRefresh()方法,
Mode.PULL_FROM_END的时候只调用onPullUpToRefresh()方法
*/
refreshListView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {
//下拉刷新的时候调用的方法....请求第一页的数据,清空之前的数据,然后再添加设置适配器
@Override
public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {
//下拉刷新....请求第一页的数据,清空之前的数据,然后再添加设置适配器
getRefreshData();
}
//上拉刷新的时候调用的方法..page++,然后在请求数据
@Override
public void onPullUpToRefresh(PullToRefreshBase<ListView> refreshView) {
//上拉刷新/加载...加载的时候页数++
page_num++;
getDataFromNet();
}
});
}