- 浏览: 5770352 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
接上一篇
由简到繁,循序渐进
实现了:
0,点击&长按事件;
1,header;
2,footer;
3,加载更多;
4,还想下拉刷新?“想的美,这本就不是RecyclerView该做的事情!”
这是一个如你熟悉ListView、GridView一样熟悉的RecyclerView类库,你可以用以前使用ListView / GridView的习惯来使用RecyclerView,这些可让你将项目原有的ListView / GridView / 瀑布流 迁移到RecyclerView时减少许多工作量.
你必须了解的RecyclerView的五大开源项目-解决上拉加载、下拉刷新和添加Header、Footer等问题
http://www.see-source.com/blog/300000035/1463.html
滑动到顶部/底部 可拉伸回弹的ListView与ScrollView
https://github.com/teisun/SunmiUI
由简到繁,循序渐进
实现了:
0,点击&长按事件;
1,header;
2,footer;
3,加载更多;
4,还想下拉刷新?“想的美,这本就不是RecyclerView该做的事情!”
import java.util.ArrayList; import java.util.List; import com.example.test.R; import com.widget.view.HeaderFooterAdapter.ViewHolder; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; /** * 为了用RecyclerView创建一个带header的grid: 1,定义一个具有两种view类型的adapter,一个为header一个为普通item。 2,inflate一个header,把它传递给adapter。 3,重写GridLayoutManager中的setSpanSizeLookup,在header所处的位置返回和span count(列数)相等的 span size。 * @author Administrator * */ public class HeaderFooterAdapter<T> extends RecyclerView.Adapter<ViewHolder> { private static final int ITEM_VIEW_TYPE_HEADER = 0; private static final int ITEM_VIEW_TYPE_ITEM = 1; private static final int ITEM_VIEW_TYPE_FOOTER = 2; private final View header; private final View footer; private int headerCount=0; private int footerCount=0; private final List<T> beans; public HeaderFooterAdapter(View header, View footer,List<T> beans) { headerCount=header == null?0:1; footerCount=footer == null?0:1; this.header = header; this.footer = footer; this.beans = beans; } public boolean isHeader(int position) { if(headerCount==0){ return false; } return position == 0; } public boolean isFooter(int position) { if(footerCount==0){ return false; } return position == beans.size()+headerCount;// add 1 for footer // return position == getItemCount()-headerCount;// or Subtract 1 for footer } @Override public ViewHolder<T> onCreateViewHolder(ViewGroup parent, int viewType) { if (viewType == ITEM_VIEW_TYPE_HEADER) { return new ViewHolder<T>(header); } if (viewType == ITEM_VIEW_TYPE_FOOTER) { return new ViewHolder<T>(footer); } View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item, parent, false); return new ViewHolder<T>(view); } @Override public void onBindViewHolder(final ViewHolder holder, final int position) { if (isHeader(position)) { return; } if (isFooter(position)) { return; } final T bean = beans.get(position - headerCount); // Subtract 1 for header holder.textView.setText(bean.toString()); } @Override public int getItemViewType(int position) { if(isHeader(position)){ return ITEM_VIEW_TYPE_HEADER; } if(isFooter(position)){ return ITEM_VIEW_TYPE_FOOTER; } return ITEM_VIEW_TYPE_ITEM; } /** * 获得实际View的数量,包括header和footer */ @Override public int getItemCount() { return beans.size() + headerCount+footerCount; } class ViewHolder<T> extends RecyclerView.ViewHolder implements View.OnClickListener,View.OnLongClickListener{ public TextView textView; public ViewHolder(View itemView) { super(itemView); if (onItemClickLitener != null){ itemView.setOnClickListener(this); } if(onItemLongClickLitener!=null){ itemView.setOnLongClickListener(this); } textView = (TextView) itemView.findViewById(R.id.item_0); } @Override public void onClick(View v) { // TODO Auto-generated method stub onItemClickLitener.onItemClick(v, getLayoutPosition());//getPosition()被废弃了 } @Override public boolean onLongClick(View v) { // TODO Auto-generated method stub onItemLongClickLitener.onItemLongClick(v, getLayoutPosition()); return true; } } private static OnItemClickLitener onItemClickLitener; public void setOnItemClickLitener(OnItemClickLitener onItemClickLitener) { this.onItemClickLitener = onItemClickLitener; } public interface OnItemClickLitener { /** * 点击回调,注意position,指的是在Adapter中的位置,已经算上header * @param view * @param position */ void onItemClick(View view, int position); } private static OnItemLongClickLitener onItemLongClickLitener; public void setOnItemLongClickLitener(OnItemLongClickLitener onItemLongClickLitener) { this.onItemLongClickLitener = onItemLongClickLitener; } public interface OnItemLongClickLitener { /** * 长按回调,注意position,指的是在Adapter中的位置,已经算上header * @param view * @param position */ void onItemLongClick(View view, int position); } /** * 在position位置插入item * @param position:指的是item在beans中的位置,而不是在Adapter中的位置; * 所以在notifyItemInserted的时候需要算上header * @param item */ public void addItemAt(int position,T item) { beans.add(position, item); notifyItemInserted(position+headerCount); } /** * 在底部添加Items * @param items */ public void addItemsAtLast(ArrayList<T> items) { int size=beans.size(); beans.addAll(items); notifyItemRangeInserted(size+headerCount, items.size()); } /** * 移除position位置的Item * @param position :指的是item在beans中的位置,而不是在Adapter中的位置; * 所以在notifyItemInserted的时候需要算上header */ public void removeItemAt(int position) { beans.remove(position); notifyItemRemoved(position+headerCount); } /** * 获得中间Item的数量,不包括header和footer * @return */ public int getItemSize(){ return beans.size(); } }
ArrayList<String> list=new ArrayList<String>(); for (int i = 0; i < 30; ++i) { list.add(String.valueOf(i)); } View header = LayoutInflater.from(this).inflate(R.layout.header_view, recyclerView, false); View footer = LayoutInflater.from(this).inflate(R.layout.footer_view, recyclerView, false); final HeaderFooterAdapter<String> adapter = new HeaderFooterAdapter<String>(header,footer, list); adapter.setOnItemClickLitener(new HeaderFooterAdapter.OnItemClickLitener() { @Override public void onItemClick(View view, int position) { // TODO Auto-generated method stub if(adapter.isHeader(position)){ Toast.makeText(context, "header clicked", Toast.LENGTH_SHORT).show(); }else if(adapter.isFooter(position)){ Toast.makeText(context, "footer clicked", Toast.LENGTH_SHORT).show(); }else{ Toast.makeText(context, "header item "+position, Toast.LENGTH_SHORT).show(); } } }); final GridLayoutManager manager = new GridLayoutManager(this, 2); manager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() { @Override public int getSpanSize(int position) { if(adapter.isHeader(position)||adapter.isFooter(position)){ return manager.getSpanCount(); } return 1; } }); //如果可以确定每个item的高度是固定的,设置这个选项可以提高性能 recyclerView.setHasFixedSize(true); recyclerView.setLayoutManager(manager); recyclerView.setAdapter(adapter); recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrolled(RecyclerView rv, int dx, int dy) { boolean isBottom = manager.findLastCompletelyVisibleItemPosition()>= adapter.getItemCount()-1; if (isBottom) { ArrayList<String> list=new ArrayList<String>(); int size=adapter.getItemSize(); for (int i = size; i < 30+size; ++i) { list.add(String.valueOf(i)); } adapter.addItemsAtLast(list); } } });
这是一个如你熟悉ListView、GridView一样熟悉的RecyclerView类库,你可以用以前使用ListView / GridView的习惯来使用RecyclerView,这些可让你将项目原有的ListView / GridView / 瀑布流 迁移到RecyclerView时减少许多工作量.
你必须了解的RecyclerView的五大开源项目-解决上拉加载、下拉刷新和添加Header、Footer等问题
http://www.see-source.com/blog/300000035/1463.html
滑动到顶部/底部 可拉伸回弹的ListView与ScrollView
https://github.com/teisun/SunmiUI
发表评论
-
工具类之FragmentUtils
2017-04-01 11:37 1635fragment应该是广大Android开发者都用到过的一个v ... -
左中右结构的行布局
2016-12-19 21:35 1136最近项目要开发一个新版本,发现项目中许多布局大致都相同改动不大 ... -
RecyclerView:带header和footer的grid
2015-09-09 13:47 2992知道原理后,为RecyclerView实现同时带header和 ... -
RecyclerView:带header的grid
2015-09-09 13:01 2385RecyclerView是一个高度可定制性的View 本文将使 ... -
iconify使用文本替换icon测试
2015-08-28 17:12 1650源项目地址 https://github.com/JoanZa ... -
快速上传头像到服务端工具类FaceUtil
2015-07-12 14:22 3010快速迭代用 import java.io.DataOut ... -
HorizontalScrollView+RadioGroup+ViewPager+FragmentPagerAdapter基本结构
2015-07-12 13:56 3241快速迭代用 import java.util.Arr ... -
LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构
2015-07-12 13:07 4094一切为了快速迭代 import java.util. ... -
RadioButton+ViewPager+FragmentPagerAdapter快速搭建页面结构
2015-07-12 11:08 2511一切为了快速开发 开发类似界面 import and ... -
为ViewPager设置CirclePageIndicator(小圆点)
2015-07-03 16:54 15239一切为了快速迭代! import android.con ... -
简单实现可以多选的ProductListDialog<T>
2015-06-25 22:33 1207只是一个范例,是为了代码快速迭代而写的 使用了listView ... -
基于上一篇写的SimplePairListPopupWindow<F,S>
2015-06-19 11:15 1486这次使用Pair<F,S>实现一个简单的Simpl ... -
基于上一篇实现的SimpleListPopupWindow<T>
2015-06-19 11:11 1474这次是个简单的PopupWindow,快速迭代用。 imp ... -
实现一个快速简单的SimpleListDialog<T>
2015-06-19 10:59 1695我写这样的文章都是为了快速迭代,所以都写的比较简单,谅解 此 ... -
为ViewPager设置SimpleViewPagerIndicator
2015-02-14 13:45 4671说到ViewPagerIndicator,网上有很多专门的开源 ... -
一个典型的从下部弹上来的Dialog
2014-12-05 14:47 5997典型的看图 import android.app ...
相关推荐
RecyclerView封装:加载更多,添加Header和Footer
普通列表功能、为列表添加分割线,设置分割线高度(宽度)、颜色等。... 再不需要加载更多数据情况下,支持添加Footer。 未扩展下拉刷新功能,如需要,请使用Android官方提供的SwipeRefreshLayout 。
今天终于有点时间,来写了一下: 为RecyclerView实现下拉刷新和上拉加载更多。今天会在前面的两篇文章的基础上: RecyclerView系列之(1):为RecyclerView添加Header和Footer RecyclerView系列之(2):为...
瀑布流列表使用的是自定义Header和Footer的下拉刷新和上拉上拉加载,没有设置了下拉使放大的图片,使用默认的刷新动画。 用法: Gradle: dependencies { compile 'com.android.support:recyclerview-v7:23.1.0' ...
源码AnimRefreshRecyclerViewDemo,下拉刷新和上拉加载更多的RecyclerView,具有下拉和刷新动画。 效果: 嗯...看起来有点卡,截图软件的问题: 使用说明: 上图中演示了三种不同的布局和下拉效果,三种布局和三种...
支持刷新和加载更多效果,滑动到底部自动加载下页数据 支持自定义刷新和加载更多效果 支持添加多个header和footer,一行代码搞定 支持动态加载各种Item类型的列表、网格、瀑布流 支持极简通用的万能适配器Adapter,...
滑动冲突解决方式,自定义下拉刷新,上拉加载更多,适配RecyclerView/ListView/ScrollView,支持自定义刷新Header/Footer,支持自动加载更多或手动上拉加载更多。
支持刷新和加载更多效果,滑动到底部自动加载下页数据 支持自定义刷新和加载更多效果 支持添加多个header和footer,一行代码搞定 支持动态加载各种Item类型的列表、网格、瀑布流 支持极简通用的万能适配器Adapter,...
基于RecyclerView的封装,实现下拉刷新,上拉加载更多,添加header,添加footer基本组成//添加Header//添加Header和Footer1、BaseAdapter 基本组成2、HeaderAdapter 添加Header3、HeaderBottomAdapter 添加Header和...
将开发中常用的RecyclerView的各种需求封装进库。...并且adapter支持数据管理,Header与Footer添加,加载更多。没有更多。加载错误 使用了部分Malinskiy/SuperRecyclerView的代码,将更多功能交给了adapter实现。
2.基于XRecyclerView进行修改,像朋友圈一样流畅的加载更多体验。 3.外面可以嵌套官方SwipeRefreshLayout,自动关闭自身的下拉加载。 4.底部加载更多可以展示加载中、加载失败、没有更多数据等多个状态,点击加载...
下拉刷新支持大部分view:ListView、ScrollView、WebView等...加载更多目前支持ListView、RecyclerView、GridView、SwipeRefreshLayout 支持自定义header以及footer 增加SwipeRefreshLayout刷新方式,同样支持加载更多
SmartRefreshLayout的目标是打造一个强大,稳定,成熟的下拉刷新框架,并集成各种的炫酷、多样、实用、美观的Header和Footer。 特点功能: 支持多点触摸 支持嵌套多层的视图结构 Layout (LinearLayout,FrameLayout......
所以header和footer其实只是一个和你的普通数据类型不一样的Item罢了,可以加载更多的Footer也不例外,而LightAdapter的工作只是管理这些多类型Item,并不关心具体的逻辑。所以,当你不使用LoadMoreFooter时,...
前言 RecyclerView是一个大家常用的列表...支持Header Footer 和 下拉刷新 加载更多 支持Item滑动动画 支持空白、错误等状态页的展示 系列文章 用法与详解(详见下文) MultiItem进阶 实现Head Foot和加载更多 Multi
下拉刷新支持大部分view:ListView、ScrollView、WebView等...加载更多目前支持ListView、RecyclerView、GridView、SwipeRefreshLayout 支持自定义header以及footer 增加SwipeRefreshLayout刷新方式,同样支持加载更多
当页面到底部或者当前页面显示不全时,自动加载其余数据,并显示LoadMoreView加载更多时出错自动停止加载更多,并显示LoadMoreFailedView没有更多数据加载时,显示NoMoreView支持Header View和Footer View除下拉刷新以外...
安卓基础模块整合,含视频欢迎界面、一行代码实现QQ聊天列表侧滑栏效果、基于RecyclerView的封装,仿qq侧拉删除效果,实现下拉刷新,上拉加载更多,添加header,添加footer、强大而灵活的RecyclerView Adapter(列表...
XXXXX(上拉加载更多,错误界面的展示,Header或者Footer)怎么实现? 回顾初心,我写当初这篇博客的目的是 展示一种不同的实现思路,但这种实现方式并非是非常优秀的,从某种意义上讲,我认为这种方式也存在一些弊端...
##可添加Header和footer的RecyclerView###支持的功能支持添加一个或者多个Header支持添加加载更多的footer支持分页加载(加载更多)