欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Kotlin使用滾動控件RecyclerView實例教程

 更新時間:2022年12月02日 09:22:51   作者:Hdnw  
RecyclerView是Android一個更強大的控件,其不僅可以實現和ListView同樣的效果,還有優(yōu)化了ListView中的各種不足。其可以實現數據縱向滾動,也可以實現橫向滾動(ListView做不到橫向滾動)。接下來講解RecyclerView的用法

1.RecyclerView介紹

  • RecyclerView是一個增強版的ListView(Android 5.0推出)。
  • 被用來代替ListView和GridView控件,并且能夠實現瀑布流的布局。
  • 它更加高級并且更加靈活·,可提供更為高效的回收復用機制,同時實現管理與視圖的解耦合。

2.RecyclerView控件的使用

步驟: 在項目的build.gradle中添加RecyclerView庫的依賴。

implementation 'androidx.recyclerview:recyclerview:1.2.1'

在布局中加入RecyclerView控件和為RecyclerView的子項指定一個我們自定義的布局。

<androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
/>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="60dp">
     <ImageView
         android:id="@+id/fruitImage"
         android:layout_width="40dp"
         android:layout_height="40dp"
         android:layout_gravity="center_horizontal"
         android:layout_marginTop="10dp"
         />
    <TextView
        android:id="@+id/fruitName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="10dp"/>
</LinearLayout>

自定義RecyclerView.Adapter適配器

  • 要創(chuàng)建一個Adapter類,該類繼承于RecyclerView.Adapter<VH>,其中VH是我們在Adapter類中創(chuàng)建的一個繼承于RecyclerView.ViewHolder的內部類。
  • 該Adapter類主要有3個方法和一個自定義ViewHolder組成。

(1)onCreateViewHolder:創(chuàng)建ViewHolder并返回,后續(xù)item布局里控件都是從ViewHolder中取出

(2)onBindViewHolder:通過方法提供ViewHolder,將數據綁定到ViewHolder。

(3)getItemCount:獲取數據源總的條數。

(4)viewHolder:這是RecyclerView.ViewHolder的實現類,可用于初始化item布局中的子控件。需要注意的是,在這個類的構造方法中需要傳遞item布局的View給父類。

class FruitAdapter(val fruitList:List<Fruit>):RecyclerView.Adapter<FruitAdapter.ViewHolder>(){
    inner class ViewHolder(view: View):RecyclerView.ViewHolder(view){
        val fruitName:TextView=view.findViewById(R.id.fruitName)
        val fruitImage:ImageView=view.findViewById(R.id.fruitImage)
    }
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        val view=LayoutInflater.from(parent.context).inflate(R.layout.fruit_item,parent,false)
        return ViewHolder(view)
    }
    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
        val fruit=fruitList[position]
        holder.fruitImage.setImageResource(fruit.imageId)
        holder.fruitName.text=fruit.name
    }
    override fun getItemCount(): Int {
       return fruitList.size
    }
}

RecyclerView綁定數據適配器

class MainActivity : AppCompatActivity() {
    private val fruitList = ArrayList<Fruit>()
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        //初始化控件
        val recyclerView = findViewById<RecyclerView>(R.id.recyclerView)
        initFruits()
        //設置RecyclerView布局管理器
        val layoutManager = LinearLayoutManager(this)
        recyclerView.layoutManager = layoutManager
        //設置適配器
        val adapter = FruitAdapter(fruitList)
        recyclerView.adapter = adapter
    }
    private fun initFruits() {
        repeat(2) {
            fruitList.add(Fruit("Apple", R.drawable.apple_pic))
            fruitList.add(Fruit("Banana", R.drawable.banana_pic))
            fruitList.add(Fruit("Orange", R.drawable.orange_pic))
            fruitList.add(Fruit("Watermelon", R.drawable.watermelon_pic))
            fruitList.add(Fruit("Pear", R.drawable.pear_pic))
            fruitList.add(Fruit("Grape", R.drawable.grape_pic))
            fruitList.add(Fruit("Pineapple", R.drawable.pineapple_pic))
            fruitList.add(Fruit("Strawberry", R.drawable.strawberry_pic))
            fruitList.add(Fruit("Cherry", R.drawable.cherry_pic))
            fruitList.add(Fruit("Mango", R.drawable.mango_pic))
        }
    }
}

效果如圖:

3.實現橫向滾動

瀑布流布局和網格布局

橫向滾動

(1)對子布局進行修改

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="80dp"
    android:layout_height="wrap_content">
     <ImageView
         android:id="@+id/fruitImage"
         android:layout_width="40dp"
         android:layout_height="40dp"
         android:layout_gravity="center_horizontal"
         android:layout_marginTop="10dp"
         />
    <TextView
        android:id="@+id/fruitName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="10dp"/>
</LinearLayout>

(2)在MainActivity中加入一行代碼

layoutManager.orientation=LinearLayoutManager.HORIZONTAL//表示讓布局橫行排列

效果圖:

瀑布流布局

(1)對子布局進行修改

LinearLayout的寬度改為match_parent,因為瀑布流布局的寬度是根據布局的列數自動適配的,而不是一個固定值。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp">
     <ImageView
         android:id="@+id/fruitImage"
         android:layout_width="40dp"
         android:layout_height="40dp"
         android:layout_gravity="center_horizontal"
         android:layout_marginTop="10dp"
         />
    <TextView
        android:id="@+id/fruitName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left"
        android:layout_marginTop="10dp"/>
</LinearLayout>

(2)在MainActivity中加入一行代碼

val layoutManager=StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL) 

效果圖:

網格布局

(1)在MainActivity中加入一行代碼

val layoutManager=GridLayoutManager(this,3)

效果圖:

4.RecyclerView的點擊事件

與ListView不同的是,RecyclerView并沒有提供類似于setOnItemClickListener()這樣的注冊監(jiān)聽器,而是需要我們自己給子項具體的View去注冊點擊事件。

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        val view=LayoutInflater.from(parent.context).inflate(R.layout.fruit_item,parent,false)
        val viewHolder=ViewHolder(view)
        viewHolder.itemView.setOnClickListener {
            val position=viewHolder.bindingAdapterPosition
            val fruit=fruitList[position]
            Toast.makeText(parent.context,"你點擊了${fruit.name}",Toast.LENGTH_SHORT).show()
        }
        viewHolder.fruitImage.setOnClickListener{
            val position=viewHolder.bindingAdapterPosition
            val fruit=fruitList[position]
            Toast.makeText(parent.context,"你點擊了${fruit.name}的圖片",Toast.LENGTH_SHORT).show()
        }
        return viewHolder
    }

效果圖:

getAdapterPosition()方法被標記成了廢棄問題:

官方放棄getAdapterPosition()方法,換成了getbindingAdapter()和getAbsoluteAdapterPosition()方法,當使用recyclerView的監(jiān)聽事件時,

getbindingAdapter():表示單個數據源的單獨位置。

getAbsoluteAdapterPosition():表示多個數據源的位置。

5.下拉刷新

1.SwipeRefreshLayout控件的介紹

SwipeRefreshLayout控件是谷歌公司提供的下拉刷新控件,具有使用簡單、靈活等特點。

SwipeRefreshLayout控件的方法有很大,這里只介紹常用的5個方法:

  • isRefreshing()

判斷當前的狀態(tài)是否是刷新狀態(tài)

  • setColorSchemeResources()

設置下拉進度條的顏色主題,參數為可變參數,并且為資源ID,可以用來設置多種不同的顏色,沒轉一圈就顯示一種顏色。

  • setOnRefreshListener()

設置監(jiān)聽,需要重寫onRefresh()方法頂部下拉時會調用這個方法。在里面實現請求數據的邏輯,設置下拉進度條消失等。

  • setProgressBackgroundColorSchemeResource()

設置下拉進度條的背景顏色,默認為白色。

  • setRefreshing(boolean refreshing)

設置刷新狀態(tài),true表示正在刷新,false表示取消刷新。

2.SwipeRefreshLayout控件的使用

添加依賴

implementation 'androidx.swiperefreshlayout:swiperefreshlayout:1.1.0'

在RecyclerView的外面嵌套一層SwipeRefreshLayout,這樣RecyclerView就擁有下拉刷新功能了。

<androidx.swiperefreshlayout.widget.SwipeRefreshLayout
        android:id="@+id/swipeRefresh"
        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"/>
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>

首先調用swipeRefreshLayout的setColorSchemeResources()方法設置下拉刷新進度條的顏色,接著調用swipeRefreshLayout的setOnRefreshListener()方法來設置一個下拉刷新的監(jiān)聽器,當觸發(fā)了下拉刷新事件時,就去網絡上請求最新的數據,然后再將這些數據展示出來。

    val swipeRefresh:SwipeRefreshLayout=findViewById(R.id.swipeRefresh)
        swipeRefresh.setColorSchemeResources(R.color.purple_200)
        swipeRefresh.setOnRefreshListener {
            thread {
                Thread.sleep(2000)
                runOnUiThread {
                    initFruits()
                    adapter.notifyDataSetChanged()
                    swipeRefresh.isRefreshing=false
                }
            }
        }

到此這篇關于Kotlin使用滾動控件RecyclerView實例教程的文章就介紹到這了,更多相關Kotlin RecyclerView內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Android?app啟動節(jié)點與上報啟動實例詳解

    Android?app啟動節(jié)點與上報啟動實例詳解

    系統(tǒng)的啟動過程非常復雜,下面這篇文章主要給大家介紹了關于Android?app啟動節(jié)點與上報啟動的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • Android 通過代碼安裝 APK的方法詳解

    Android 通過代碼安裝 APK的方法詳解

    這篇文章主要介紹了Android 通過代碼安裝 APK的方法詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學習火鍋工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Android登錄代碼MVP架構詳解

    Android登錄代碼MVP架構詳解

    這篇文章主要為大家詳細介紹了Android登錄代碼MVP架構的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 解決EditText、ListView以及GridView同時使用,輸入法自動跳出來的方法

    解決EditText、ListView以及GridView同時使用,輸入法自動跳出來的方法

    本篇文章是對在Android中EditText、ListView以及GridView同時使用,輸入法自動跳出來的解決方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • Android實現帶圓環(huán)的圓形頭像

    Android實現帶圓環(huán)的圓形頭像

    這篇文章主要為大家詳細介紹了Android實現帶圓環(huán)的圓形頭像,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Android studio 切換flutterSDK之后報錯及解決辦法(推薦)

    Android studio 切換flutterSDK之后報錯及解決辦法(推薦)

    這篇文章主要介紹了Android studio 切換flutterSDK之后報錯及解決辦法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Flutter實現可以縮放拖拽的圖片示例代碼

    Flutter實現可以縮放拖拽的圖片示例代碼

    這篇文章主要給大家介紹了關于利用Flutter實現可以縮放拖拽的圖片的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Flutter具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • Cocos2d-x 3.0多線程異步加載資源實例

    Cocos2d-x 3.0多線程異步加載資源實例

    手機游戲,即便是休閑類的小游戲,往往也涉及大量紋理資源、音視頻資源、文件讀寫以及網絡通信,處理的稍有不甚就會出現畫面卡頓,交互不暢的情況
    2014-04-04
  • Android 將文件下載到指定目錄的實現代碼

    Android 將文件下載到指定目錄的實現代碼

    本文通過實例代碼給大家介紹了android將文件下載到指定目錄的實現方法,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-06-06
  • Android開發(fā)之TextView控件用法實例總結

    Android開發(fā)之TextView控件用法實例總結

    這篇文章主要介紹了Android開發(fā)之TextView控件用法,結合實例形式總結分析了TextView控件常用的屬性設置及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-02-02

最新評論