Android recyclerView 多布局

1.首先引入我们的RecyclerView的包

2.在布局文件中使用他

<android.support.v7.widget.RecyclerView  
    android:id="@+id/myRecycler"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"/>  

设置他的多布局样式
item_a.xml布局

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical" android:layout_width="match_parent"  
    android:layout_height="wrap_content"  
    android:background="#65edfc"  
    android:layout_margin="5dp">  
    <TextView  
        android:id="@+id/item_a_text1"  
        android:layout_width="match_parent"  
        android:layout_height="wrap_content"  
        android:gravity="center"  
        android:textSize="30sp"/>  
    <TextView  
        android:id="@+id/item_a_text2"  
        android:layout_width="match_parent"  
        android:layout_height="wrap_content"  
        android:gravity="center"  
        android:background="#f5e593"  
        android:textSize="30sp"/>  
</LinearLayout>  

item_b.xml布局

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="horizontal" android:layout_width="match_parent"  
    android:layout_height="wrap_content"  
    android:background="#b0ed65"  
    android:layout_margin="5dp">  
    <ImageView  
        android:id="@+id/item_b_image"  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:src="@mipmap/image"/>  
    <LinearLayout  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        android:orientation="vertical">  
        <TextView  
            android:id="@+id/item_b_text1"  
            android:layout_width="match_parent"  
            android:layout_height="0dp"  
            android:layout_weight="1"  
            android:gravity="center"  
            android:textSize="30sp"/>  
        <TextView  
            android:id="@+id/item_b_text2"  
            android:layout_width="match_parent"  
            android:layout_height="0dp"  
            android:layout_weight="1"  
            android:gravity="center"  
            android:textSize="30sp"/>  
    </LinearLayout>  

</LinearLayout>  

a.新建一个接口,我们的Bean类会实现他的一个返回条目类别的接口

public interface TypeInterf {  
    public int getType();  
}  

b.新建两个子类来实现我们的接口,这里我就以一个为例子了

public class Item_a implements TypeInterf {  
    String text1;  
    String text2;  

    public String getText1() {  
        return text1;  
    }  

    public void setText1(String text1) {  
        this.text1 = text1;  
    }  

    public String getText2() {  
        return text2;  
    }  

    public void setText2(String text2) {  
        this.text2 = text2;  
    }  

    @Override  
    public int getType() {  
        return R.layout.item_a;  
    }  
}  

可以看到我们的返回类型是他的布局文件,这样做会在他返回的时候逻辑比较清楚

c.将这两个子类的多个对象放入数据源中就好

(4)接收Context和数据源,其中数据源的泛型要是你的接口

private Context context;  
   private List<TypeInterf> list;  

   public MyRecyclerAdapter(Context context, List<TypeInterf> list) {  
       this.context = context;  
       this.list = list;  
   }  

(5)重写getItemViewType方法

@Override  
public int getItemViewType(int position) {  
    return list.get(position).getType();  
}  

这个方法的值会在onCreateViewHoldere中的到,然后我们根据不同的type来创建不同的ViewHolder

(6)根据不同的type实现不同的ViewHolder

@Override  
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {  
    RecyclerView.ViewHolder holder = null;  
    View view = LayoutInflater.from(context).inflate(viewType, parent, false);  
    if(viewType==R.layout.item_a){  
        holder = new ViewHolder_a(view);  
    }else{  
        holder = new ViewHolder_b(view);  
    }  
    return holder;  
}  

(7)绑定数据

@Override  
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {  
    if(holder instanceof ViewHolder_a){  
        ((ViewHolder_a) holder).textView1.setText(((Item_a)list.get(position)).getText1());  
        ((ViewHolder_a) holder).textView2.setText(((Item_a)list.get(position)).getText2());  
    }else{  
        ((ViewHolder_b) holder).textView1.setText(((Item_b)list.get(position)).getText1());  
        ((ViewHolder_b) holder).textView2.setText(((Item_b)list.get(position)).getText2());  
    }  
}  

(8)设置我们的数据源

private void initData() {  
    list = new ArrayList<>();  
    Item_a item_a = null;  
    Item_b item_b = null;  
    for (int i = 0; i < 100; i++) {  
        if (i%3==0) {  
            item_a = new Item_a();  
            item_a.setText1("ItemA的第"+i+"个text1");  
            item_a.setText2("ItemA的第"+i+"个text2");  
            list.add(item_a);  
        }else{  
            item_b = new Item_b();  
            item_b.setText1("ItemB的第"+i+"个text1");  
            item_b.setText2("ItemB的第"+i+"个text2");  
            list.add(item_b);  
        }  
    }  
}  
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: RecyclerView 是一个用于在 Android 应用中显示大量数据列表的强大工具。它是 ListView 和 GridView 的改进版本,具有更高的灵活性和性能优化。 RecyclerView 采用了 ViewHolder 模式来管理列表项视图的缓存,以便在滚动时提高性能。此外,RecyclerView 还支持多种布局管理器,可以轻松地实现不同的列表布局,例如线性布局、网格布局和瀑布流布局等。 要在 Android 应用中使用 RecyclerView,需要完成以下步骤: 1. 添加 RecyclerView 依赖库到应用的 build.gradle 文件中: ``` implementation 'androidx.recyclerview:recyclerview:1.2.1' ``` 2. 在布局文件中添加 RecyclerView 控件: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 创建 RecyclerView 的 Adapter 类,并实现其中的必要方法: ``` class MyAdapter(private val dataList: List<String>) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() { override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder { val view = LayoutInflater.from(parent.context) .inflate(R.layout.item_layout, parent, false) return MyViewHolder(view) } override fun onBindViewHolder(holder: MyViewHolder, position: Int) { holder.bind(dataList[position]) } override fun getItemCount() = dataList.size class MyViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) { fun bind(item: String) { itemView.findViewById<TextView>(R.id.textView).text = item } } } ``` 4. 在 Activity 或 Fragment 中设置 RecyclerView 的 LayoutManager 和 Adapter: ``` val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) val layoutManager = LinearLayoutManager(this) val adapter = MyAdapter(listOf("item 1", "item 2", "item 3")) recyclerView.layoutManager = layoutManager recyclerView.adapter = adapter ``` 以上就是使用 RecyclerView 实现多布局的基本步骤。可以根据需要进行进一步的自定义和优化。 ### 回答2: Android RecyclerView 是一款强大的控件,它让我们可以轻松创建与管理数据集合,以及快速显示它们。其中,在RecyclerView 中使用多布局是非常常见的,特别是在需要展示多种类型的数据时。在这种情况下,使用多布局可以让我们根据每种数据类型的不同,选择正确的布局以呈现更好的用户体验。 要在 RecyclerView 中使用多布局,我们需要进行以下步骤: 1.创建一组不同的布局,以满足不同的数据类型。我们可以在布局文件中定义不同的 RecyclerView ViewHolder,每个 ViewHolder 都对应着不同类型的数据。 2.在 Adapter 中实现 getItemViewType() 方法,该方法用于确定每个 ViewHolder 对应的数据类型。我们可以根据数据内容,选择不同的布局类型,比如可以使用 item 类型表示某个具体的数据,使用 header 类型表示一些相关的信息。 3.在 Adapter 中实现 onCreateViewHolder() 方法,该方法根据 View type 创建不同的 ViewHolder。我们可以通过 LayoutInflater API 将不同类型的布局加载到新创建的 ViewHolder 中。 4.在 onBindViewHolder() 中,我们可以根据 ViewHolder position 来确定该 ViewHolder 显示的数据,为 ViewHolder 中的视图设置内容。 因此,以上步骤可以帮助我们在 RecyclerView 中实现多布局。需要注意的是,在使用多布局时,我们需要特别小心,确保不要因为过多的复杂逻辑而影响 RecyclerView 的性能。 ### 回答3: Android RecyclerView是一个高级版本的ListView,它提供了更多的灵活性和可定制性。RecyclerView支持很多种布局格式,其中一种便是多布局。所谓“多布局”,是指在RecyclerView中,不同位置的item使用不同的布局文件。需要在Adapter中重写getItemViewType()方法,返回不同的viewType,这样就可以根据不同的viewType来选择不同的布局文件。 多布局的应用场景常见且广泛,比如一个聊天窗口,左侧为接受的消息,右侧为发送的消息,这就是两种不同的布局;再比如一个社交软件中的朋友圈,其中有纯文字、文字加图片、文字加视频等多种不同的布局方式。 在RecyclerView的Adapter中,可以继承RecyclerView.Adapter<T>,并重写其中的几种方法。为了支持多种布局,主要需要重写getItemViewType和onCreateViewHolder方法。 getItemViewType方法用于获取当前item的类型。需要根据position的位置,判断需要使用哪种类型的布局文件。在方法中,可以使用一个switch-case去判断,并根据不同的position来返回对应的类型。它需要返回一个int值,表示当前item的类型。 onCreateViewHolder方法用于创建ViewHolder对象。ViewHolder对象用来绑定视图控件,使其能够正确显示数据。在这个方法中,可以根据item类型去创建不同的ViewHolder并返回。同时,需要注意,该方法中的layoutInflate.inflate()方法需要根据viewType参数来加载不同的布局文件。 另外,需要在Adapter中重写getItemCount()方法,返回item的数量,以确保RecyclerView中正确显示所有的item。 综上所述,RecyclerView之所以受到开发者的喜爱,是因为其强大高效的布局管理和灵活的定制能力。通过实现多布局,可以实现各种不同的布局方式,提高用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值