我正在实现一个非常基本的刷新控件...
var refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: Selector(("refresh:")), for: UIControlEvents.valueChanged)
refreshControl.backgroundColor = UIColor.red
self.tableView.addSubview(refreshControl)
出于某种原因,尽管每当我下拉刷新时,刷新控件似乎无法跟上表格 View ,并且两者之间存在白色间隙。
这是模拟器上的问题...我相信在 iPhone 上更糟
最佳答案
虽然我也建议您按照 Artem 发布的内容进行操作,但它并没有直接为我消除差距。原来我遇到了 2 个与 UIRefreshControl
相关的不同问题,并找到了一些“hacks”来绕过它们。简单的解决方法是将 tableView 的背景颜色设置为与刷新控件相同的颜色,但这样做的副作用是在 table view 的底部看到相同的颜色。
我的设置是一个 UINavigationController
托管一个 UIViewController
,一个 UITableView
subview 和一个 UISearchBar
设置为tableView 的 tableHeaderView。我的目标是匹配导航栏、刷新控件和搜索栏的颜色。
问题 1
我认为这与您遇到的问题相同。似乎只要您拖动以启动拉动以刷新操作,在手势的前几个点就会出现间隙。在某个阈值之后,刷新控件变为正确的颜色。不过,在返回 TableView 的静止滚动状态的途中,我们再次看到相同的间隙,就在它到达内容偏移量 0 之前。这是它的样子:
解决方案一
如果您将 UIRefreshControl
子类化并覆盖 frame
和 isHidden
属性,并在设置它们时打印出它们的值,您会注意到直到与 TableView 顶部的距离为 4pt 时,刷新控件才真正取消隐藏。同样,当您向下滚动时,您还会看到它被设置为隐藏在同一位置周围,这是在您无法再看到刷新控件之前以及为什么我们看到缝隙偷看 tableView 背景之前。
在我们的子类中,我们可以通过覆盖 isHidden
的 setter 和 getter 以及 frame 的
仅在刷新控件的偏移量实际为 0 时隐藏。didSet
来防止这种“提前”隐藏和“延迟”取消隐藏
class RefreshControl: UIRefreshControl {
override var isHidden: Bool {
get {
return super.isHidden
}
set(hiding) {
if hiding {
guard frame.origin.y >= 0 else { return }
super.isHidden = hiding
} else {
guard frame.origin.y < 0 else { return }
super.isHidden = hiding
}
}
}
override var frame: CGRect {
didSet {
if frame.origin.y < 0 {
isHidden = false
} else {
isHidden = true
}
}
}
}
我称之为 hack,因为我不太喜欢修改 UIRefreshControl 的现有行为,但我还没有找到更好的方法来解决这个问题。
第 2 期
在问题 1 中拉动刷新超过该间隙阈值时,UIRefreshControl 的框架似乎跟不上搜索栏。这给了我们另一种跟随搜索栏的差距。这是它的样子:
解决方案2
这个滞后的差距看起来像帧没有像我们滚动一样快地更新甚至动画。事实证明,如果我们在类似 layoutSubviews
的地方将框架设置为自身,我们会得到以下行为:
override func layoutSubviews() {
super.layoutSubviews()
var originalFrame = frame
frame = originalFrame
}
同样,这很老套,但我也没有找到解决这个问题的不同方法。
结果
关于ios - 拉动时 UIRefreshControl 下面的白线.. tableView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41331691/