- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 Udacity 上从事 VirtualTourist 项目,我们需要在通过 Flickr 客户端刷新图像时显示图像。目前我的实现是只有在图像完全下载后才会显示刷新。该项目要求图像在下载时显示为 ,并且在下载时显示事件指示器。
我的代码如下:
@IBAction func newCollectionButtonDidTap(_ sender: Any) {
print("FETCHING NEW COLLECTION...")
DispatchQueue.main.async {
self.photos.removeAll()
self.collectionView.reloadData()
print("Reload Data newColVC")
}
for items in fetchedResultsController.fetchedObjects! {
context.delete(items as! NSManagedObject)
}
loadPhotos()
}
func loadPhotos() {
newColActivityIndicator.startAnimating()
newColActivityIndicator.isHidden = false
newCollectionButton.isUserInteractionEnabled = false
newCollectionButton.alpha = 0.4
FlickrClient.sharedInstance.getPhotos(pin.coordinate.latitude as AnyObject, lon: pin.coordinate.longitude as AnyObject, { (results, error) in
if let error = error {
print(error)
} else {
if results != nil {
for result in results! {
let picture = Photo(pin: self.pin, imageData: result as NSData, context: self.context)
self.photos.append(picture)
}
do {
try self.delegate.stack?.saveContext()
} catch let error as NSError {
print("Error saving context in loadPhotos(): \(error.localizedDescription)")
}
DispatchQueue.main.async {
self.collectionView.reloadData()
self.newColActivityIndicator.stopAnimating()
self.newColActivityIndicator.isHidden = true
self.newCollectionButton.isUserInteractionEnabled = true
self.newCollectionButton.alpha = 1.0
print("Reload Data loadPhotos")
}
}
}
})
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath) as! ImageViewCell
cell.activityIndicator.startAnimating()
cell.activityIndicator.isHidden = false
let photo = photos[indexPath.row]
if let photoImage = photo.imageData {
print("PhotoImage present")
DispatchQueue.main.async {
cell.activityIndicator.stopAnimating()
cell.activityIndicator.isHidden = true
cell.imageView?.image = UIImage(data: photoImage as Data)
}
} else {
print("PhotosImage don have")
}
return cell
}
非常感谢这里的一些建议,谢谢!
最佳答案
因此,首先,当您点击 newCollectionButton
时,您将删除核心数据中存储的所有数据以及 Collection View 中显示的所有数据。所以此时, Collection View 没有任何内容可显示。因此它应该是空的,什么也不显示。
现在,我认为您的 loadPhotos
方法返回来自闪烁的照片集合,您将其添加到本地数组和 coredata 中。 Collection View 的数据源必须使用 photos
数组中的数据。
您删除事件指示器,然后重新加载 Collection View 。此时,您已经拥有了显示图像所需的数据。因此,cellForItemAt
从本地数组中检索数据,并创建图像并显示它。也许这个过程发生得如此之快,以至于您的 cell.activityIndicator.startAnimating()
和 cell.activityIndicator.stopAnimating()
执行得更快。
由于您的问题不清楚,并且您的 loadPhotos
获取照片数据集合,如果您希望在每个单元格中显示 ActivityIndicator,直到下载所有图像,您可以
Photo
对象中存在的图像数据loadPhotos
关于ios - 刷新图像时显示带有 ActivityIndicator 的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42093258/
我是一名优秀的程序员,十分优秀!