簡體   English   中英

Recyclerview onclick 打開新片段

[英]Recyclerview onclick to open new fragment

我在片段中有recycleview。 當我單擊 recyclerview 中的一項時,我想打開新片段。 如您所見,我必須在我的適配器中列: 在此處輸入圖像描述 我還創建了兩個片段。(fragment_opel 和片段雪佛蘭。)當用戶單擊雪佛蘭行時,片段雪佛蘭必須打開。我是 android 工作室的新手。我在我的適配器中創建 onclick 方法。 但我無法填寫 function。 :) 你能幫我一下嗎?

我的適配器:

package com.example.parcaburada



class AracMarkaAdapter(tumKategori: ArrayList<AracMarka>) :
    RecyclerView.Adapter<AracMarkaAdapter.AracMarkaViewHolder>() {


    var araclar = tumKategori

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): AracMarkaViewHolder {

        var inflater = LayoutInflater.from(parent.context)
        var arackategori = inflater.inflate(R.layout.arac_kategori, parent, false)

        return AracMarkaViewHolder(arackategori)

    }

    override fun getItemCount(): Int {
        return araclar.size
    }

    override fun onBindViewHolder(holder: AracMarkaViewHolder, position: Int) {


        holder.aracismi.text = araclar.get(position).aracAdi
        holder.aracLogo.setImageResource(araclar.get(position).aracLogo)


    }


    class AracMarkaViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView),
        View.OnClickListener {
        override fun onClick(v: View?) {


        }


        var teksatirKategori = itemView
        var aracismi = teksatirKategori.tvaracAdi
        var aracLogo = teksatirKategori.img_arac_sembol
    }


}

我的片段:

package com.example.parcaburada.ui.kategori



class KategoriFragment : Fragment() {
    var araclarKategori = ArrayList<AracMarka>()


    private lateinit var galleryViewModel: GalleryViewModel

    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        veriKaynaginiDoldur()
        galleryViewModel =
            ViewModelProviders.of(this).get(GalleryViewModel::class.java)
        var root = inflater.inflate(R.layout.fragment_category, container, false)

        var rvarackategori = root.findViewById(R.id.rvarackategori) as RecyclerView
        var MyAdapter = AracMarkaAdapter(araclarKategori)
        rvarackategori.adapter = MyAdapter

        var linearLayoutManager = LinearLayoutManager(context, RecyclerView.VERTICAL, false)
        rvarackategori.layoutManager = linearLayoutManager

        return root
    }

    fun veriKaynaginiDoldur(): ArrayList<AracMarka> {

        var aracLogo = arrayOf(R.drawable.opellogo, R.drawable.chevroletlogo)
        var aracismi = resources.getStringArray(R.array.arabaisim)

        for (i in 0 until min(aracismi.size, aracLogo.size)) {

            var eklenecekaracKategori = AracMarka(aracismi[i], aracLogo[i])
            araclarKategori.add(eklenecekaracKategori)
        }
        return araclarKategori

    }

    override fun onActivityCreated(savedInstanceState: Bundle?) {
        super.onActivityCreated(savedInstanceState)

    }


}

首先設置一個點擊監聽器:

ViewHolder object 上設置點擊監聽器。

  override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): AracMarkaViewHolder {

    var inflater = LayoutInflater.from(parent.context)
    var arackategori = inflater.inflate(R.layout.arac_kategori, parent, false)

    return AracMarkaViewHolder(arackategori).also {
       arackategori.setOnClickListener { clickHandler.forwardClick(it) }
    }
}

我們設置了一個監聽器,我們在其中調用 function forwardClick(holder: AracMarkaViewHolder) 我們將當前膨脹的視圖持有者引用傳遞給它,以便我們可以對它進行任何未來的操作。

現在設置一個界面:

我們創建一個界面是因為我們希望任何點擊事件都由活動處理。 在您的情況下,這些事件包括啟動一個新片段。

interface ClickEventHandler {
    fun forwardClick(holder: AracMarkaViewHolder)
}

現在在您的適配器中,設置如下界面:

private val clickHandler: ClickEventHandler = context as ClickEventHandler 

修改適配器 class 簽名:

現在,我們需要稍微修改適配器的構造函數。

var MyAdapter = AracMarkaAdapter(araclarKategori, requireContext()) //We pass the activity's context. 

您的適配器 class 簽名應如下所示:

 class AracMarkaAdapter(tumKategori: ArrayList<AracMarka>, context: Context) :
   RecyclerView.Adapter<AracMarkaAdapter.AracMarkaViewHolder>() {
        private val clickHandler: ClickEventHandler = context as ClickEventHandler 
  }   

實現接口:

現在我們在活動中實現接口。

class MainActivity : AppCompatActivity(), ClickEventHandler  {
  override fun forwardClick(holder: AracMarkaViewHolder) {
     //Launch a new fragment here.
  }
}

只需像這樣在onBindViewHolder方法中實現“轉到片段”-

override fun onBindViewHolder(holder: AracMarkaViewHolder, position: Int) {
    holder.aracismi.text = araclar.get(position).aracAdi
    holder.aracLogo.setImageResource(araclar.get(position).aracLogo)
    holder.setOnClickListener {
        if (position == 0) {
            TODO("Go to first fragment")
        } else {
            TODO("Go to second fragment")
        }
    }
}

以防萬一這有助於任何使用 Kotlin 和 Android Studio 4 的人。

我在片段中的 RecycleView 上使用適配器。 您只能在 mainactivity.kt class 而不是適配器 class 中進行覆蓋,因為如果您要顯示新的片段視圖,它不在主線程上。

因此,我的 recyclerview 適配器中的構造函數更改為:

class MyFollowRecyclerViewAdapter(
    private val values: List<FollowItem>,
    private val context: Context
)

然后我的適配器 class 中有一個變量:

 private val clickHandler: ClickEventHandler = context as ClickEventHandler

然后我將適配器 class 中的 setOnClickListener 添加到 onCreateViewHolder 方法中:

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        val view = LayoutInflater.from(parent.context)
            .inflate(layout.fragment_item_follow, parent, false)
        view.setOnClickListener {
            clickHandler.viewFollow(it)
        }
        return ViewHolder(view)
    }

ClickEventHandler 在我的適配器 class 中定義為:

  interface ClickEventHandler {
        fun viewFollow(holder: View)
    }

現在在 mainactivity 中覆蓋 function。 我將 ClickEventListener 添加到我的 MainActivity class:

class MainActivity : AppCompatActivity(), ClickEventHandler {

然后我在我的主活動 ZA2F2ED4F8EBC2ABC1DDC40 中定義在我的適配器 class 中定義的 function 的覆蓋 function :

 override fun viewFollow(holder: View) {
}

你需要為你的適配器實現一個 onClickListener 接口。 之后,您可以設置您的 recyclerview 可見性消失和 frameLayout Visible。 現在將您想要的片段發送到 frameLayout。

或者

在您的主要活動中實現適配器 onClickListener 並通過選定的 recyclerview 項目索引顯示您想要的片段

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM