4 кликабельных просмотра в одной и той же программе recyclerView (kotlin) - PullRequest
0 голосов
/ 30 апреля 2020

Я хочу установить множество кнопок (я имею в виду кликабельные просмотры) в элементе recyclerView, как у каждого элемента есть загрузка, воспроизведение, остановка, удаление. Как я могу это сделать? если я установилOnlickListener как holder.download_image.setOnClickListenr () {} его работы для всех элементов, я хочу, чтобы у каждого элемента была отдельная ссылка для скачивания

class RecyclerAdapter(private val soundList: List<SoundItem>,private val mListener: AdapterView.OnItemClickListener?) :
    RecyclerView.Adapter<RecyclerAdapter.RecyclerViewHolder>() {



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


        val itemView =
            LayoutInflater.from(parent.context).inflate(R.layout.recycler_view, parent, false)
        return RecyclerViewHolder(itemView)
    }



    override fun onBindViewHolder(holder: RecyclerViewHolder, position: Int) {
        val currnetItem = soundList[position]
        holder.soundNmae.text = currnetItem.soundName
        holder.play_image.setImageResource(currnetItem.playImage)
        holder.stop_image.setImageResource(currnetItem.stopImage)
        holder.download_image.setImageResource(currnetItem.donloadImage)
        holder.delete_image.setImageResource(currnetItem.deleteImage)



    }

    override fun getItemCount() = soundList.size
    class RecyclerViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        val soundNmae = itemView.soundName
        val play_image = itemView.play_image
        val stop_image = itemView.stop_image
        val download_image = itemView.download_image
        val delete_image = itemView.delete_image



    }     

}

, это активность для recyclerView im new in kotlin извините, если мой вопрос может быть простым, или я могу сказать, что я имею в виду

class RelaxSoundActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_relax_sound)
        val exampleList=generatorSoundList(500)
        recyceler_view.adapter=RecyclerAdapter(exampleList)
        recyceler_view.layoutManager=LinearLayoutManager(this)
        recyceler_view.setHasFixedSize(true)
    }


    fun generatorSoundList(size:Int ):List<SoundItem>{
         val list=ArrayList<SoundItem>()
        for(i in 0 until size){
            val drawable=when(i % 5){
                0->R.drawable.ic_play_arrow_black_24dp
                1->R.drawable.ic_play_arrow_black_24dp
                2->R.drawable.ic_play_arrow_black_24dp
                3->R.drawable.ic_play_arrow_black_24dp
                else->R.drawable.ic_play_arrow_black_24dp
            }
            val drawable2=when(i % 5){
                0->R.drawable.ic_stop_black_24dp
                1->R.drawable.ic_stop_black_24dp
                2->R.drawable.ic_stop_black_24dp
                3->R.drawable.ic_stop_black_24dp
                else->R.drawable.ic_stop_black_24dp
            }
            val drawable3=when(i % 5){
                0->R.drawable.ic_file_download_black_24dp
                1->R.drawable.ic_file_download_black_24dp
                2->R.drawable.ic_file_download_black_24dp
                3->R.drawable.ic_file_download_black_24dp
                else->R.drawable.ic_file_download_black_24dp
            }
            val drawable4=when(i % 5){
                0->R.drawable.ic_delete_black_24dp
                1->R.drawable.ic_delete_black_24dp
                2->R.drawable.ic_delete_black_24dp
                3->R.drawable.ic_delete_black_24dp
                else->R.drawable.ic_delete_black_24dp
            }
            val item=SoundItem("item $i" ,drawable,drawable2,drawable3,drawable4)
            list+=item

        }
        return list
    }
}

и recycler_view. xml файл здесь

<?xml version="1.0" encoding="utf-8"?>
<androidx.cardview.widget.CardView 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"

    >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal"
        android:padding="8dp"
       >


        <TextView
            android:id="@+id/soundName"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="TextView"
            android:textSize="20dp"/>

        <ImageView
            android:id="@+id/play_image"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            app:srcCompat="@drawable/ic_play_arrow_black_24dp" />

        <ImageView
            android:id="@+id/stop_image"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            app:srcCompat="@drawable/ic_stop_black_24dp" />

        <ImageView
            android:id="@+id/download_image"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            app:srcCompat="@drawable/ic_file_download_black_24dp" />

        <ImageView
            android:id="@+id/delete_image"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            app:srcCompat="@drawable/ic_delete_black_24dp" />

    </LinearLayout>
</androidx.cardview.widget.CardView>

Ответы [ 2 ]

1 голос
/ 30 апреля 2020

вы можете сделать это несколькими способами. Вы можете добавить прослушиватели щелчков на своих представлениях и напрямую выполнить операцию в своем адаптере, или вы можете передать функцию в своем классе держателя представления переработчика.

Так что для краткого описания я могу просто дать вам способ, которым вы можете понять process.

В вашем адаптере onBindViewHolder вы можете добавить

holder.download_image.setOnCLickListener{
   val downloadLink = currnetItem.getDownloadLink()
   // Download task start by this download link

}

Таким образом, этот прослушиватель одним нажатием на загружаемом изображении будет воздействовать на каждый элемент и выполнять отдельно.

0 голосов
/ 30 апреля 2020

IMO, вы должны прикрепить список щелчков к каждой кнопке, а затем вы можете либо сделать обратный вызов для адаптера / действия и обработать его оттуда.

Если вы используете View.OnClickListener, то вы всегда кликабельный вид. С этого момента, это всего лишь вопрос написания оператора switch, в котором вы можете определить с помощью идентификатора нажатого представления, какое действие было выбрано.

Если вам нужны дополнительные данные, вы можете просто добавить тег в представление и передать его через clickListener.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...