我在试着做一个定制的日期选择器。我对UIPickerView进行了子类化,并在init(coder:)和init(frame:)中使其成为UIPickerViewDataSource和UIPickerViewDelegate
class XKPickerView: UIPickerView, UIPickerViewDataSource, UIPickerViewDelegate {
override init(frame: CGRect) {
super.init(frame: frame)
self.dataSource = self
self.delegate = self
}
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)!
self.dataSource = self
self.delegate = self
}
(...)
}但是在视图加载时没有调用委托函数pickerView(titleForRow:)。我想,我在init()上遗漏了一些东西,但是什么?
Add:我正在使用故事板来构造视图。
Add 2:pickerView代码还有很多虚拟代码,但是即使是简单的return "abc"也不起作用,因为函数本身没有被调用(使用print()和调试器进行双重检查)。
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int,
forComponent component: Int) -> String? {
switch component {
case 0: // day label
return String(row + 1)
case 1: // month label (localized)
return "0"
case 2: // century label
return "0"
case 3: // year of the century label
return String(row + 1)
case 4: // era label (localized)
return "0"
default:
return nil
}
}发布于 2017-03-15 19:14:09
不知道你的尝试是怎么回事,但我只是这么做的,而且没有问题.
class MyPickerView: UIPickerView, UIPickerViewDataSource, UIPickerViewDelegate {
override init(frame: CGRect) {
super.init(frame: frame)
self.dataSource = self
self.delegate = self
}
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)!
self.dataSource = self
self.delegate = self
}
func numberOfComponents(in pickerView: UIPickerView) -> Int {
return 1
}
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
return 3
}
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
return "Row \(row)"
}
}全班都是这样。
发布于 2017-03-15 19:21:04
谢谢大家的回答!我丢失了,我在相应的视图控制器的ViewDidLoad()中添加了一个ViewDidLoad。(多么丢人:)
https://stackoverflow.com/questions/42817764
复制相似问题