[英]SWIFT 2 - UICollectionView - slow scrolling
我在我的项目中设置了一个uicollectionview,它从JSON文件获取数据。 一切都很好,但是,滚动非常缓慢,并且当视图滚动即将到来的单元格时,一会儿会显示之前单元格的内容。
我试过使用dispatch_async
但它仍然非常缓慢且跳跃。
任何想法我在做什么错?
override func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
let videoCell = collectionView.dequeueReusableCellWithReuseIdentifier("VideoCell", forIndexPath: indexPath) as UICollectionViewCell
let communityViewController = storyboard?.instantiateViewControllerWithIdentifier("community_id")
videoCell.frame.size.width = (communityViewController?.view.frame.size.width)!
videoCell.center.x = (communityViewController?.view.center.x)!
videoCell.layer.borderColor = UIColor.lightGrayColor().CGColor
videoCell.layer.borderWidth = 2
let fileURL = NSURL(string:self.UserVideosInfo[indexPath.row][2])
let asset = AVAsset(URL: fileURL!)
let assetImgGenerate = AVAssetImageGenerator(asset: asset)
assetImgGenerate.appliesPreferredTrackTransform = true
let time = CMTimeMake(asset.duration.value / 3, asset.duration.timescale)
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)) {
//self.showIndicator()
let NameLabelString = self.UserVideosInfo[indexPath.row][0]
let CommentLabelString = self.UserVideosInfo[indexPath.row][1]
let DateLabelString = self.UserVideosInfo[indexPath.row][3]
let buttonPlayUserVideo = videoCell.viewWithTag(1) as! UIButton
let nameLabel = videoCell.viewWithTag(2) as! UILabel
let commentUserVideo = videoCell.viewWithTag(3) as! UILabel
let dateUserVideo = videoCell.viewWithTag(4) as! UILabel
let thumbUserVideo = videoCell.viewWithTag(5) as! UIImageView
let deleteUserVideo = videoCell.viewWithTag(6) as! UIButton
buttonPlayUserVideo.layer.setValue(indexPath.row, forKey: "indexPlayBtn")
deleteUserVideo.layer.setValue(indexPath.row, forKey: "indexDeleteBtn")
dispatch_async(dispatch_get_main_queue()) {
nameLabel.text = NameLabelString
commentUserVideo.text = CommentLabelString
dateUserVideo.text = DateLabelString
self.shadowText(nameLabel)
self.shadowText(commentUserVideo)
self.shadowText(dateUserVideo)
if let cgImage = try? assetImgGenerate.copyCGImageAtTime(time, actualTime: nil) {
thumbUserVideo.image = UIImage(CGImage: cgImage)
}
}
}
//THIS IS VERY IMPORTANT
videoCell.layer.shouldRasterize = true
videoCell.layer.rasterizationScale = UIScreen.mainScreen().scale
return videoCell
}
首先 -您正在使用全局队列中的UI对象,并且似乎没有任何目的。 禁止这样做-否则行为将不确定。
其次 ,最繁重的操作是创建在主队列上执行的缩略图。 考虑使用AVAssetImageGenerator
的方法
public func generateCGImagesAsynchronouslyForTimes(requestedTimes: [NSValue], completionHandler handler: AVAssetImageGeneratorCompletionHandler)
而不是您自己的异步。
第三 , viewWithTag
是非常繁重的操作,导致viewWithTag
subviews
枚举。 考虑在单元格中声明所需视图的属性。
UPD:要在单元格中声明属性,请创建具有适当属性的UICollectionViewCell
子类作为IBOutlets。 然后,在您的视图控制器viewDidLoad
实现中,调用
collecionView.registerClass(<YourCellSubclass>.dynamicType, forCellWithReuseIdentifier:"VideoCell")
或者,如果在情节提要中配置了收藏视图单元格,请指定单元格的类并将其子视图直接在Interface Builder中的单元格设置窗口中连接到类的出口。
第四 ,您的单元格被集合视图重用。 每当您的单元格超出可见区域时,它就会从集合视图中删除,并放入重用队列。 当您滚动回到单元格时,再次要求您的视图控制器提供一个单元格。 然后,您将为每个新出现的单元格再次获取视频的缩略图。 考虑通过collectionView的indexPath.item
索引将已提取的缩略图存储在某个数组中来进行indexPath.item
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.