【RecyclerView】 九、为 RecyclerView 设置不同的布局样式

简介: 【RecyclerView】 九、为 RecyclerView 设置不同的布局样式

文章目录

一、为 RecyclerView 设置不同的布局样式

二、完整代码

三、RecyclerView 相关资料





一、为 RecyclerView 设置不同的布局样式


为 RecyclerView 设置不同的布局样式流程 :



① 自定义 RecyclerView.Adapter 泛型类型 : 适配器的泛型类型需要设置为 RecyclerView.ViewHolder , 这是所有 ViewHolder 的基类 ;


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



② 实现 getItemViewType( ) 方法 : 这里为不同位置的组件设置不同的布局类型 ;


       @Override

   

public int getItemViewType(int position) {
            // 返回 View 布局类型, 奇数序号组件类型为 VIEW_TYPE_2, 偶数序号组件类型为 VIEW_TYPE_1
            return position % 2;
        }


③ 根据布局类型加载不同的布局文件 : 在 onCreateViewHolder( ) 方法中 , 根据当前的 int viewType 参数 , 加载不同的布局文件 ;


     

@Override
        public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
            // 根据不同的组件类型加载不同类型的布局文件
            switch (viewType){
                case VIEW_TYPE_1:
                    return new ViewHolder(
                            LayoutInflater.from(MainActivity.this)
                                    .inflate(R.layout.item_recyclerview, parent, false)
                    );
                case VIEW_TYPE_2:
                    return new ViewHolder2(
                            LayoutInflater.from(MainActivity.this)
                                    .inflate(R.layout.item_recyclerview2, parent, false)
                    );
            }
            return null;
        }


④ 根据不同的布局类型绑定数据 : 在 onBindViewHolder( ) 方法中为布局组件绑定数据时 , 可以调用 getItemViewType 方法 , 获取当前的布局类型 , 然后根据该布局类型 , 将 ViewHolder 参数强转为不同的子类对象 , 然后为其绑定数据 ;


     

@Override
        public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
            // 根据 position 获取布局类型 , 然后绑定数据
            switch (getItemViewType(position)){
                case VIEW_TYPE_1:
                    ((ViewHolder)holder).text.setText("" + position);
                    break;
                case VIEW_TYPE_2:
                    ((ViewHolder2)holder).text.setText("" + position);
                    ((ViewHolder2)holder).image.setImageResource(R.mipmap.ic_launcher);
                    break;
            }
        }




二、完整代码


完整代码 :


package kim.hsl.recyclerview;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import androidx.recyclerview.widget.StaggeredGridLayoutManager;
public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //1 . 从布局中获取 RecyclerView
        RecyclerView recycler_view = findViewById(R.id.recycler_view);
        //2 . 创建并设置布局管理器
        //创建布局管理器
        LinearLayoutManager layoutManager = new LinearLayoutManager(this, RecyclerView.VERTICAL, false);
        //设置布局管理器
        recycler_view.setLayoutManager(layoutManager);
        // 添加分隔符
        recycler_view.addItemDecoration(new ItemDecoration());
        //3 . 创建并设置列表适配器
        Adapter adapter = new Adapter();
        recycler_view.setAdapter(adapter);
    }
    /**
     * RecyclerView 适配器
     * RecyclerView.Adapter 中的 ViewHolder 泛型设置为 RecyclerView.ViewHolder
     * 同理 onBindViewHolder 中的泛型也要是该类型的
     */
    public class Adapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
        public static final int VIEW_TYPE_1 = 0;
        public static final int VIEW_TYPE_2 = 1;
        @Override
        public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
            // 根据不同的组件类型加载不同类型的布局文件
            switch (viewType){
                case VIEW_TYPE_1:
                    return new ViewHolder(
                            LayoutInflater.from(MainActivity.this)
                                    .inflate(R.layout.item_recyclerview, parent, false)
                    );
                case VIEW_TYPE_2:
                    return new ViewHolder2(
                            LayoutInflater.from(MainActivity.this)
                                    .inflate(R.layout.item_recyclerview2, parent, false)
                    );
            }
            return null;
        }
        @Override
        public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
            // 根据 position 获取布局类型 , 然后绑定数据
            switch (getItemViewType(position)){
                case VIEW_TYPE_1:
                    ((ViewHolder)holder).text.setText("" + position);
                    break;
                case VIEW_TYPE_2:
                    ((ViewHolder2)holder).text.setText("" + position);
                    ((ViewHolder2)holder).image.setImageResource(R.mipmap.ic_launcher);
                    break;
            }
        }
        @Override
        public int getItemCount() {
            return 10;
        }
        @Override
        public int getItemViewType(int position) {
            // 返回 View 布局类型, 奇数序号组件类型为 VIEW_TYPE_2, 偶数序号组件类型为 VIEW_TYPE_1
            return position % 2;
        }
        public class ViewHolder extends RecyclerView.ViewHolder {
            TextView text;
            public ViewHolder(@NonNull View itemView) {
                super(itemView);
                text = itemView.findViewById(R.id.text);
            }
        }
        public class ViewHolder2 extends RecyclerView.ViewHolder {
            TextView text;
            ImageView image;
            public ViewHolder2(@NonNull View itemView) {
                super(itemView);
                text = itemView.findViewById(R.id.text);
                image = itemView.findViewById(R.id.image);
            }
        }
    }
}



运行结果 :




image.png




三、RecyclerView 相关资料


官方文档 :


使用 RecyclerView 创建动态列表 : https://developer.android.google.cn/guide/topics/ui/layout/recyclerview


高级 RecyclerView 自定义 : https://developer.android.google.cn/guide/topics/ui/layout/recyclerview-custom



代码示例 :


GitHub 源码地址 : https://github.com/han1202012/001_RecyclerView


博客源码快照 : https://download.csdn.net/download/han1202012/14956298


( 使用 Android Studio 打开 )


目录
相关文章
|
7月前
|
XML 数据格式
RecyclerView使用示例(瀑布流)
RecyclerView使用示例(瀑布流)
61 0
|
5月前
|
Android开发
NestedScrollView,ScrollView中嵌套listView 或者RecyclerView会自动跳到顶部,中部,底部的问题。
NestedScrollView,ScrollView中嵌套listView 或者RecyclerView会自动跳到顶部,中部,底部的问题。
160 0
|
XML Java Android开发
Android 中ScrollView垂直滚动视图之隐藏滚动条的三种方法
Android 中ScrollView垂直滚动视图之隐藏滚动条的三种方法
166 0
|
XML Android开发 数据格式
一个Adapter+recycleview实现多种布局,区分布局中
最近因为需要所以学习了一下recycleview,使用Adapter修饰器修饰,使用一个Adapter+recycleview实现多种布局,而不是之前的三个Adapter在同一个recycleview中实现三个布局。点击区分布局中的gridview的图片和姓名。
56 0
【布局 widget】ConstrainedBox 与 UnconstrainedBox
【布局 widget】ConstrainedBox 与 UnconstrainedBox
133 0
【布局 widget】ConstrainedBox 与 UnconstrainedBox
|
前端开发 容器
【布局 widget】OverflowBox 与 SizedOverflowBox
【布局 widget】OverflowBox 与 SizedOverflowBox
137 0
【布局 widget】OverflowBox 与 SizedOverflowBox
|
Android开发
同一页面实现recycleView三种布局【recycleView + adapter】
同一页面实现recycleView三种布局【recycleView + adapter】
153 0
同一页面实现recycleView三种布局【recycleView + adapter】
|
Android开发
【RecyclerView】 三、RecyclerView 布局 ( 线性布局管理器 LinearLayoutManager )
【RecyclerView】 三、RecyclerView 布局 ( 线性布局管理器 LinearLayoutManager )
585 0
【RecyclerView】 三、RecyclerView 布局 ( 线性布局管理器 LinearLayoutManager )
|
Java Android开发
【RecyclerView】 七、RecyclerView.ItemDecoration 条目装饰 ( getItemOffsets 边距设置 )
【RecyclerView】 七、RecyclerView.ItemDecoration 条目装饰 ( getItemOffsets 边距设置 )
146 0
【RecyclerView】 七、RecyclerView.ItemDecoration 条目装饰 ( getItemOffsets 边距设置 )
RecyclerView的item宽度不能全屏显示
RecyclerView的item宽度不能全屏显示
226 0