仿京东、饿了么 左右联动菜单列表自定义View

仿京东、饿了么 左右联动菜单列表

这是一个左右联动的自定义View

这里本人将两个列表进行了联动封装,使用的时候调用方法即可,方便快捷,扩展性也强。

完整Demo传送门

效果图:

在这里插入图片描述

正题开始:

我们看一下API

  • 设置左边列表的ITem布局
 //设置左边Item的自定义布局 layout
    public void setLeftLayoutId(int layoutId){
        this.leftLayoutId = layoutId;
        initView(context);
    }
  • 设置右边列表的Item布局
//设置右边Item的自定义布局 layout
    public void setRightLayoutId(int layoutId){
        this.rightLayoutId = layoutId;
        initView(context);
    }
  • 左边ITem是否自动等比铺满
//设置左边的Item高度是否自动等比铺满
    public void setLeftItemAutoScreen(boolean isAuto)
  • 设置选中、未选中样式
//设置左边的列表的Item的选中、未选中的背景以及字体颜色
    public void setLeftSelectStatus(int leftSelectBg,int leftUnSelectBg,int leftSelectTxColor,int leftUnSelectTxColor)
  • 设置左、右的列表宽高(默认铺满)
setRvLeftWidthHeight(getResources().getDimensionPixelOffset(R.dimen.dp_100),ViewGroup.LayoutParams.MATCH_PARENT);
        setRvRightWidthHeight(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.MATCH_PARENT);

设置数据源,这里接受泛型数据

//设置左右两边的数据源
    //数据实体可自行继承 DLLinkeAgeItem 扩展字段(必须继承DLLinkeAgeItem)
    //leftData-左边列表数据源   rightData-右边数据源
    public void setData(List<T> leftData,List<M> rightData)

监听

  • 初始化监听
  • onBindItem、onBindRightItem相当于RV的onBindViewHolder绑定数据源
 dlView.setOnRvInitListener(new DolinLinkAgeRVView.OnRvInitListener() {
            //左边Item初始化
            @Override
            public void onBindItem(RecyclerView.ViewHolder holder, View itemView, int position) {
                TextView tv_title = itemView.findViewById(R.id.tv_title);
                tv_title.setText(aList.get(position).getName());
            }

            //右边Item初始化
            @Override
            public void onBindRightItem(RecyclerView.ViewHolder holder, View itemView, int position) {
                TextView tv_title = itemView.findViewById(R.id.tv_right_title);
                tv_title.setText(bList.get(position).getName());
            }
        });
  • 左边列表点击事件
        dlView.setOnLeftItemClickListener(new DolinLinkAgeRVView.OnLeftItemClickListener() {
            @Override
            public void onItemClick(int position) {
                Toast.makeText(SecondActivity.this,"点击了左边第"+position+"个",Toast.LENGTH_SHORT).show();
            }
        });
  • 右边列表点击事件
dlView.setOnRightItemClickListener(new DolinLinkAgeRVView.OnRightItemClickListener() {
            @Override
            public void onItemClick(int position) {
                Toast.makeText(SecondActivity.this,"点击了第"+position+"个",Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onLongClick(int position) {
                Toast.makeText(SecondActivity.this,"长按了第"+position+"个",Toast.LENGTH_SHORT).show();
            }
        });

- 当一切准备就绪,请调用prepareFinish();

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值