仿阿里头部滑动及列表多布局实现
关于多布局实现那些事
-
在Adapter的onBindViewHolder(RecycleView中)/getView(listView中),通过数据的Flag展示不同的界面 例如:
public void onBindViewHolder(ViewHolder holder, final int position){ final BannerListBean banner = mList.get(position); //判断广告样式 switch (banner.getType()){ case "1": //TODO show item1 break; case "2": //TODO show item2 break; } }
-
ScrollView + LinearLayout 获取到一个item的数据,往LinearLayout中add一个特定的view 例如:
LinearLayout.addView(LayoutInflater.from(mContext).inflate(R.layout.item_index_ad_content1,null));
-
调用第三方框架如:BRVAH 很好很强大。
-
在RecycleView中有getItemViewType方法在onCreateViewHolder之前先设置当前item的类型在onCreateViewHolder创建的时候获取到Type值对不同的Type创建不同的ViewHolder 本文中的多布局就是基于改思路做的一些相关的封装
#相关使用
- 为每种类型的item创建一个对应的视图模板,继承ItemViewFactory这个工厂类 如 Content_1_ItemView
- 多布局示例
MultiTypeRecyclerAdapter adapter = new MultiTypeRecyclerAdapter(); List<ItemViewFactory> datas = new ArrayList<>(); datas.add(new Content_1_ItemView(activity, dataModel)); ... datas.add(new Content_6_ItemView(activity, dataModel)); adapter.setData(itemList); recycleView.setAdapter(adapter);
- 单布局示例
为了兼容原来的单布局的模式,封装了一个入口用于单布局显示
List<DataModel> datas; //列表中需要显示的数据模型 adapter.singleData(activity, Content_1_ItemView.class, DataModel.class, datas);