Android开发 Fragment与RecyclerView的混合使用

Fragment与RecyclerView的混合使用
这篇是参考了这位仁兄的文章。所写的笔记;
要想使用Fragment与RecylerView的结合,首先知道Fragment是嵌入在Activity中的,而RecylerView是一个组件,它则嵌入在Fragment只有了解他们的关系才能更好的配置他们的代码:

  1. MainActivity.java(主要Activity的逻辑类)
  2. BlankFragment.java(嵌入在Activity的Fragment的逻辑类)
  3. RecyclerView_Myadapter.java(嵌入在Fragment的ReclyerView逻辑类)
  4. Bean.java(存储数据类)
  5. activity_main.xml(主要Activity的布局文件)
  6. fragemt_blank.xml(Fragment的布局文件)
  7. item_layout.xml(ReclyerView单个空格的布局文件)

在这里插入图片描述

MainActivity.java

package com.example.fragment;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
}

BlankFragment.java

package com.example.fragment;

import android.os.Bundle;

import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import android.os.RecoverySystem;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;

import java.util.ArrayList;


public class BlankFragment extends Fragment {
    private View root;
    private TextView textview;
    private Button button;
    private ArrayList<Bean> beanArrayList = new ArrayList<>();
    private RecyclerView recyclerview;
    private RecyclerView_Myadpter recyclerview_adapter;

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

    }
    //创建Fragemnt视图的方法
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        if (root == null){
            //获得布局文件
            root = inflater.inflate((R.layout.fragment_blank),container, false);
        }
        //初始化RecylerView组件的方法
        initRecyclerview();
        //初始化数据
        initData();
//        //这个部分是用于设置Fragemnt布局文件中控件的点击反应的*********************************************
//        textview = root.findViewById(R.id.tv);
//        button = root.findViewById(R.id.but);
//        button.setOnClickListener(new View.OnClickListener() {
//            @Override
//            public void onClick(View view) {
//                textview.setText("修改");
//            }
//        });
//        //******************************************
        //返回设置完成的View文件用于显示
        return  root;
    }

    private void initData() {
        for (int i=0;i<30;i++){
            Bean bean = new Bean();
            bean.setId("ID:"+i);
            beanArrayList.add(bean);
        }
    }

    private void initRecyclerview() {
        //获得Recyclerview
        recyclerview = (RecyclerView)root.findViewById(R.id.recyclerview);
        //创建adapter类的对象
        recyclerview_adapter = new RecyclerView_Myadpter(getActivity(), beanArrayList);
        //将对象作为参数通过setAdapter方法设置给recylerview;
        recyclerview.setAdapter(recyclerview_adapter);
        //这步骤必须有,这是选择RecylerView的显示方式
        recyclerview.setLayoutManager(new LinearLayoutManager(getActivity(),LinearLayoutManager.VERTICAL,false));
    }
}

RecyclerView_Myadapter.java

package com.example.fragment;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

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

import java.util.ArrayList;

public class RecyclerView_Myadpter extends RecyclerView.Adapter<RecyclerView_Myadpter.myViewHodler> {
    private Context context;
    private ArrayList<Bean> beanArrayList;

    public RecyclerView_Myadpter(Context context, ArrayList<Bean> beanArrayList) {
        this.context = context;
        this.beanArrayList = beanArrayList;
    }

    @NonNull
    @Override
    public myViewHodler onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        //item_layout是Reclyerview每个格子的布局
        //获取recylerview格子的样式
        View itemview = View.inflate(context,R.layout.item_layout,null);
        //返回根据myViewHodler()处理完的新View
        return new myViewHodler(itemview);
    }

    @Override
    public void onBindViewHolder(@NonNull myViewHodler holder, int position) {
        Bean data = beanArrayList.get(position);
        holder.text.setText(data.getId());
    }

    @Override
    public int getItemCount() {
        return beanArrayList.size();
    }
    //用于根据布局文件生成View
    public class myViewHodler extends RecyclerView.ViewHolder{
        private TextView text;
        public myViewHodler(View itemview) {
            super(itemview);
            text = (TextView)itemview.findViewById(R.id.item_tv);
        }
    }
}

Bean.java

package com.example.fragment;

public class Bean {
    private String id;

    public Bean(String id) {
        this.id = id;
    }

    public Bean() {

    }


    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }
}

activity_main.xml

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

    <fragment
        android:name="com.example.fragment.BlankFragment"
        android:layout_width="200dp"
        android:layout_height="400dp"
        android:layout_gravity="center_horizontal"
        android:id="@+id/fg"/>





</LinearLayout>

fragemt_blank.xml

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

    <!-- TODO: Update blank fragment layout -->
    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center" />
</LinearLayout>

item_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:id="@+id/item_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        tools:ignore="MissingConstraints" />

</androidx.constraintlayout.widget.ConstraintLayout>
好的,我可以为您介绍一下在 Android Studio 中如何在 Fragment使用 RecyclerView。 首先,在 Fragment 的布局文件中添加 RecyclerView 控件: ```xml <androidx.recyclerview.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 然后,在 Fragment 的代码中找到 RecyclerView 控件: ```java RecyclerView recyclerView = view.findViewById(R.id.recycler_view); ``` 接下来,需要为 RecyclerView 设置布局管理器和适配器: ```java // 设置布局管理器 recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); // 设置适配器 MyAdapter adapter = new MyAdapter(dataList); recyclerView.setAdapter(adapter); ``` 其中,`MyAdapter` 是您自己定义的 RecyclerView 适配器类,`dataList` 是您要显示的数据列表。 最后,您需要在 `MyAdapter` 中实现 RecyclerViewViewHolder 和 onBindViewHolder 方法,以及返回数据列表的大小的方法。 ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mDataList; public MyAdapter(List<String> dataList) { mDataList = dataList; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()) .inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { String data = mDataList.get(position); holder.mTextView.setText(data); } @Override public int getItemCount() { return mDataList.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { public TextView mTextView; public ViewHolder(@NonNull View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } } } ``` 上面的代码中,`item_layout` 是您自己定义的 RecyclerView Item 的布局文件,`text_view` 是其中一个 TextView 控件的 ID。 这样,您就可以在 Fragment使用 RecyclerView 了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值