微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

尝试在列表适配器中单击图像视图时更改它的可绘制对象

如何解决尝试在列表适配器中单击图像视图时更改它的可绘制对象

实际上,问题是当我单击单个项目的图像视图时,它的可绘制对象正在发生变化,但许多其他随机项目的图像视图也会随着单击而变化。下面是我的列表适配器代码。我已经从一些来源看到了这个问题的解决方案,我发现设置标签然后设置点击侦听器有效,但它对我不起作用。作为参考,addMealItem 是单击时要更改的视图的 id。我什至添加了 toast 来测试有什么问题,但在这种情况下 toast 不是很有帮助。


class FoodsAdapter(application: Application,val context: Context,val clickListener: MealItemclickListener) : listadapter<MealItemmodel,FoodsAdapter.ViewHolder>(MealItemDiffCallBack()) {
    val database = MealItemDatabase.getInstance(application)

    class ViewHolder private constructor(val binding: Mealitembinding) : RecyclerView.ViewHolder(binding.root) {
        fun bind(item: MealItemmodel,clickListener: MealItemclickListener,context: Context,database: MealItemDatabase) {
            binding.food = item
            GlobalScope.launch {
                withContext(dispatchers.IO) {
                    if(database.mealItemDao.getBreakfastItem(item.itemTitle)!=null) {
                        if (database.mealItemDao.getBreakfastItem(item.itemTitle).likedOrNot) {
                            binding.addmealItem.setTag("unliked")
                            withContext(dispatchers.Main){
                                Toast.makeText(context,"Unliked",Toast.LENGTH_LONG).show()
                            }
                            binding.addmealItem.setimageResource(R.drawable.ic_add_button)
                        } else {
                            withContext(dispatchers.Main){
                                Toast.makeText(context,"Liked",Toast.LENGTH_LONG).show()
                            }
                            binding.addmealItem.setTag("liked")
                            binding.addmealItem.setimageResource(R.drawable.ic_add_button_filled)
                        }
                    }
                }
            }
            binding.addmealItem.setonClickListener {
                clickListener.onClick(item)
                GlobalScope.launch {
                    withContext(dispatchers.IO) {
                        if(database.mealItemDao.getBreakfastItem(item.itemTitle)!=null) {
                            if (database.mealItemDao.getBreakfastItem(item.itemTitle).likedOrNot) {
                                binding.addmealItem.setTag("unliked")
                                withContext(dispatchers.Main){
                                    Toast.makeText(context,Toast.LENGTH_LONG).show()
                                }
                                binding.addmealItem.setimageResource(R.drawable.ic_add_button)
                                database.mealItemDao.getBreakfastItem(item.itemTitle).likedOrNot = false
                            } else {
                                binding.addmealItem.setTag("liked")
                                withContext(dispatchers.Main){
                                    Toast.makeText(context,Toast.LENGTH_LONG).show()
                                }
                                binding.addmealItem.setimageResource(R.drawable.ic_add_button_filled)
                                database.mealItemDao.getBreakfastItem(item.itemTitle).likedOrNot = true
                            }
                        }
                    }
                }
            }

//            binding.addmealItem.setonClickListener {
//                clickListener.onClick(item)
//                if (binding.addmealItem.drawable.constantState!!.equals(ResourcesCompat.getDrawable(context.resources,R.drawable.ic_add_button,null)!!.constantState)) {
//                    binding.addmealItem.setimageResource(R.drawable.ic_add_button_filled)
//                } else {
//                    binding.addmealItem.setimageResource(R.drawable.ic_add_button)
//                }
//            }
            binding.executePendingBindings()
        }

        companion object {
            fun from(parent: ViewGroup): ViewHolder {
                val layoutInflater = LayoutInflater.from(parent.context)
                val binding = Mealitembinding.inflate(layoutInflater,parent,false)
                return ViewHolder(binding)
            }
        }
    }

    override fun onCreateViewHolder(parent: ViewGroup,viewType: Int): ViewHolder {
        return ViewHolder.from(parent)
    }

    override fun onBindViewHolder(holder: ViewHolder,position: Int) {
        val item = getItem(position)
        holder.bind(item,clickListener,context,database)
    }
}

class MealItemDiffCallBack : DiffUtil.ItemCallback<MealItemmodel>() {
    override fun areItemsTheSame(oldItem: MealItemmodel,newItem: MealItemmodel): Boolean {
        return oldItem == newItem
    }

    override fun areContentsTheSame(oldItem: MealItemmodel,newItem: MealItemmodel): Boolean {
        return oldItem.itemTitle == newItem.itemTitle
    }
}

class MealItemclickListener(val clickListener: (foodTitle: String) -> Unit) {
//    var flag = false
    fun onClick(mealItem: MealItemmodel) {
//        flag = !flag
        return clickListener(mealItem.itemTitle)
    }
}  

解决方法

如果您要实现的功能具有相似/不同的功能。 您应该尝试创建自定义可绘制对象。

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:android:state_enabled="true"
      android:drawable="@android:color/liked"/>
<item android:drawable="@android:color/unliked"/>
</selector>

使用此作为xml中图像的drawable,您将能够通过访问视图来访问图像的两种状态并在其之间切换

addMealItem.isEnabled=true //(or false) this should be able to do the switching easily.
,

如果您想动态更改可绘制颜色,请使用此即

(itemBinding.tvGrade.background as GradientDrawable).setColor(Color.parseColor(item?.gradeColor))

如果您想以编程方式更改可绘制对象,请执行以下操作

binding.workBtn.setBackgroundResource(R.drawable.work_selected_bg)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。