• Android RecyclerView(瀑布流)水平/垂直方向分割线


    

    Android RecyclerView(瀑布流)水平/垂直方向分割线

    Android RecyclerView不像过去的ListView那样随意的设置水平方向的分割线,如果要实现RecyclerView的水平/垂直分割线,则需要继承自RecyclerView.ItemDecoration重写getItemOffsets方法,从而增加水平/垂直分割线。
    写一个例子。
    MainActivity.java:

    package zhangphil.app;
    
    import android.content.Context;
    import android.graphics.Color;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.support.v7.widget.RecyclerView;
    import android.support.v7.widget.StaggeredGridLayoutManager;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.TextView;
    
    public class MainActivity extends AppCompatActivity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            RecyclerView mRecyclerView = (RecyclerView) findViewById(R.id.recyclerView);
    
            // 两列
            int spanCount = 2;
    
            // StaggeredGridLayoutManager管理RecyclerView的布局。
            StaggeredGridLayoutManager mLayoutManager = new StaggeredGridLayoutManager(spanCount, StaggeredGridLayoutManager.VERTICAL);
            mRecyclerView.setLayoutManager(mLayoutManager);
    
            //为RecyclerView增加分割线,水平和垂直方向都有。增加分割线值比如为32。
            RecyclerViewItemDecoration decoration = new RecyclerViewItemDecoration(32);
            mRecyclerView.addItemDecoration(decoration);
    
            RecyclerViewAdapter mAdapter = new RecyclerViewAdapter(this);
            mRecyclerView.setAdapter(mAdapter);
        }
    
        private class ItemViewHolder extends RecyclerView.ViewHolder {
            private TextView text;
    
            public ItemViewHolder(View itemView) {
                super(itemView);
                text = (TextView) itemView.findViewById(android.R.id.text1);
                text.setTextColor(Color.WHITE);
            }
        }
    
        public class RecyclerViewAdapter extends RecyclerView.Adapter<ItemViewHolder> {
            private Context context;
    
            public RecyclerViewAdapter(Context context) {
                super();
                this.context = context;
            }
    
            @Override
            public ItemViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
                View view = View.inflate(context, android.R.layout.simple_list_item_1, null);
                view.setBackgroundColor(Color.RED);
                ItemViewHolder holder = new ItemViewHolder(view);
                return holder;
            }
    
            @Override
            public void onBindViewHolder(ItemViewHolder viewHolder, int pos) {
                viewHolder.text.setText(String.valueOf(pos));
            }
    
            @Override
            public int getItemCount() {
                return 15;
            }
        }
    }


    布局文件,很简单,就放一个RecyclerView,注意背景颜色的设置:

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@android:color/holo_orange_light">
    
        <android.support.v7.widget.RecyclerView
            android:id="@+id/recyclerView"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        </android.support.v7.widget.RecyclerView>
    
    </RelativeLayout>
    


    最关键的RecyclerViewItemDecoration.java:

    package zhangphil.app;
    
    /**
     * Created by Phil on 2016/10/8.
     */
    
    import android.graphics.Rect;
    import android.support.v7.widget.RecyclerView;
    import android.view.View;
    
    /**
     * 为RecyclerView增加间距
     * 预设2列,如果是3列,则左右值不同
     */
    public class RecyclerViewItemDecoration extends RecyclerView.ItemDecoration {
        private int space = 0;
        private int pos;
    
        public RecyclerViewItemDecoration(int space) {
            this.space = space;
        }
    
        @Override
        public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
    
            outRect.top = space;
    
            //该View在整个RecyclerView中位置。
            pos = parent.getChildAdapterPosition(view);
    
            //取模
    
            //两列的左边一列
            if (pos % 2 == 0) {
                outRect.left = space;
                outRect.right = space / 2;
            }
    
            //两列的右边一列
            if (pos % 2 == 1) {
                outRect.left = space / 2;
                outRect.right = space;
            }
        }
    }


    代码运行结果:

  • 相关阅读:
    delphi 遇到Line too long(more than 1023 characters问题,将原有代码分离出过程来调用,调用使用 过程名字(self) 调用
    sql 从房间号中或从含有几个"-"间隔的字符串中,截取楼层数,或截取第几个"-"后的前几个字符或数字
    delphi mac地址 网卡地址获取,如果有无线网卡连接情况,mac地址随机获取某个本地连接网卡地址,要都写进去判断
    delphi 输入年月判断天数,判断指定年份与月份判断当月有多少天
    在SQL SERVER中查询数据库中第几条至第几条之间的数据SQL语句写法
    手动修改PHP页面返回状态码
    PHPExcel 导出包含图片excel
    windows apache启动报错
    mysql正则查询 模糊查询
    symfony安装总结
  • 原文地址:https://www.cnblogs.com/hehehaha/p/6147252.html
Copyright © 2020-2023  润新知