Android Recyclerview多布局

4 篇文章 1 订阅
3 篇文章 0 订阅

今天给大家看一个recyclerview多布局的写法,是tablayout是的写法在上一篇文章中,感兴趣的兄弟可以去看看学一学

 这里是动图的地址http://qcloudcos.xunjiepdf.com/xunjievideo/temp/202205111401/45fc6ee39cf44fd5a6adb7e34b489835/video1_1.gif

我们废话不多说,直接上我们最喜欢的代码

添加一下我们的依赖

implementation 'androidx.recyclerview:recyclerview:1.1.0'
implementation 'com.github.bumptech.glide:glide:4.8.0'//glide第三方图片加载所需要的包

然后写我们的recyclerview布局

 <androidx.recyclerview.widget.RecyclerView
                android:id="@+id/recyclerview"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />

然后在我们的Activity或者Fragment中拿到我们的控件,我这边是在fragment中写的

package com.example.map.ui.fragment;

import android.content.Context;
import android.graphics.Rect;
import android.os.Bundle;

import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.ActionBarDrawerToggle;
import androidx.appcompat.widget.Toolbar;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.DividerItemDecoration;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import androidx.recyclerview.widget.StaggeredGridLayoutManager;

import com.example.map.R;
import com.example.map.adapter.MyAdapter;
import com.example.map.api.ApiService;
import com.example.map.bean.WallPaperResponse;
import com.llw.network.NetworkApi;
import com.llw.network.observer.BaseObserver;
import com.llw.network.utils.KLog;
import com.yalantis.phoenix.PullToRefreshView;
import java.util.ArrayList;
import java.util.List;

public class Fragment1 extends Fragment {

    private View view;
    private RecyclerView mRecyclerView;
    private List<WallPaperResponse.ResBean.VerticalBean> list;
    private MyAdapter adapter;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        view = inflater.inflate(R.layout.frament_1, container, false);
        initView();
        return view;
    }

    private void initView() {
        mPullToRefresh = view.findViewById(R.id.pull_to_refresh);
        mRecyclerView = view.findViewById(R.id.recyclerview);
        //创建集合
        list = new ArrayList<>();
        //创建适配器
        adapter=new MyAdapter(list,getActivity());
        //创建布局管理器
        LinearLayoutManager LayoutManager=  new LinearLayoutManager(getActivity(),LinearLayoutManager.VERTICAL, false);
        mRecyclerView.setLayoutManager(LayoutManager);
        //添加适配器
        mRecyclerView.setAdapter(adapter);
        //访问网络
        requestNetwork();

    }

    private void requestNetwork() {
        /**
         * OkHttp+Retrofit+Rxjava 网络框架
         */
        NetworkApi.createService(ApiService.class)
                .getWallPaper()
                .compose(NetworkApi.applySchedulers(new BaseObserver<WallPaperResponse>() {
                    @Override
                    public void onSuccess(WallPaperResponse wallPaperResponse) {
                        List<WallPaperResponse.ResBean.VerticalBean> vertical = wallPaperResponse.getRes().getVertical();
                        if (vertical != null && vertical.size() > 0) {
                            //把请求的数据添加到我们的集合中然后刷新适配器
                            list.addAll(vertical);
                            adapter.notifyDataSetChanged();
                        } else {
                            Toast.makeText(getActivity(), "数据为空", Toast.LENGTH_SHORT).show();
                        }
                    }

                    @Override
                    public void onFailure(Throwable e) {
                        KLog.e("MainActivity", e.toString());
                        Toast.makeText(getActivity(), "访问失败", Toast.LENGTH_SHORT).show();
                    }
                }));
    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
    }

    @Override
    public void onAttach(Context context) {
        super.onAttach(context);
    }

    public static Fragment1 newInstance() {
        Fragment1 fragment1 = new Fragment1();
        return fragment1;
    }

}

接下来是我们的适配器

package com.example.map.adapter;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import com.bumptech.glide.Glide;
import com.example.map.R;
import com.example.map.bean.WallPaperResponse;

import java.util.List;

public class MyAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
    private List<WallPaperResponse.ResBean.VerticalBean> list;
    private Context context;
    //三个final分别代表三个不同的布局
    public static final int ITEMONE = 1;
    public static final int ITEMTWO = 2;
    public static final int ITEMTHREE = 3;


    public MyAdapter(List<WallPaperResponse.ResBean.VerticalBean> list, Context context) {
        this.list = list;
        this.context = context;
    }


    @NonNull
    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int i) {
        //这时候就要根据这个i来判断加哪一个布局了
        View inflate = null;
        RecyclerView.ViewHolder viewHolder = null;
        switch (i) {
            case ITEMONE:
                inflate = LayoutInflater.from(context).inflate(R.layout.rv_item, parent, false);
                viewHolder = new OneItemHolder(inflate);
                break;
            case ITEMTWO:
                inflate = LayoutInflater.from(context).inflate(R.layout.item_two, parent, false);
                viewHolder = new TwoItemHolder(inflate);
                break;
            case ITEMTHREE:
                inflate = LayoutInflater.from(context).inflate(R.layout.item_three, parent, false);
                viewHolder = new ThreeItemHolder(inflate);
                break;
        }
        return viewHolder;
    }

    /**
     * 绑定控件,这里可以写一些事件方法等
     *
     * @param holder
     * @param position
     */
    @Override
    public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
        //如果当前的 holder 属于 OneItemHolder 则执行
        if (holder instanceof OneItemHolder){
            Glide.with(context).load(list.get(position).getImg()).into(((OneItemHolder) holder).image);

        }else if(holder instanceof TwoItemHolder){
            Glide.with(context).load(list.get(position).getImg()).into(((TwoItemHolder) holder).image1);
            Glide.with(context).load(list.get(position).getImg()).into(((TwoItemHolder) holder).image2);
        }else if (holder instanceof ThreeItemHolder){
            Glide.with(context).load(list.get(position).getImg()).into(((ThreeItemHolder) holder).image1);
            Glide.with(context).load(list.get(position).getImg()).into(((ThreeItemHolder) holder).image2);
            Glide.with(context).load(list.get(position).getImg()).into(((ThreeItemHolder) holder).image3);
        }
    }


    @Override
    public int getItemCount() {
        return list.size();
    }
    /**
     * 返回条目类型(这里就做个简单的判断区分)
     *
     * @param position 代表第几个条目
     * @return
     */
    @Override
    public int getItemViewType(int position) {

        if (position % 3 == 0) {
            return ITEMTHREE;
        } else if (position % 2 == 0) {
            return ITEMTWO;
        } else {
            return ITEMONE;
        }
    }
    /**
     * 第一个布局的Holder,要继承自RecyclerView.ViewHolder,这里你可以绑定控件
     */
    private class OneItemHolder extends RecyclerView.ViewHolder {
        private ImageView image;

        public OneItemHolder(View itemView) {
            super(itemView);
            image = itemView.findViewById(R.id.iv_img);
        }
    }
    /**
     * 第二个布局的Holder,要继承自RecyclerView.ViewHolder,这里你可以绑定控件
     */
    private class TwoItemHolder extends RecyclerView.ViewHolder {
        private ImageView image1;
        private ImageView image2;
        public TwoItemHolder(View itemView) {
            super(itemView);
            image1 = itemView.findViewById(R.id.iv_img1);
            image2 = itemView.findViewById(R.id.iv_img2);
        }
    }
    /**
     * 第三个布局的Holder,要继承自RecyclerView.ViewHolder,这里你可以绑定控件
     */
    private class ThreeItemHolder extends RecyclerView.ViewHolder {
        private ImageView image1;
        private ImageView image2;
        private ImageView image3;
        public ThreeItemHolder(View itemView) {
            super(itemView);
            image1 = itemView.findViewById(R.id.iv_img1);
            image2 = itemView.findViewById(R.id.iv_img2);
            image3 = itemView.findViewById(R.id.iv_img3);

        }
    }
}

然后是适配器中的三种布局样式

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <ImageView
        android:id="@+id/iv_img"
        android:layout_width="150dp"
        android:layout_height="200dp"
        android:layout_margin="5dp"
        android:scaleType="centerCrop"
        android:src="@mipmap/bg_fragment_1" />
</LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <ImageView
        android:id="@+id/iv_img1"
        android:src="@mipmap/bg_fragment_1"
        android:layout_width="150dp"
        android:scaleType="centerCrop"
        android:layout_marginTop="5dp"
        android:layout_height="200dp" />
    <ImageView
        android:id="@+id/iv_img2"
        android:src="@mipmap/bg_fragment_1"
        android:layout_width="150dp"
        android:scaleType="centerCrop"
        android:layout_marginTop="5dp"
        android:layout_height="200dp" />
</LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <ImageView
        android:id="@+id/iv_img1"
        android:layout_width="137dp"
        android:layout_height="200dp"
        android:layout_marginTop="5dp"
        android:scaleType="centerCrop"
        android:src="@mipmap/bg_fragment_1" />

    <ImageView
        android:id="@+id/iv_img2"
        android:layout_width="137dp"
        android:layout_height="200dp"
        android:layout_marginTop="5dp"
        android:scaleType="centerCrop"
        android:src="@mipmap/bg_fragment_1" />

    <ImageView
        android:id="@+id/iv_img3"
        android:layout_width="137dp"
        android:layout_height="200dp"
        android:layout_marginTop="5dp"
        android:scaleType="centerCrop"
        android:src="@mipmap/bg_fragment_1" />
</LinearLayout>

然后这个就是我们的多布局的样式了项目中的网络请求是我自己封装的一个请求,到时候可以给大家发出来

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答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之所以受到开发者的喜爱,是因为其强大高效的布局管理和灵活的定制能力。通过实现多布局,可以实现各种不同的布局方式,提高用户体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值