1

我一直在尝试RecyclerView在列表项为ImageViews 的应用程序中进行工作,并且图像被下载并(异步)放入onBindViewHolder方法中。我的代码没有遇到任何错误,但出于某种原因

只有在加载活动时对用户可见(甚至部分)的列表项才会加载图像。

虽然我看不到图像,但我观察到这些项目的高度和宽度已正确分配。由于首先下载图像,然后确定ImageView's 的尺寸,我认为问题与RecyclerView它本身有关吗?如果有人可以对此有所了解,那就太好了。谢谢。

我还想补充一点,如果 Activity 暂停然后恢复(通过单击“方形”导航按钮然后恢复它),所有列表项的图像都会正确加载。

图#1 如您所见,图像应该在的灰色部分 图#2 更有说服力:)

这是我的代码:

onCreate方法:

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

        recyclerView {
            id = ViewID.ID_LIST
        }

        val imgList = ArrayList<ImageView>()
        imgList.add(ImageView(ctx))
        imgList.add(ImageView(ctx))
        imgList.add(ImageView(ctx))
        imgList.add(ImageView(ctx))
        val lv = findViewById(ViewID.ID_LIST) as RecyclerView
        lv.layoutManager = LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false)
        lv.adapter = ImageRecyclerAdapter(ctx, imgList)

}

RecyclerView.Adapter班级:

private class ImageRecyclerAdapter(val context: Context, val imageList: ArrayList<ImageView>) :
            RecyclerView.Adapter<RecyclerView.ViewHolder>() {

        override fun onViewRecycled(holder: RecyclerView.ViewHolder?) {
            super.onViewRecycled(holder)
            if (holder != null) {
                val v = holder.itemView as ImageView
                v.setImageBitmap(null)
            }
        }

        override fun onBindViewHolder(p: RecyclerView.ViewHolder, position: Int) {
            val v = p.itemView as ImageView
            Ion.with(v)
                    .load("https://pbs.twimg.com/profile_images/616076655547682816/6gMRtQyY.jpg")
                    .setCallback({ exception, t ->
                        if (t != null) {
                            val dm = Point()
                            context.windowManager.defaultDisplay.getRealSize(dm)
                            val w = t.maxWidth
                            val h = t.maxHeight

                            val params = t.layoutParams
                            if (params != null) {
                                params.width = dm.x
                                params.height = (dm.x * (h.toDouble() / w.toDouble())).toInt()
                                t.layoutParams = params
                                t.requestLayout()
                            }
                        }
                    })
        }

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

        override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): RecyclerView.ViewHolder {
            val v = ImageView(context)
            return object : RecyclerView.ViewHolder(v) {}
        }
    }
4

1 回答 1

0

在我将数据绑定到同步请求之后,它起作用了,并且我将ImageView操作(更改LayoutParams)移动到onViewAttachedToWindow我的适配器的覆盖方法中。

onViewAttachedToWindow

override fun onViewAttachedToWindow(holder: RecyclerView.ViewHolder?) {
    super.onViewAttachedToWindow(holder)
    val t = holder?.itemView as ImageView
    val dm = Point()
    context.windowManager.defaultDisplay.getRealSize(dm)
    val w = t.maxWidth
    val h = t.maxHeight
    val params = t.layoutParams
    if (params != null) {
        params.width = dm.x
        params.height = (dm.x * (h.toDouble() / w.toDouble())).toInt()
        t.layoutParams = params
        t.requestLayout()
    }
}

onBindViewHolder

override fun onBindViewHolder(p: RecyclerView.ViewHolder, position: Int) {
    val v = p.itemView as ImageView
    Ion.with(v)
            .load(imageList[position].toString())
            .tryGet()
}
于 2016-12-25T08:32:01.260 回答