上一篇我们讲到了,  Http Json的功能的抽取. 如果我们请求的是一个列表的数据呢?

我们使用那个功能就不是很好. 因为一个列表, 还有很多其他功能(比如每个listView都需要setAdapter, notifyDataSetChanged等操作,但是我们没必要在每个Activity都去做这样的操作, 直接交给父类处理即可,子类只管发送请求就行了), 所以这样重新定义了一个类, 供列表类型的Activity使用(BaseListFragment) .

1, 列表类型的Activity功能介绍 ,

①现在很多是把最新的数据加载到listView的最前面, 俗称下拉刷新 .

②但是还有另一类listView就是把最新的时候放在最后, 也就是 :上拉加载更多(最新)

总结来说就是一个降序,一个是升序. 各有的应用场景, 大部分适合第一种, 特别是经常更新的数据. 但是比如第二种就适合"课程"的列表, 用户总希望是从第1课往后排, 而不是第一课在最后面.

在父类定义一个布尔类型的变量即可:

	/** 是否是升序 */
	protected boolean ascending = false;

如果是升序, 则是第二种情况, 把下拉刷新的功能禁止即可.

2, 总体和上一篇文章的架构是类似的. 只是在父类的判断多了, 因为操作类型多了.

Http Json的功能模型在List Http Json里也是需要的, 所以回调接口在自己已有方法的基础上还继承了Http Json的回调接口ISingleCallback

下面是回调接口:

public interface <strong>IListCallback</strong><T> extends <strong>ISingleCallback </strong>{

	/**
	 * 当listView到达最后
	 */
	public void onReachLast();

	/**
	 * 刷新
	 */
	public void onRefresh();

	/**
	 * 解析json
	 *
	 * @param json
	 * @return
	 */
	public List<T> parseJson(String json);

	/**
	 * 获取最新数据
	 */
	public void sendLastestDataRequest(HttpParam params);

	/**
	 * 根据id获取最新数据
	 *
	 * @param id
	 */
	public void sendRefreshRequest(HttpParam params);

	/**
	 * 加载更多
	 */
	public void sendLoadMoreRequest(HttpParam params);
}

3, 下面是核心代码 :

	private void <strong>baseListRequest</strong>(final int key, final HttpParam params) {
		params.setUrl(listUrl);
		final int symbol = params.getInt(Constant.SYMBOL);
		if (TaskController.getInstance().exist(key)) {
			ToastUtil.showShortToast(getActivity(), R.string.task_executing);
			return;
		}
		new TaskHttp(key, new HttpCallback() {
			@Override
			public Object shouldExecute(HttpParam params) {
				return searchCache(key, params);
			}

			@Override
			public Object handleJsonData(String json) {
				if (StringUtil.isEmpty(json)) {
					return null;
				}
				try {
					return parseJson(json);
				} catch (Exception e) {
					e.printStackTrace();
				}
				return null;
			}

			@SuppressWarnings("unchecked")
			@Override
			public void onFinalResult(Object content) {
				finishPullOrUp();

				if (content != null) {
					if (content instanceof List) {
						List<T> tmp = (List<T>) content;
						if (ascending) {
							list.addAll(tmp);
						} else {
							// 下拉刷新
							if (symbol == Constant.SYMBOL_PULL_REFRESH) {
								list.addAll(0, tmp);
								checkResultCount(params, tmp);
							} else {// 加载更多
								list.addAll(tmp);
							}
							if (symbol == Constant.SYMBOL_LASTEST_DATA) {
								checkResultCount(params, tmp);
							}
						}
						if (adapter != null){
							adapter.notifyDataSetChanged();
						}
					} else if (content instanceof String) {
						ToastUtil.showLongToast(getActivity(),
								content.toString());
					}
				} else {
					if (symbol == Constant.SYMBOL_LOAD_MORE) {
						isLast = true;
					}
				}
				if (isLast) {
					mPullListView.setHasMoreData(false);
				}
			}

			@Override
			public void onFailed(int type, String msg) {
				finishPullOrUp();

				if (LogUtil.DEVELOP_MODE)
					LogUtil.error(TAG, msg);
				FragmentActivity activity = getActivity();
				if (activity != null) {
					ToastUtil.showShortToast(activity, msg);
				}
				mPullListView.errLoaded();
			}

			private void finishPullOrUp() {
				switch (symbol) {
				case Constant.SYMBOL_LASTEST_DATA:
				case Constant.SYMBOL_PULL_REFRESH:
					mPullListView.onPullDownRefreshComplete();
					setLastUpdateTime();
					break;
				case Constant.SYMBOL_LOAD_MORE:
					mPullListView.onPullUpRefreshComplete();
					break;
				}
			}

			private void checkResultCount(final HttpParam params, List<T> tmp) {
				if (params.getInt(Constant.MAX_RECORD) > tmp.size()) {
					mPullListView.setHasMoreData(false);
					isLast = true;
				}
			}

		}).execute(params);
	}

	public List<T> parseJson(String json) {
		return null;
	}

	/**
	 * 获取列表数据
	 *
	 * @param param
	 *            1:taskFlag,2:firstIndex,3:symbol
	 */
	<strong>private </strong>void <strong>sendListRequest</strong>(int key, HttpParam params) {
		int symbol = params.getInt(Constant.SYMBOL);
		switch (symbol) {
		case Constant.SYMBOL_PULL_REFRESH:
			params.addParam(Constant.MAX_RECORD, Integer.MAX_VALUE);
			break;
		case Constant.SYMBOL_LASTEST_DATA:
		case Constant.SYMBOL_LOAD_MORE:
			params.addParam(Constant.MAX_RECORD, Constant.RECORD_COUNT);
			if (ascending) {
				params.addParam(Constant.ASCENDING, "1");
			}
			break;
		}

		baseListRequest(key, params);
	}

	public void <strong>sendLoadMoreRequest</strong>(HttpParam params) {
		params.addParam(Constant.ACTION, "list").addParam(Constant.SYMBOL,
				Constant.SYMBOL_LOAD_MORE);
		sendListRequest(flagTaskLoadMore, params);
	}

	@Override
	public void <strong>sendLastestDataRequest</strong>(HttpParam params) {
		params.addParam(Constant.ACTION, "lastest").addParam(Constant.SYMBOL,
				Constant.SYMBOL_LASTEST_DATA);
		sendListRequest(flagTaskDefault, params);
	}

	@Override
	public void <strong>sendRefreshRequest</strong>(HttpParam params) {
		params.addParam(Constant.ACTION, "list").addParam(Constant.SYMBOL,
				Constant.SYMBOL_PULL_REFRESH);
		sendListRequest(flagTaskRefresh, params);
	}

这样也就完成了.  在子类那就很方便了, 只需要做请求就可以了, 界面的渲染都不要做了, 父类全做好了.

Android项目-高考作文项目架构(三)的更多相关文章

  1. Android项目-高考作文项目架构(二)

    1, 普通的http json请求 请看下面架构草图: 这样就抽象出了其他Activity可能需要的Http Json请求的功能. 只要其他Activity有Http Json请求的需求都可以继承Ba ...

  2. Android项目-高考作文功能简介(一)

    前言 :  开发安卓也已2年多了近3年了, 在自己刚入行的时候就有自己独立开发一个App的想法. 后来自己做了<<高考作文>>这一App. 后面续续断断的维护者. 也因为功能简 ...

  3. Android项目-高考作文-使用ORMLite抽象公共的Dao层

    1, 定义统一的Dao接口 public interface IDao<T> { public abstract T getSingleById(int id); public abstr ...

  4. Android项目-高考作文-抽象BaseAdapter

    1, 在使用baseAdapter的时候,总是有需要重复的代码如: @Override public int getCount() { return list.size(); } @Override ...

  5. Android项目-高考作文-AsyncTask的不足

    1, AsyncTask的不足. 从android4.0开始, 后台只允许一个AsyncTask执行, 如果当前的AsyncTask没有执行完毕, 那么当前的请求一直处于等待状态. 直到上一个执行完毕 ...

  6. ReadHub项目Kotlin版开发指南(三、MVP架构)

    ReadHub项目Kotlin版转换指南(一.环境搭建) ReadHub项目Kotlin版转换指南(二.数据库和网络请求) ReadHub项目Kotlin版转换指南(三.MVP架构) Android ...

  7. Android Gradle Plugin指南(三)——依赖关系、android库和多项目配置

    原文地址:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Dependencies-Android-Librari ...

  8. GitHub上最著名的Android播放器开源项目大全

    GitHub上最著名的Android播放器开源项目大全                                                                          ...

  9. 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新

    本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...

随机推荐

  1. day06 Request Response

    rw 读写模板的设置 day05 Request Response 1. HttpServletResponse 简介 1.1 Response 的 OutputStream 输出中文的问题 1.2 ...

  2. CSS 常用的命名规则

    (1)页面结构 容器: container 页头:header 内容:content/container 页面主体:main 页尾:footer 导航:nav 侧栏:sidebar 栏目:column ...

  3. 利用Bioperl的SeqIO模块解析fastq文件

    测序数据中经常会接触到fastq格式的文件,比如说拿到fastq格式的原始数据后希望查看测序碱基的质量并去除低质量碱基.一般而言大家都是用现有的工具,比如说fastqc这个Java写的小程序,确实很好 ...

  4. Node.js Domain 模块

    Node.js Domain(域) 简化异步代码的异常处理,可以捕捉处理try catch无法捕捉的异常.引入 Domain 模块 语法格式如下: var domain = require(" ...

  5. GDAL C#版本 "安全透明方法"问题解决方案

    之前写过一篇关于再C#中调用GDAL库出现OSGeo.GDAL.GdalPINVOKE"的类型初始值设定项引发异常的解决方案,博客地址见下: http://blog.csdn.net/lim ...

  6. MySQL系列教程(二)

    mySQL执行计划 语法  explain <sql语句> 例如: explain select * from t3 where id=3952602; explain输出解释 +---- ...

  7. Android开发学习之路--Java和Js互相调用

      随着前端的火热,以前开发的快速,越来越多的native app在其中融合了h5,就拿淘宝就是很多的h5组成的,一旦出现什么节日,他都可以不用通过更新app来实现界面的改变,而且android和io ...

  8. ejabberd开发和部署

    ejabberd开发和部署 (金庆的专栏 2016.10) 搭建了自己的ejabberd集群,然后少量更改源码,实现定制的XMPP服务器. 从github fork ejabberd 库,定为 mas ...

  9. MyBatis批量新增和更新

    之前有开发任务一个接口里面有大量的数据新增和更新操作,导致十分缓慢.使用了批量操作之后速度有明显提升,几乎百倍千倍的速度提升. 博主之前统计过,通过普通接口一次数据库插入大概需要200ms,对于大量新 ...

  10. N个鸡蛋放到M个篮子中

    N个鸡蛋放到M个篮子中,篮子不能为空,要满足:对任意不大于N的数量,能用若干个篮子中鸡蛋的和表示. 写出函数,对输入整数N和M,输出所有可能的鸡蛋的放法. 比如对于9个鸡蛋5个篮子 解至少有三组: 1 ...