我正在尝试对 aUIPickerView
开始移动的事件做出反应(而不是在已经选择该行时)。
我搜索了整个委托方法,但没有任何帮助。我还尝试注册一个通知,但是当用户将手指放在组件上并开始滚动时,我找不到任何通知。
关于有什么替代方案的任何想法?
我正在尝试对 aUIPickerView
开始移动的事件做出反应(而不是在已经选择该行时)。
我搜索了整个委托方法,但没有任何帮助。我还尝试注册一个通知,但是当用户将手指放在组件上并开始滚动时,我找不到任何通知。
关于有什么替代方案的任何想法?
您可以创建一个自定义类UIPickerView
并覆盖hitTest(point:with:)
. 创建一个协议,您可以通过委托方法将当前选择器发送到您的控制器并绘制您喜欢的任何内容:
protocol CustomPickerViewDelegate: class {
func didTapped(_ picker: CustomPickerView)
}
class CustomPickerView: UIPickerView {
weak var myDelegate: CustomPickerViewDelegate?
override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
// Only test for points in your needed view
if !self.point(inside: point, with: event) {
return nil
}
// Return using CustomPickerViewDelegate the current picker
// that can be used to determine which one was selected
myDelegate?.didTapped(self)
// Call super.hitTest(_: with:)
return super.hitTest(point, with: event)
}
}
不要忘记(在您的控制器中:例如YourViewController
):
self.pickerView.myDelegate = self
.
创建订阅CustomPickerViewDelegate
协议的控制器的扩展:
extension YourViewController: CustomPickerViewDelegate {
func didTapped(_ picker: CustomPickerView) {
// do what you want here
self.addBorderTo(picker: picker)
}
}
如果您愿意,可以扩展UIPickerViewDelegate
(见下文如何扩展基类委托)
祝你好运 :]