上一篇我们讲到了,  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. Asp.Net Core 2.0 项目实战(7)MD5加密、AES&DES对称加解密

    本文目录 1. 摘要 2. MD5加密封装 3. AES的加密.解密 4. DES加密/解密 5. 总结 1.  摘要 C#中常用的一些加密和解密方案,如:md5加密.RSA加密与解密和DES加密等, ...

  2. random 模块

    import stringprint (random.random()) # 0-1之间选浮点数print (random.randint(0,99,))#0-99之间选任意整数print (rand ...

  3. Spring-cloud (七)自定义HystrixCommand

    前提 1.在继续学习Hystrix之前,向关注本人博客的各位致歉 由于之前的项目起名以及服务之间的名称不是很规范,所以我修改了这些名称方便后来的代码管理,这些代码可以在本人github中找到,这里贴出 ...

  4. 纯CSS菜单样式,及其Shadow DOM,Json接口 实现

    先声明,要看懂这篇博客要求你具备少量基础CSS知识, 当然如果你只是要用的话就随便了,不用了解任何知识 完整项目github链接:https://github.com/git-Code-Shelf/M ...

  5. 《读书报告 -- Elasticsearch入门 》--简单使用(2)

    <读书报告 – Elasticsearch入门 > ' 第四章 分布式文件存储 这章的主要内容是理解数据如何在分布式系统中存储. 4.1 路由文档到分片 创建一个新文档时,它是如何确定应该 ...

  6. 使用redis构建文章投票系统

    首先,我得说明这篇博客基本上就是<<redis in action>>第一章内容的读书笔记. 需求 首先,说明一下,我们的需求 用户可以发表文章,发表时,自己就默认的给自己的文 ...

  7. 2017年校园招聘ios面试题

    一.搜狐快站 1.谈谈你做过的项目: 2.项目中最有成就感的部分: 3.倒计时如何实现?(NSTimer,还有其他的实现方式吗): 4.UIButton的继承关系? 5.iOS中可以进行输入的控件?( ...

  8. Android简易实战教程--第三十话《撕衣美女》

    此篇邪恶一些,给单身屌丝发点"福利",通过图片的绘制,给美女脱掉衣服. 原理:图片覆盖图片,通过画笔对顶端的图片做一些特效处理,即手指触摸的地方,设置为透明.即可显示最底部的美女图 ...

  9. Java学习之栈和堆的区别

    在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配. 当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配 ...

  10. memcached实战系列(七)理解Memcached的数据过期方式、新建过程、查找过程

    1.1.1. 新建Item分配内存过程 1:快速定位slab classid,先计算Item长度 key键长+flag+suffix(16字节)+value值长+结构大小(32字节),如90byte ...