日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網(wǎng)站首頁 編程語言 正文

Android?RecyclerView使用入門介紹_Android

作者:知奕奕 ? 更新時間: 2022-11-22 編程語言

添加 recycler 依賴

前往 build.gradle 下,添加以下依賴:

implementation 'androidx.recyclerview:recyclerview:1.2.1'

設置單個列表項布局

眾所周知,一個完整的列表是由多個列表項組成的,而列表項可以使用布局文件進行定義;

我們簡單的使用線性布局+一個 tv 組件定義列表項;

下方為布局文件 items.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:paddingTop="10dp"
    android:paddingBottom="10dp"
    android:paddingRight="20dp"
    android:paddingLeft="20dp">
    <TextView
        android:id="@+id/item_text"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginEnd="8dp"
        android:padding="15dp"
        android:text="tools"
        android:textColor="#353434"
        android:textSize="20sp"/>
</LinearLayout>

主布局中添加 recyclerview

添加方式和 listview 基本一致,很簡單:

<?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="match_parent">
    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</LinearLayout>

RecyclerAdapter

我們同樣需要編寫一個適配器來配置其對象關系;

新建適配器文件 RecyclerAdapter.kt

基本原理以及完善過程:

  1. 首先讓主類繼承 RecyclerView.Adapter ,泛型使用本類中的我們自建的 viewholder 方法
  2. 我們自創(chuàng)的 viewholder 方法需要繼承 RecyclerView.ViewHolder
  3. 我們在 MyViewHolder 中直接獲取列表項中的 TextView 組件
  4. 與此同時,我們還需要實現(xiàn)三個方法

onCreateViewHolder:選擇使用哪一個 layout 作為 viewholder,并放回該 layout 組成的 viewholder

onBindViewHolder:針對 viewholder 內部組件的一些賦值與處理操作

getItemCount:列表項需要渲染幾個?

class RecyclerAdapter(val context: Context) : RecyclerView.Adapter<RecyclerAdapter.MyViewHolder>() {
    inner class MyViewHolder(view: View) : RecyclerView.ViewHolder(view) {
        val textView: TextView = view.findViewById(R.id.item_text)
    }
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
        val itemView = LayoutInflater.from(context).inflate(R.layout.items, parent, false)
        return MyViewHolder(itemView)
    }
    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
        holder.textView.text = "this is $position"
    }
    override fun getItemCount(): Int {
        return 40
    }
}

主 activity 注冊

初始化 recyclerview 的方式和 listview 差不多,只不過這里多設置了一個 layoutManager

依葫蘆畫瓢即可!

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        initRecycler()
    }
    fun initRecycler() {
        val adapter = RecyclerAdapter(this)
        val recyclerView = findViewById<RecyclerView>(R.id.recyclerView)
        recyclerView.adapter = adapter
        val layoutManager = LinearLayoutManager(this)
        layoutManager.orientation = RecyclerView.VERTICAL
        recyclerView.layoutManager = layoutManager
    }
}

成果圖

原文鏈接:https://blog.csdn.net/delete_you/article/details/127156670

欄目分類
最近更新