用委托者模式实现的多类型Adapter

场景

面对多类型的列表,应该怎么处理?

解决方案(设计思想的方法--委托者模式)

什么是委托者模式,简单的来说就是业务所需要实现的逻辑交给一个目标实现类来完成。 不管任何条目,都统一实现IDelegateAdapter接口

然后让一个实现类去完成

下面是代码实现
public interface IDelegateAdapter {


    // 查找委托时调用的方法,返回自己能处理的类型即可。
    boolean isForViewType(BaseRvBean baseRvBean);

    // 用于委托Adapter的onCreateViewHolder方法
    SuperViewHolder onCreateViewHolder(ViewGroup parent, int viewType);

    // 用于委托Adapter的onBindViewHolder方法
    void onBindViewHolder(RecyclerView.ViewHolder holder, int position, BaseRvBean baseRvBean);

    //清除数据
    void clearData();

}
复制代码

由于篇幅原因,代码没有全部贴入

public class BaseRvAdapter extends RecyclerView.Adapter<SuperViewHolder> {
    List<IDelegateAdapter> delegateAdapters = new ArrayList<>();

    public void addDelegate(IDelegateAdapter delegateAdapter) {
        delegateAdapters.add(delegateAdapter);
    }

    @Override
    public SuperViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        IDelegateAdapter iDelegateAdapter = delegateAdapters.get(viewType);
        return iDelegateAdapter.onCreateViewHolder(parent, viewType);
    }

    @Override
    public void onBindViewHolder(SuperViewHolder holder, int position) {
        int itemViewType = holder.getItemViewType();
        IDelegateAdapter iDelegateAdapter = delegateAdapters.get(itemViewType);
        iDelegateAdapter.onBindViewHolder(holder, position, mDataList.get(position));
    }


    @Override
    public int getItemViewType(int position) {
        BaseRvBean baseRvBean = mDataList.get(position);
        for (IDelegateAdapter delegateAdapter : delegateAdapters) {
            if (delegateAdapter.isForViewType(baseRvBean)) {
                return delegateAdapters.indexOf(delegateAdapter);
            }

        }

        throw new RuntimeException("没有可以处理的委托Adapter");
    }

    public void clear() {
        mDataList.clear();
        for (IDelegateAdapter delegateAdapter : delegateAdapters) {
            delegateAdapter.clearData();
        }
        notifyDataSetChanged();
    }
}
复制代码

使用方法

  1. 实现自己业务需要的item类型
class EditTextAdapter : IDelegateAdapter {
    override fun clearData() {
        mTextCache.clear()
    }

    override fun isForViewType(baseRvBean: BaseRvBean?): Boolean {

        return baseRvBean?.type == ViewType.ITEM_TYPE_GENERAL_EDITTEXT
    }

    @SuppressLint("InflateParams")
    override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): SuperViewHolder {
        val view = LayoutInflater.from(parent?.context).inflate(R.layout.view_custom_ed, null)
        return ViewHolder(view)
    }


    private val mTextCache = SparseArray<String>()
    override fun onBindViewHolder(holder: RecyclerView.ViewHolder?, position: Int, baseRvBean: BaseRvBean?) {
    }
复制代码
  1. 创建Adapter
mAdapter = BaseRvAdapter(mActivity).apply {
           addDelegate(EditTextAdapter())
       }
复制代码
  1. 赋值
mAdapter?.setDataList(mDataList )\\这些都是基本操作,大家都会的
复制代码

委托模式是不是很简单呀,把设计模式运用到开发中,真的是件很有意思的事情,大家都可以多尝试下

转载于:https://juejin.im/post/5cbd764bf265da03a54c1c40

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值