早就听说RecyclerView有多少多少XX


但是直到今天才开始尝试使用它,惭愧惭愧



android5.0之RecyclerView_github



包括:


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;


/**
 * @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使用的一些心得


RecyclerView自定义LayoutManager,打造不规则布局



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

  • android5.0之RecyclerView_ide_02

  • 大小: 165.7 KB
  • eclipse.rar (2.2 MB)
  • 下载次数: 8
  • 查看图片附件