流式布局 ChipsLayoutManager

ChipsLayoutManager
ChipsLayoutManager github地址
在这里插入图片描述

<android.support.v7.widget.RecyclerView
       android:layout_width="match_parent"
       android:layout_height="match_parent"
       android:layoutDirection="ltr"
       />

android:layoutDirection=“ltr” 从左到右

public static void initFlowLayout(Context context, RecyclerView recyclerView, ChipsAdapter adapter){
        adapter.setOnRemoveListener(new MyRemoveListener(adapter));
        ChipsLayoutManager chipsLayoutManager = ChipsLayoutManager.newBuilder(context)
                //set vertical gravity for all items in a row. Default = Gravity.CENTER_VERTICAL
                .setChildGravity(Gravity.TOP)
                //whether RecyclerView can scroll. TRUE by default
                .setScrollingEnabled(true)
                //set maximum views count in a particular row
//                .setMaxViewsInRow(2)
                //set gravity resolver where you can determine gravity for item in position.
                //This method have priority over previous one
                .setGravityResolver(new IChildGravityResolver() {
                    @Override
                    public int getItemGravity(int position) {
                        return Gravity.CENTER;
                    }
                })
                //a layoutOrientation of layout manager, could be VERTICAL OR HORIZONTAL. HORIZONTAL by default
                .setOrientation(ChipsLayoutManager.HORIZONTAL)
                // row strategy for views in completed row, could be STRATEGY_DEFAULT, STRATEGY_FILL_VIEW,
                //STRATEGY_FILL_SPACE or STRATEGY_CENTER
                .setRowStrategy(ChipsLayoutManager.STRATEGY_DEFAULT)
                // whether strategy is applied to last row. FALSE by default
                .withLastRow(true)
                .build();
        recyclerView.setLayoutManager(chipsLayoutManager);
        recyclerView.setAdapter(adapter);
    }

    private static class MyRemoveListener implements OnRemoveListener {

        private ChipsAdapter adapter;

        public MyRemoveListener(ChipsAdapter adapter){
            this.adapter = adapter;
        }

        @Override
        public void onItemRemoved(int position) {
            adapter.getChipsEntitys().remove(position);
            adapter.notifyItemRemoved(position);
        }
    }

ChipsLayoutManager.STRATEGY_DEFAULT,默认左对齐或右对齐
ChipsLayoutManager.STRATEGY_FILL_SPACE, item左右两边分布,中间空格

setGravityResolver(new IChildGravityResolver() ) 可能报错,看实际选择
java.lang.IllegalArgumentException: bottom point of input rect can’t be bigger than maxTop

.setRowBreaker(new IRowBreaker() {
 @Override
      public boolean isItemBreakRow(@IntRange(from = 0) int position) {
          return position == 6 || position == 11 || position == 2;
      }
  })

//对应position的item,如果右边可再放置一个item,可放置的item必须放下一行,对应position不受影响,不用单独放上一行。

import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageButton;
import android.widget.TextView;

import com.lianyucn.szfjzxy.R;
import com.lianyucn.szfjzxy.bean.ChipsEntity;
import com.lianyucn.szfjzxy.tool.listener.OnRemoveListener;

import java.util.List;


public class ChipsAdapter extends  RecyclerView.Adapter<ChipsAdapter.ViewHolder> {

    private List<ChipsEntity> chipsEntities;
    private OnRemoveListener onRemoveListener;

    public ChipsAdapter(List<ChipsEntity> chipsEntities) {
        this.chipsEntities = chipsEntities;
    }

    public ChipsAdapter(List<ChipsEntity> chipsEntities, OnRemoveListener onRemoveListener) {
        this.chipsEntities = chipsEntities;
        this.onRemoveListener = onRemoveListener;
    }

    public ChipsAdapter(List<ChipsEntity> chipsEntities, OnRemoveListener onRemoveListener, boolean isShowingPosition) {
        this.chipsEntities = chipsEntities;
        this.onRemoveListener = onRemoveListener;
    }

    public void setOnRemoveListener(OnRemoveListener onRemoveListener){
        this.onRemoveListener = onRemoveListener;
    }

    @Override
    public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_chip, parent, false);
        return new ViewHolder(itemView);
    }

    @Override
    public void onBindViewHolder(ViewHolder holder, int position) {
        holder.bindItem(chipsEntities.get(position));
    }

    @Override
    public int getItemCount() {
        return chipsEntities.size();
    }

    public List<ChipsEntity> getChipsEntitys(){
        return chipsEntities;
    }

    class ViewHolder extends RecyclerView.ViewHolder {

        private TextView tvName;
        private ImageButton ibClose;

        ViewHolder(View itemView) {
            super(itemView);
            tvName = (TextView) itemView.findViewById(R.id.tvName);
            ibClose = (ImageButton) itemView.findViewById(R.id.ibClose);
        }

        void bindItem(ChipsEntity entity) {
            itemView.setTag(entity.getName());

            tvName.setText(entity.getName());

            ibClose.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if (onRemoveListener != null && getAdapterPosition() != -1) {
                        onRemoveListener.onItemRemoved(getAdapterPosition());
                    }
                }
            });
        }
    }

}


自定义布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingTop="3dip"
    android:paddingBottom="3dip"
    android:paddingLeft="7dip"
    android:paddingRight="7dip"
    >
    <TextView
        android:background="@drawable/radius19_f6_rlayout"
        android:id="@+id/tvName"
        android:tag="text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        tools:text="Trevor Hansen"
        android:paddingLeft="@dimen/dp15"
        android:paddingRight="@dimen/dp15"
        android:paddingTop="@dimen/dp7"
        android:paddingBottom="@dimen/dp7"
        android:textColor="@color/colorA7"
        android:textSize="@dimen/text_size_15"
        android:layout_centerVertical="true"
        />
    <ImageButton
        android:layout_marginTop="-3dip"
        android:layout_alignRight="@id/tvName"
        android:id="@+id/ibClose"
        android:layout_width="@dimen/dp15"
        android:layout_height="@dimen/dp15"
        android:src="@drawable/shanchutupian"
        android:background="@null"
        />

</RelativeLayout>

布局:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值