- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 UICollectionView
,我在其中显示图像或带有播放按钮的视频图像。单元格占据屏幕的整个宽度,因此同一时间只有一个单元格在屏幕上可见。用户可以向左或向右滚动以显示下一个图像或视频。我最能将它与 Instagram 的提要进行比较。
因此,当用户滚动时,总会有一张图片显示给用户。但是,当我在单元格中滚动时,比方说,有四张或五张图片时,它们会混淆。这是我的代码:
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "mediaSliderCell", for: indexPath) as! MediaSliderCell
if(dataArray.count > 0) {
if(dataArray[indexPath.item].mediaType == .photo) {
let mediaURL = URL(string: "https://myURL.com/media/\(dataArray[indexPath.item].mediaURL)")
cell.photoView.kf.setImage(with: mediaURL, options: [.targetCache(mediaCache)])
cell.photoView.isHidden = false
cell.videoView.isHidden = true
} else if(dataArray[indexPath.item].mediaType == .video) {
cell.photoView.isHidden = true
cell.videoView.isHidden = false
let mediaThumbURL = URL(string: "https://myURL.com/media/\(dataArray[indexPath.item].mediaThumbURL!)")
let mediaURL = URL(string: "https://myURL.com/media/\(dataArray[indexPath.item].mediaURL)")!
cell.videoView.placeholderView.kf.setImage(with: mediaThumbURL, options: [.targetCache(mediaCache)])
cell.videoView.mediaURL = mediaURL
cell.videoView.testLabel.text = "indexPath.item: \(indexPath.item)"
}
}
return cell
}
我知道出列是如何工作的。过去我遇到过这个问题。到目前为止,我还尝试了我所知道的一切来避免这个问题:
当我使用视频时会发生这种情况。对于照片,我还没有看到,但也可能是这种情况。我该如何解决这个问题?
这是我的MediaSliderCell
:
class MediaSliderCell: UICollectionViewCell {
override func prepareForReuse() {
videoView.placeholderView.kf.cancelDownloadTask()
videoView.placeholderView.image = UIImage()
photoView.image = UIImage()
}
var photoView: UIImageView = {
let photoView = UIImageView()
photoView.translatesAutoresizingMaskIntoConstraints = false
photoView.backgroundColor = .black
photoView.isHidden = true
return photoView
}()
var videoView: VideoView = {
let videoView = VideoView()
videoView.translatesAutoresizingMaskIntoConstraints = false
videoView.backgroundColor = .black
return videoView
}()
override init(frame: CGRect) {
super.init(frame: frame)
setupViews()
}
func setupViews() {
addSubview(photoView)
addSubview(videoView)
photoView.topAnchor.constraint(equalTo: topAnchor).isActive = true
photoView.bottomAnchor.constraint(equalTo: bottomAnchor).isActive = true
photoView.leadingAnchor.constraint(equalTo: leadingAnchor).isActive = true
photoView.trailingAnchor.constraint(equalTo: trailingAnchor).isActive = true
videoView.topAnchor.constraint(equalTo: topAnchor).isActive = true
videoView.bottomAnchor.constraint(equalTo: bottomAnchor).isActive = true
videoView.leadingAnchor.constraint(equalTo: leadingAnchor).isActive = true
videoView.trailingAnchor.constraint(equalTo: trailingAnchor).isActive = true
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
VideoView
也是自定义的,但这只是 AVPlayer
的实现,不应影响单元格的行为。这是相当多的代码,所以我不想发布它,因为它不处理显示的图像。知道这里发生了什么吗?当我在 cellForItemAt
中打印 indexPaths 和 URL 时,我总是得到我应该看到的图像的正确 URL。但是图像混淆了。我使用 KingFisher 下载图像并缓存它们以备将来使用。
编辑:基本上,据我了解目前的情况,在 cellForItemAt
中,返回了正确的数据(至少当我打印出来时)。我确实注意到,只要 iOS 想要检索它们,就会检索单元格,因此 iOS 可以为单元格 0、然后是单元格 1、然后是单元格 2、然后是单元格 1 获取数据……但这不应该是问题。
首先,我认为问题可能出在 KingFisher 下载方法中,因为当单元格已更改时,下载可能会稍后完成。但是话又说回来,该单元格也使用了错误的 mediaURL,因此不仅图像是错误的,而且我链接到它的 mediaURL 也是错误的(mediaURL 例如是 https://myURL.com/media/test.mp4,mediaThumbURL 例如是 https://myURL.com/media/thumb/test.jpeg)。我认为问题出在其他地方,也许在 VideoView 中?这会被重复使用或以某种方式错误关联吗?
提及我的 dataArray 是这样构建的可能也会有所帮助:
struct MediaData: Codable {
var mediaType: MediaType // enum .photo or .video
var mediaURL: String
var mediaThumbURL: String?
}
接下来,我简单地追加我的所有项目,因此我需要以正确的顺序显示它们,这就是我依赖 indexPath.item 正确地从数组中挑选它们的原因。
EDIT2:我现在注意到返回的 indexPath 有时也是错误的。我在单元格中添加了一个 UILabel
并添加了 cell.testLabel.text = indexPath.item
。有时,对于第一个单元格(应该是 indexPath 项目 0),结果是 3。所以第一个单元格,在左右滚动之后,然后有 indexPath (0,3)。为什么会这样?我该如何解决?
最佳答案
在对 KingsFisher 库进行一些研究后,我发现,如果图像的缓存是磁盘缓存,则 cancelDownloadTask() 不会阻止 KingsFisher 从磁盘缓存中检索图像。同样对于磁盘缓存,它会将获取的数据切换到另一个 DispatchQueue 并且 kf.setImage 会在一段时间后从磁盘缓存设置图像。这导致了有趣的“行为”(我会说这不是记录在案的行为或可能是错误)。
如何重现它:
1. 运行您的应用。
2. 滚动到收藏 View 的末尾。
3. 等待一段时间(直到所有图像都下载并缓存到磁盘)。
4. 重新启动您的应用。
5. 等待图像从磁盘缓存加载并显示在您的第一个 UICollectionViewCell 中。
6. 向右滚动到第二个单元格,无需等待即可返回到第一个单元格。
7. 您将看到来自第二个单元格而不是第一个单元格的图像。
原因是如果 KingsFisher 同步从内存缓存中获取图像。但对于磁盘缓存,它使其与另一个 DispatchQueue 异步。
// This url is loaded from disk cache
let url1 = URL(string: "some url 1")
// This url is loaded from memory cache
let url2 = URL(string: "some url 2")
// Because url1 is taken from disk cache
// it would be setted asynchronously in future.
imageView.kf.setImage(with: url1)
// Becase url2 is taken from memory cache
// it setted synchronously in present.
imageView.kf.setImage(with: url2)
// As result imageView constains image from url1 instead of image from url2.
/*
One of the solutions is to use .fromMemoryCacheOrRefresh option
that would igrnore disk cache, and load images synchronously from memory cache.
imageView.kf.setImage(with: url1, options: [.fromMemoryCacheOrRefresh])
imageView.kf.setImage(with: url2, options: [.fromMemoryCacheOrRefresh])
imageView will show image from url2.
*/
此外,您在 setupViews 中必须将标签和视频 View 放置在它的 contentView 上而不是单元格上。
contentView.addSubview(photoView)
contentView.addSubview(videoView)
关于ios - UICollectionView 出列错误的单元格并显示错误的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58666601/
我的Angular-Component位于一个flexbox(id =“log”)中。可以显示或隐藏flexbox。 我的组件内部有一个可滚动区域,用于显示日志消息。 (id =“message-li
我真的很困惑 有一个 phpinfo() 输出: MySQL 支持 启用 客户端 API 版本 5.5.40 MYSQL_MODULE_TYPE 外部 phpMyAdmin 显示: 服务器类型:Mar
我正在研究这个 fiddle : http://jsfiddle.net/cED6c/7/我想让按钮文本在单击时发生变化,我尝试使用以下代码: 但是,它不起作用。我应该如何实现这个?任何帮助都会很棒
我应该在“dogs_cats”中保存表“dogs”和“cats”各自的ID,当看到数据时显示狗和猫的名字。 我有这三个表: CREATE TABLE IF NOT EXISTS cats ( id
我有一个字符串返回到我的 View 之一,如下所示: $text = 'Lorem ipsum dolor ' 我正在尝试用 Blade 显示它: {{$text}} 但是,输出是原始字符串而不是渲染
我无法让我的链接(由图像表示,位于页面左侧)真正有效地显示一个 div(包含一个句子,位于中间)/单击链接时隐藏。 这是我的代码: Practice
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
最初我使用 Listview 来显示 oracle 结果,但是最近我不得不切换到 datagridview 来处理比 Listview 允许的更多的结果。然而,自从切换到数据网格后,我得到的结果越来越
我一直在尝试插入一个 Unicode 字符 ∇ 或 ▽,所以它显示在 Apache FOP 生成的 PDF 中。 这是我到目前为止所做的: 根据这个基本帮助 Apache XSL-FO Input,您
我正在使用 node v0.12.7 编写一个 nodeJS 应用程序。 我正在使用 pm2 v0.14.7 运行我的 nodejs 应用程序。 我的应用程序似乎有内存泄漏,因为它从我启动时的大约 1
好的,所以我有一些 jQuery 代码,如果从下拉菜单中选择了带有前缀 Blue 的项目,它会显示一个输入框。 代码: $(function() { $('#text1').hide();
当我试图检查 Chrome 中的 html 元素时,它显示的是 LESS 文件,而 Firefox 显示的是 CSS 文件。 (我正在使用 Bootstrap 框架) 如何在 Chrome 中查看 c
我是 Microsoft Bot Framework 的新手,我正在通过 youtube 视频 https://youtu.be/ynG6Muox81o 学习它并在 Ubuntu 上使用 python
我正在尝试转换从 mssql 生成的文件到 utf-8。当我打开他的输出 mssql在 Windows Server 2003 中使用 notepad++ 将文件识别为 UCS-2LE我使用 file
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在尝试执行单击以打开/关闭一个 div 的功能。 这是基本的,但是,点击只显示 div,当我点击“关闭”时,没有任何反应。 $(".inscricao-email").click(function
假设我有 2 张卡片,屏幕上一次显示一张。我有一个按钮可以用其他卡片替换当前卡片。现在假设卡 1 上有一些数据,卡 2 上有一些数据,我不想破坏它们每个上的数据,或者我不想再次重建它们中的任何一个。
我正在使用 Eloquent Javascript 学习 Javascript。 我在 Firefox 控制台上编写了以下代码,但它返回:“ReferenceError:show() 未定义”为什么?
我正在使用 Symfony2 开发一个 web 项目,我使用 Sonata Admin 作为管理面板,一切正常,但我想要做的是,在 Sonata Admin 的仪表板菜单上,我需要显示隐藏一些菜单取决
我试图显示一个div,具体取决于从下拉列表中选择的内容。例如,如果用户从列表中选择“现金”显示现金div或用户从列表中选择“检查”显示现金div 我整理了样本,但样本不完整,需要接线 http://j
我是一名优秀的程序员,十分优秀!