早就听说RecyclerView有多少多少XX
但是直到今天才开始尝试使用它,惭愧惭愧
包括:
1,分割线装饰(DividerGridItemDecoration & DividerItemDecoration)
2,自定义动画(ScaleInOutItemAnimator等)
3,Item点击和长按事件
4,动态添加删除Item
5,自定义ActionBar风格
注意:瀑布流效果需要Item的高度都不一致,这样才能看出来。
动态添加删除Item时分割线会有点小问题,如果很介意,建议不要使用装饰(Decoration)来实现分割线,而是使用Item的padding或margin
很简单直接上代码
import java.util.ArrayList;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.GridLayoutManager;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import com.widget.effect.DividerGridItemDecoration;
/**
* http://blog.csdn.net/lmj623565791/article/details/45059587
* @author Administrator
*
*/
public class MainActivity extends Activity {
private Context context;
private MyAdapter adapter;
private RecyclerView recyclerView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
context=this;
initViews();
}
public void initViews(){
recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
recyclerView.addItemDecoration(new DividerGridItemDecoration(this));
recyclerView.setItemAnimator(new DefaultItemAnimator());//动画effect
LinearLayoutManager manager = new LinearLayoutManager(this);
manager.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerView.setLayoutManager(manager);
final ArrayList<KeyValue> list=new ArrayList<KeyValue>();
for (int i = 0; i < 100; i++){
list.add(new KeyValue("key"+i, "value"+i));
}
adapter = new MyAdapter(list);
adapter.setOnItemClickLitener(new MyAdapter.OnItemClickLitener() {
@Override
public void onItemClick(View view, int position) {
// TODO Auto-generated method stub
adapter.removeData(position);
}
});
// 设置Adapter
recyclerView.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu){
getMenuInflater().inflate(R.menu.main, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item){
switch (item.getItemId()){
case R.id.action_add:
adapter.addData(1);
break;
case R.id.action_delete:
adapter.removeData(1);
break;
case R.id.action_0:
LinearLayoutManager manager0 = new LinearLayoutManager(this);
manager0.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerView.setLayoutManager(manager0);
break;
case R.id.action_1:
LinearLayoutManager manager1 = new LinearLayoutManager(this);
manager1.setOrientation(LinearLayoutManager.VERTICAL);
recyclerView.setLayoutManager(manager1);
break;
case R.id.action_2:
GridLayoutManager manager2 = new GridLayoutManager(this,4);
recyclerView.setLayoutManager(manager2);
break;
case R.id.action_3:
GridLayoutManager manager3 = new GridLayoutManager(this,3);
manager3.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
@Override
public int getSpanSize(int position) {
return (3 - position % 3);
}
});
recyclerView.setLayoutManager(manager3);
break;
case R.id.action_4:
StaggeredGridLayoutManager manager4 = new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL);
recyclerView.setLayoutManager(manager4);
break;
case R.id.action_5:
StaggeredGridLayoutManager manager5 = new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.HORIZONTAL);
recyclerView.setLayoutManager(manager5);
break;
}
return true;
}
}
具体看附件
关于Recycleview使用的一些心得
http://blog.csdn.net/dywailly/article/details/47169355
RecyclerView自定义LayoutManager,打造不规则布局
http://blog.csdn.net/qibin0506/article/details/52676670
FlowLayoutManager
https://github.com/xiaofeng-han/AndroidLibs/tree/master/flowlayoutmanager
https://github.com/danylovolokh/LondonEyeLayoutManager
SnappyLinearLayoutManager
https://android-arsenal.com/details/1/3909
https://github.com/xiaofeng-han/AndroidLibs/tree/master/flowlayoutmanager
https://github.com/Cleveroad/FanLayoutManager
https://github.com/BelooS/ChipsLayoutManager
https://github.com/L4Digital/FastScroll
http://www.jcodecraeer.com/a/opensource/2017/0117/7048.html
http://www.jcodecraeer.com/a/opensource/2017/0117/7048.html
- 大小: 165.7 KB
分享到:
相关推荐
Android 5.0 RecyclerView的使用方法
类似于ListView功能的新的特效,可以实现android 5.0 中列表下滑的特效效果
android5.0之RecyclerView实战demo
Android5.0 RecyclerView reference resource 分割线 DividerItemDecoration 增加和删除动画 Summary LayoutManager去实现ListView, GridView, 横向ListView/GridView, 瀑布流 ItemDecoration 实现的原理和如何定制 ...
android 5.0 发布后, RecyclerView CardView Palette新组建的实例Demo。
通过爬虫技术实时抓取36Kr数据 使用技术:Android5.0 (RecyclerView,CardView,SwipeRefeshLayout...),数据爬虫,原生 HTML5 混合开发,Volley,Okhttp,UIL,Fresco,EventBus,消息推送,多渠道打包,增量升级...
android5.0最新容兼开发包 包括carview、recyclerview已经各种style
基本的几个控件的用法,这里温馨提示,对于5.0以下的版本,兼容性可能存在部分问题。
android5.0 RecycelerView和CardView结合的一个小例子
一个Activity掌握Android5.0新控件,讲解RecyclerView,Patelle,CardView,Toolbar,RippleDrawable基本使用方法。
android-5.0 安卓 5.0 演示android 5.0 的演示。 您可以研究如何使用新视图,例如 cardView recyclerView 和 floatbutton。 谢谢。
自Android 5.0之后,谷歌公司推出了RecylerView控件,RecylerView,我想看到一个新名词后大部分人会首先发出一个疑问,recylerview是什么?为什么会有recylerview也就是说recylerview的优点是什么?recylerview怎么用...
android recyclerview appbarlayout toolbar snackbar coordinatorLayout 等组件的简单测试。
RecyclerView是Android 5.0以来新加入的一个组件,基本上全面优于ListView,这里我们将来关注Android开发中RecyclerView组件使用的一些进阶技讲解:
谷歌在推出Android5.0的同时推出了一些新控件,Android5.0中最常用的新控件有下面5种。 1. CardView(卡片视图) CardView顾名思义是卡片视图,它继承FrameLayout。它是一个带圆角的背景和阴影FrameLayout。...
RecyclerView是Android 5.0 materials design中的组件之一,相应的还有CardView、Palette等。看名字我们就能看出一点端倪,没错,它主要的特点就是复用。我们知道,Listview中的Adapter中可以实现ViewHolder的复用...
两个Demo中简单应用了Android 5.0中新增加的特性,使用AndroidStudio编写。 关于Android 5.0中MaterialDesgin的介绍可以参考我的blog: [] AndroidL_MaterialDesgin_Demo: Demo to show some features of Material ...
RecyclerView是Android 5.0以来新加入的组件,被广泛认为是ListView的替代品,这里我们就结合理论与实践来深入解析Android中的RecyclerView组件: