- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了 Collection View 单元格内 imageView 的 isHighlighted
状态问题:我无法按照我的目标方式为两个图像之间的过渡设置动画。
我的 Collection View 的每个自定义单元格都有 3 个 View :
当我触摸单元格时,两个 ImageView 都会立即移动到突出显示状态,但我希望它们转换到此状态(一个简单的 CrossDissolve 转换)
我尝试了两种不同的方法:重写自定义单元类中的 isSelected
方法并将动画放入 collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
重写 isSelected 属性:
override var isSelected: Bool {
didSet {
UIView.transition(with: cellImageView, duration: 1, options: .transitionCrossDissolve, animations: {
self.cellImageView.setNeedsLayout()
self.cellImageView.layoutIfNeeded()
self.cellImageView.isHighlighted = self.isSelected
})
}
}
通过这种方式,当我单击模拟器中的单元格时,无论是在选择单元格还是在失去选定状态时,我都不会获得动画,除非我单击并按住 一个单元格:然后我得到前一个单元格丢失其选定单元格的动画(换句话说,我将前一个选定的 imageView 从 isHighlighted(true)
转换为 isHighlighted(false)
)。
didSelectItemAt indexPath方法
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
let cell = collectionView.cellForItem(at: indexPath) as! SubMenuCell
UIView.transition(with: cell, duration: 1.0, options: .transitionCrossDissolve, animations:
cell.setNeedsLayout()
cell.layoutIfNeeded()
cell.cellImageView.isHighlighted = cell.isSelected
})
}
此方法不会在单元格被选中时触发动画,但会在单元格从 isSelected(true)
移动到 isSelected(false)
时提供过渡动画:换句话说,我看到之前选定的单元格淡出,但没有看到选定的单元格淡入。
如果您能提供有关其为何不起作用以及如何修复的提示,我将不胜感激!
感谢大家花时间阅读和回复!最好的,
最佳答案
感谢大家花时间思考我的问题。通过进一步调查,我决定检查 3 个事件的发生方式和时间,即 cell.isHighlighted
、cell.isSelected
和 collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
在哪里触发,我实际上发现了一些非常有趣的东西。我总结一下:
当您触摸 Collection View 中的单元格 (cell1) 时,会发生以下事件:
cell1.isHightlighted
设置为 true
cell1.isHightlighted
设置为 false
cell1.isSelected
设置为 true
,这会回调 cell1.isHighlighted
属性collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath)
方法现在,当您触摸 Collection View 中的另一个单元格 (cell2) 时,会发生以下事件:
cell2.isHighlighted
设置为 true
cell1.isSelected
设置为 false
,这会回调 cell1.isHightlighted
属性cell2.isHighlighted
设置为 false
cell1.isSelected
再次设置为 false
(!)cell2.isSelected
设置为 true
,这会回调 cell2.isHighlighted
属性collectionView(_ collectionView:
UICollectionView, didSelectItemAt indexPath: IndexPath)
方法是 称为考虑到这一点,我得出的结论是,在 Collection View 方法中的 isHighlighted
状态上运行过渡动画永远不会按预期工作,因为该属性在到达方法。
我发现获得两种动画(isHighlighted
true
和 false
)的一种解决方案是对 的属性观察器进行操作我的自定义 Collection View 单元格的 >isHighlighted
和 isSelected
,如下所示:
override var isHighlighted: Bool {
willSet {
if newValue == true {
UIView.transition(with: cellImageView, duration: 1.0, options: .transitionCrossDissolve, animations: {
self.cellImageView.isHighlighted = newValue
})
}
}
}
override var isSelected: Bool {
willSet {
if newValue == false {
UIView.transition(with: cellImageView, duration: 1.0, options: .transitionCrossDissolve, animations: {
self.cellImageView.isHighlighted = newValue
})
}
}
}
我希望它能有所帮助,并再次感谢所有花了一些时间试图解决这个问题的人!如果有人找到更优雅的解决方案,请随时发布!最好的,
关于ios - Collection View 单元格内 imageView 的 Animate isHighlighted 状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53771635/
我想知道如何在我的 UIButton 周围设置边框,以便在单击或突出显示时更改不透明度及其中的文本。 我的逻辑告诉我,它应该是这样的......但它似乎不起作用: //BTN STYLING
我已经对 NSTextFieldCell (在 NSTableView 内部)进行了子类化,以在选择单元格(即行)时绘制自定义前景色(例如 isHighlighted 为 true)并且一切正常。 问
我已经对 UIButton 进行了子类化,并希望在按钮进入突出显示状态时仅调用一次委托(delegate)方法,并在按钮进入未突出显示状态时再次调用一次: override var isHighlig
我正在尝试观察对象 UIImageView 上的属性“isHighlighted”,但似乎我的代码不正确?有什么想法吗? imageView.rx .observe(Optional.self, "i
序言(在实际问题的代码之后向下翻页): 我有一个自定义的 UIButton 类,其中我用以下行为替换了普通的 UIButton isHighlighted 动画行为: 当用户的手指实际放在按钮上(即突
我在 UITableViewCell 中有图像,我使用“isHighlighted”字段来设置图像是否应为灰色或彩色。每当我选择单元格时,UITableViewCell 在所有 subview 上将
在 UIControl 中,如果我重写 isHighlighted 以设置私有(private) _isHighlighted 属性,然后检查控件的 state 看看它是否包含 .highlighte
我想将 ComboBoxItem.IsHighlighted 属性放入我的 ViewModel。我想我可以设置项目容器样式并基于该属性执行触发器,但后来我被卡住了。
如标题所示,我想知道 WPF 样式中的 IsMouseOver 和 IsHighlighted 属性触发器有什么区别。 有人知道吗? 最佳答案 IsHighlighted 会考虑任何输入设备(如键盘)
我正在尝试为我的 UIButton 创建 isHighlighted Observable,以便在每次 isHiglighted 为 UIButton 更改时发送序列。我写过这样的东西 extensi
我遇到了 Collection View 单元格内 imageView 的 isHighlighted 状态问题:我无法按照我的目标方式为两个图像之间的过渡设置动画。 我的 Collection Vi
我想在突出显示/选择时对自定义表格 View 单元格应用一些样式更改,因此我重写了 isHighlighted 和 isSelected 来实现此目的。它适用于我的自定义 Collection Vie
我是一名优秀的程序员,十分优秀!