- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的应用程序中,我使用的是 firestore recyclerview,它基本上是从云 firestore 文档中获取图像 url,并且使用 glide 图像库将所有获取的 url 加载到 RecyclerView
中,但是它成功加载了图像,但是当我开始时滚动它会在错误的位置显示图像,我无法弄清楚问题的原因。
这是我的代码:
private fun initializeData() {
db = FirebaseFirestore.getInstance()
val query: Query
query = db!!.collection("Items")
s = "Items"
val response = FirestoreRecyclerOptions.Builder<FriendsResponse>()
.setQuery(query, FriendsResponse::class.java)
.build()
adapter = object : FirestoreRecyclerAdapter<FriendsResponse, FriendsHolder>(response) {
public override fun onBindViewHolder(holder: FriendsHolder, position: Int, model: FriendsResponse) {
val id = snapshots.getSnapshot(position).id
holder.exname.text = id
db!!.collection("Items").document(id).get().addOnCompleteListener { task ->
if(activity!=null){
val document = task.result
val url = document!!.data!!["imageurl"] as String?
Glide.with(holder.imgmenu.context).load(url).into(holder.imgmenu)
}
}
holder.itemView.setOnLongClickListener {
s = "Items"
docname = (recyclerView!!.findViewHolderForAdapterPosition(position)!!.itemView.findViewById<View>(R.id.menuname) as TextView).text.toString()
false
}
holder.itemView.setOnClickListener { v ->
docname = (recyclerView!!.findViewHolderForAdapterPosition(position)!!.itemView.findViewById<View>(R.id.menuname) as TextView).text.toString()
db!!.collection("Items").document(docname!!).get().addOnCompleteListener { task ->
val document = task.result
val url = document!!.data!!["imageurl"] as String?
val id = document.data!!["Id"].toString()
val dialogBuilder = AlertDialog.Builder(activity)
val inflater = activity!!.layoutInflater
val dialogView = inflater.inflate(R.layout.fragment_itemdet, null)
dialogBuilder.setView(dialogView)
name = dialogView.findViewById(R.id.itemname)
img = dialogView.findViewById(R.id.itemdetimg)
img!!.setOnClickListener { v1 ->
docname = (recyclerView!!.findViewHolderForAdapterPosition(position)!!.itemView.findViewById<View>(R.id.menuname) as TextView).text.toString()
//Toast.makeText(getContext(),docname,Toast.LENGTH_LONG).show();
PickImageDialog.build(PickSetup()).show(activity!!)
val setup = PickSetup()
PickImageDialog.build(setup)
.setOnClick(object : IPickClick {
override fun onGalleryClick() {
val intent = Intent()
intent.type = "image/*"
intent.action = Intent.ACTION_GET_CONTENT
startActivityForResult(Intent.createChooser(intent, "Select Picture"), PICK_IMAGE)
}
override fun onCameraClick() {
val cameraIntent = Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE)
startActivityForResult(cameraIntent, REQUEST_CAMERA)
}
}).show(activity!!)
}
inst = dialogView.findViewById(R.id.tvinst)
etinst = dialogView.findViewById(R.id.etinst)
counter = dialogView.findViewById(R.id.counter)
add = dialogView.findViewById(R.id.add)
del = dialogView.findViewById(R.id.sub)
confirm = dialogView.findViewById(R.id.confirm)
val custom_font = Typeface.createFromAsset(activity!!.assets, "fonts/Poppins-ExtraBoldItalic.ttf")
name!!.typeface = custom_font
val alertDialog = dialogBuilder.create()
add!!.setOnClickListener { v -> counter!!.text = i++.toString() }
del!!.setOnClickListener { v -> counter!!.text = i--.toString() }
name!!.text = docname
Glide.with(holder.imgmenu.getContext()).load(url).into(img)
confirm!!.setOnClickListener { v ->
val qty = counter!!.text.toString()
val inst = etinst!!.text.toString()
if (qty == "0") {
Toasty.error(getContext()!!, "Please Specify Quantity", Toast.LENGTH_LONG, true).show()
} else {
db = FirebaseFirestore.getInstance()
db!!.collection("Order").document(TableListFragment.tableno)
.update(
"details", FieldValue.arrayUnion("$docname--$qty--$inst")
).addOnCompleteListener {
Toasty.success(getContext()!!, "Item Added", Toast.LENGTH_LONG, true).show()
alertDialog.dismiss()
}.addOnFailureListener { e -> Log.i("WhatdFuck:", e.toString()) }
}
}
alertDialog.setTitle("Order")
alertDialog.setMessage("Enter Order Details")
alertDialog.show()
}
}
}
override fun onCreateViewHolder(group: ViewGroup, i: Int): FriendsHolder {
val view = LayoutInflater.from(group.context)
.inflate(R.layout.menu_item, group, false)
return FriendsHolder(view)
}
override fun onError(e: FirebaseFirestoreException) {
Log.e("error", e.message)
}
}
adapter!!.notifyDataSetChanged()
//int spaceInPixels = 200;
val verticalDecoration = DividerItemDecoration(recyclerView!!.context,
DividerItemDecoration.HORIZONTAL)
val verticalDivider = ContextCompat.getDrawable(activity!!, R.drawable.divider_vertical)
verticalDecoration.setDrawable(verticalDivider!!)
recyclerView!!.addItemDecoration(verticalDecoration)
val horizontalDecoration = DividerItemDecoration(recyclerView!!.context,
DividerItemDecoration.VERTICAL)
val horizontalDivider = ContextCompat.getDrawable(activity!!, R.drawable.divider_horizontal)
horizontalDecoration.setDrawable(horizontalDivider!!)
recyclerView!!.addItemDecoration(horizontalDecoration)
recyclerView!!.adapter = adapter
}
我还尝试了来自谷歌的其他解决方案,例如取消请求并在使用 glide 加载之前将 null 传递给 imageview,但它们不起作用。
最佳答案
在适配器中覆盖这两个方法。
@Override
public long getItemId(int position) {
return position;
}
@Override
public int getItemViewType(int position) {
return position;
}
抱歉,我不熟悉 Kotlin。
关于Android firestore RecyclerView 正在加载错误的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55394297/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!