最终在我的服务器中实现设备类型的图标后,我用服务器中的图标替换了之前使用的临时可绘制对象,并使用
coil
加载它们。顺便说一句,它们的 ImageView
在适配器内。第一次绘制时,一切都正确“对齐”,标签和图像是正确的配对。但是,如果我进行某种排序,ImageView
中的图像将不再与标签对齐,或者完全消失。我的应用程序中有一个行为,首先我将从服务器获取并显示数据,如果本地数据等于服务器的数据,那么我将只使用本地数据。但我认为这不会影响任何事情,因为我将服务器数据的每个字段保存在数据库上。我还添加了一些日志记录来查看 coil
应该检索哪些 URL,它们是每个图标的正确 URL。我调用 notifyDatasetChanged()
来重绘适配器,因为排序可能会返回与默认列表不同长度的项目,默认列表是我拥有的所有项目。
这是我的适配器的代码:
class ActuatorDeviceInfoAdapter(
val ctx: FragmentActivity,
var itemLst: MutableList<ActuatorDeviceInfo>,
val showToggle: Boolean
) : RecyclerView.Adapter<ActuatorDeviceInfoAdapter.ViewHolder>() {
private lateinit var binding: AdapterActuatorBinding
var onItemClick: ((ActuatorDeviceInfo) -> Unit)? = null
var onToggleClick: ((ActuatorDeviceInfo, Boolean, AdapterActuatorBinding) -> Unit)? = null
override fun onCreateViewHolder(
parent: ViewGroup,
viewType: Int
): ActuatorDeviceInfoAdapter.ViewHolder {
binding = AdapterActuatorBinding.inflate(LayoutInflater.from(parent.context), parent, false)
return ViewHolder(binding)
}
override fun onBindViewHolder(holder: ActuatorDeviceInfoAdapter.ViewHolder, position: Int) {
val pic = itemLst[position]
holder.bind(pic)
}
override fun getItemCount(): Int = itemLst.size
inner class ViewHolder(private val binding: AdapterActuatorBinding) :
RecyclerView.ViewHolder(binding.root) {
fun bind(actuatorDeviceInfo: ActuatorDeviceInfo) {
binding.actuatorDevInfo = actuatorDeviceInfo
if (showToggle) {
binding.tglStatus.visibility = View.VISIBLE
binding.tglStatus.isChecked = actuatorDeviceInfo.status
} else {
binding.tglStatus.visibility = View.GONE
}
setIcon(actuatorDeviceInfo.type!!)
}
init {
itemView.setOnClickListener {
onItemClick?.invoke(itemLst[adapterPosition])
}
binding.tglStatus.setOnClickListener {
onToggleClick?.invoke(itemLst[adapterPosition], binding.tglStatus.isChecked, binding)
}
}
}
private fun setIcon(type: ActuatorType) {
val iconPath = "${Utils.instance.getServerHost(ctx)}${type.iconPath}"
binding.imgIcon.load(iconPath)
}
companion object{
const val TAG = "ActuatorDeviceInfoAdapter"
}
}
问题出在私有函数
setIcon
。
您需要使用每个 ActuatorDeviceInfo 更新每个项目的视图。
您需要使用 Item 视图的 Binding 来设置数据和图像。
bind() 中的 For 语句使用每个项目的绑定。 但是 setIcon 使用一些其他具有最后初始化视图的绑定,但它不应该按照您的要求。
private lateinit var binding: AdapterActuatorBinding
。val binding =
。以上1,2步可选。