изменение видимости элемента в программе повторного просмотра изменяет видимость другого элемента - PullRequest
0 голосов
/ 09 декабря 2018

У меня есть просмотрщик с адаптером ... в обзоре есть элементы с кнопками, похожими на кнопки, в отличие от них.когда я нажимаю кнопку (нравится), (в отличие от) должен стать невидимым, и наоборот ... все работает нормально, но когда я нажимаю (нравится) в элементе (в отличие от) в других элементах также становится невидимым, как будто я нажимаюэта же кнопка в других представлениях Я уже пробовал этот ответ, но он не работал Android: изменение видимости представления в recyclerView вот код адаптера:

    package com.example.user.myapplication;

import android.app.Activity
import android.content.Context
import android.content.Intent
import android.content.SharedPreferences
import android.opengl.Visibility
import android.support.v4.widget.SwipeRefreshLayout
import android.support.v7.widget.RecyclerView
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.view.animation.*
import android.widget.*
import kotlinx.android.synthetic.main.activity_main.*
import kotlinx.android.synthetic.main.activity_main.view.*
import kotlinx.android.synthetic.main.item.view.*
import kotlinx.android.synthetic.main.itemm.view.*
import java.io.BufferedReader
import java.io.File
import java.io.FileReader

/**
 * Created by Ahmed on 10/14/2018.
 */

class ItemmAdapter(private val mItems: Array<File>,private val activity:Activity) : RecyclerView.Adapter<ItemmAdapter.ItemViewHolder>() {

    lateinit var parent:ViewGroup

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ItemViewHolder {
        val view = LayoutInflater.from(parent.context).inflate(R.layout.itemm, parent, false)
        this.parent=parent
        return ItemViewHolder(view)
    }

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

        val item = mItems[position]
        holder.itemView.layoutParams=RecyclerView.LayoutParams(parent.context.resources.displayMetrics.widthPixels/2,RecyclerView.LayoutParams.MATCH_PARENT)



        //holder.itemView.findViewById<ImageView>(R.id.image).setImageResource(R.drawable.icons8_cycling_104)
        //holder.itemView.findViewById<TextView>(R.id.description).text="abcdefghijklmnopqrstuvwxyzضصثقفغعهخحجدطكمنتالبيسشذئءؤرلاىة"
        //holder.itemView.findViewById<TextView>(R.id.price).text="10000$"
        holder.like.setOnClickListener{
            holder.like.visibility=View.GONE
            holder.unlike.visibility=View.VISIBLE
        }
        holder.unlike.setOnClickListener{
            holder.unlike.visibility=View.GONE
            holder.like.visibility=View.VISIBLE
        }
        holder.shopping.setOnClickListener{
            holder.shopping.visibility=View.GONE
            holder.notshopping.visibility=View.VISIBLE
        }
        holder.notshopping.setOnClickListener{
            holder.notshopping.visibility=View.GONE
            holder.shopping.visibility=View.VISIBLE
        }
    }

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

    inner class ItemViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        val like=itemView.findViewById<ImageView>(R.id.like)
        val unlike=itemView.findViewById<ImageView>(R.id.unlike)
        val shopping=itemView.findViewById<ImageView>(R.id.shopping)
        val notshopping=itemView.findViewById<ImageView>(R.id.notShopping)


    }

}

помогите мне, пожалуйста

Ответы [ 2 ]

0 голосов
/ 09 декабря 2018

Это происходит потому, что это представление рециркуляции (поэтому представление перерабатывается по мере прокрутки и видимости подобных или непохожих палочек).

Измените объект объекта, добавив логическое значение isLiked и установите егоtrue или false на onClick:

holder.like.setOnClickListener{
            item.setIsLiked(true);
        }

holder.unlike.setOnClickListener{
            item.setIsLiked(false);
        }

и установите видимость представления на основе этого:

holder.like.visibility=item.getIsLiked() ? View.VISIBLE : View.GONE; 
holder.unlike.visibility=item.getIsLiked() ? View.GONE : View.VISIBLE;

note : setIsLiked (boolean like) и getIsLiked() могут быть разными именами, если вы используете автоматически генерируемые геттеры и сеттеры;

сделать то же самое для покупок без покупок

0 голосов
/ 09 декабря 2018

только использовать привязку для установки содержимого элемента в каждом элементе и перемещать слушателей из метода привязки в класс держателя :

inner class ItemViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        var liked = false
        var shopped = false
        val like=itemView.findViewById<ImageView>(R.id.like)
        val unlike=itemView.findViewById<ImageView>(R.id.unlike)
        val shopping=itemView.findViewById<ImageView>(R.id.shopping)
        val notshopping=itemView.findViewById<ImageView>(R.id.notShopping)

        init{

           like?.setOnClickListener{
                 liked = true
                 like.visibility=View.GONE
                 unlike.visibility=View.VISIBLE
           }
           unlike?.setOnClickListener{
                  liked = false
                  unlike.visibility=View.GONE
                  like.visibility=View.VISIBLE
           }
           shopping?.setOnClickListener{
                  shopped = true 
                  shopping.visibility=View.GONE
                  notshopping.visibility=View.VISIBLE
           }
           notshopping?.setOnClickListener{
                  shopped = false
                  notshopping.visibility=View.GONE
                  shopping.visibility=View.VISIBLE
           }
       }

       fun bind(){// call this from onBind method of adapter
         if(liked) like?.performClick() else unlike?.performClick()
         if(shopped) shopping?.performClick() else notshopping?.performClick()
       }

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