上一篇我们讲到了,  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. AQS简简单单过一遍

    前言 回顾前面: 多线程三分钟就可以入个门了! Thread源码剖析 多线程基础必要知识点!看了学习多线程事半功倍 Java锁机制了解一下 只有光头才能变强! 本来我是打算在这章节中写Lock的子类实 ...

  2. merge into的用法及10g新特性总结

    merge into 的作用: 将源数据(来源于实际的表,视图,子查询)更新或插入到指定的表中(必须实际存在),依赖于on条件,好处是避免了多个insert 和update操作. merge是一个目标 ...

  3. Windows下的DOM操作

    前言:这学期学Linux之后,发现用命令行的方式来操作电脑还是很好玩的~写这篇随笔来总结下Windows环境下通过DOS来执行命令的操作,希望能帮到您~自己忘记的时候能回来复习emmm 启动DOS环境 ...

  4. CentOS 7安装Python3.5,并与Python2.7兼容并存

    CentOS7默认安装了python2.7.5,当需要使用python3的时候,可以手动下载Python源码后编译安装.1.安装python3.5可能使用的依赖1 yum install openss ...

  5. Docker 控制组

    控制组(cgroups)是 Linux 内核的一个特性,主要用来对共享资源进行隔离.限制.审计等.只有能控制分配到容器的资源,才能避免当多个容器同时运行时的对系统资源的竞争. 控制组技术最早是由 Go ...

  6. 安卓高级9 用原生intent分享

    大家都用过安卓app时发现有个分享按钮如下: 所以今天特此分享用用原生完成: package qianfeng.com.simplesharedemo; import android.content. ...

  7. [BBS]搭建开源论坛之Jforum搭配开源CKEDITOR

    本文作者:sushengmiyan 本文地址:http://blog.csdn.net/sushengmiyan/article/details/47946065 使用默认的编辑器的时候,格式都无法保 ...

  8. Github Atom开源文本代码编辑器- 由 Github 打造的下一代编程开发利器

    个人理解:Github 热度超凡的一个项目Atom,electron是整个atom的核心,对于electron可以理解成 electron =io.js + Chromium    通过 Electr ...

  9. Activtiy完全解析(一、Activity的创建过程)

    转载请标明出处: http://blog.csdn.net/xmxkf/article/details/52452218 本文出自:[openXu的博客]   在Android开发过程中,我们几乎每天 ...

  10. 剑指Offer——“你最大的缺点是什么”回答技巧及范例

    剑指Offer--"你最大的缺点是什么"回答技巧及范例   问题分析:认识自己的缺点是一个巨大的优点, 当HR问到你缺点的时候, 你的机会来了, 请快展示你的自知之明吧!你想把优点 ...