RecyclerView高级控件-附实例【android专题】
生活随笔
收集整理的這篇文章主要介紹了
RecyclerView高级控件-附实例【android专题】
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
RecyclerView高級(jí)控件
RecyclerView是Android 及其重要的一個(gè)高級(jí)UI控件,使用頻率及其的高,APP的90%以上的頁面都會(huì)使用的到。由于其出色的性能和插拔式的架構(gòu)設(shè)計(jì),被全世界廣大開發(fā)者一致稱贊。
LinerLayoutManager列表布局
縱向列表
recyclerView.layoutManager =LinearLayoutManager(context, VERTICAL, false) recyclerView.adapter = MyAdapter()橫向列表
recyclerView.layoutManager =LinearLayoutManager(context, HORIZONTAL, false) recyclerView.adapter = MyAdapter()數(shù)據(jù)源適配器
inner class MyAdapter : RecyclerView.Adapter<ViewHolder>() {// 【必須復(fù)寫】創(chuàng)建ItemView的ViewHolder,用于后續(xù)的數(shù)據(jù)綁定override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {val view =LayoutInflater.from(context).inflate(R.layout.item_view_staggered, parent, false) return ViewHolder(view)}// 【必須復(fù)寫】告訴RecyclerView列表上item的條數(shù)override fun getItemCount(): Int {return 20}// 【必須復(fù)寫】item的數(shù)據(jù)綁定override fun onBindViewHolder(holder: ViewHolder, position: Int) {holder.itemView.item_head.setImageResource(R.drawable.icon_jetpack)holder.itemView.item_name.text = "【${position}】移動(dòng)端架構(gòu)師體系課"holder.itemView.item_message.text ="移動(dòng)開發(fā)“兩極分化”,沒有差不多的“中間層,唯有盡早成長(zhǎng)為架構(gòu)師,你的職業(yè)道路才能走的更遠(yuǎn)更穩(wěn)"}}// 創(chuàng)建一個(gè)ViewHolder 必須繼承自 RecyclerView.ViewHolder。用于后續(xù)的數(shù)據(jù)綁定inner class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {}案例
代碼結(jié)構(gòu):
MainActivity.kt
package com.example.listexampleimport androidx.appcompat.app.AppCompatActivity import android.os.Bundle import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.RecyclerViewclass MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main) val list=listOf<String>("first","second","thrid","etc...")var recyclerView=findViewById<RecyclerView>(R.id.recyclerView)recyclerView.layoutManager=LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false)recyclerView.adapter=ItemAdapter(list)} }ItemAdapter.kt
package com.example.listexampleimport android.view.LayoutInflater import android.view.View import android.view.ViewGroup import android.widget.TextView import androidx.appcompat.view.menu.ActionMenuItemView import androidx.recyclerview.widget.RecyclerViewclass ItemAdapter(val items:List<String>) : RecyclerView.Adapter<ItemAdapter.ViewHolder>(){override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {val view=LayoutInflater.from(parent.context).inflate(R.layout.item_list,parent,false)return ViewHolder(view)}override fun onBindViewHolder(holder: ViewHolder, position: Int) { holder.bindView(items[position])}override fun getItemCount()=items.sizeinner class ViewHolder(itemView: View): RecyclerView.ViewHolder(itemView ){fun bindView(item: String){val textView= itemView.findViewById<TextView>(R.id.textView)textView.text=item }} }activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity"><androidx.recyclerview.widget.RecyclerViewandroid:id="@+id/recyclerView"android:layout_width="409dp"android:layout_height="729dp"android:layout_marginStart="20dp"android:layout_marginTop="20dp"android:layout_marginEnd="20dp"android:layout_marginBottom="13dp"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout>item_list.xml
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="wrap_content"><TextViewandroid:id="@+id/textView"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="TextView"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout>運(yùn)行效果
總結(jié)
以上是生活随笔為你收集整理的RecyclerView高级控件-附实例【android专题】的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 常用邮箱申请渠道有哪些?此文给你讲清楚了
- 下一篇: Flutter 完美的验证码输入框(2