【发布时间】:2019-08-08 08:25:38
【问题描述】:
我在 iPad 模拟器上运行的 ios 程序中有 2 个 UIPickerViews。
它们各有一个组件。
我通过使用标签上的开关找到相关的选择器视图。需要通过添加或删除组件来更改两个单组件视图。
这在数据源中很容易
pickerData.append(textInput)
pickerData.sort()
pickerData.reloadAllComponents
和
pickerData.remove(at: lastDataSelected)
picker.reloadAllComponents()
其中 lastDataSelected 是行整数。
这适用于更改数据源,但在传输到 UIPickerViews 时不能完全更改。 UIPickerView 显示在我滚动视图之前不会更新。更准确地说,选择的项目是正确的,但文本标签没有更新。滚动后数据标签都正确显示。 我试图以编程方式从一端滚动到另一端,但这无济于事。
那么我怎样才能告诉程序在用户不滚动的情况下更新视图呢? picker.reloadInputViews() 没有帮助。
除此之外,项目(行)的数量不会改变以反映选择器数据的变化,因此在添加新项目时最后一个项目会从列表中消失。 那么第二个问题是如何让UIPickerView函数更新行数呢?
我无法找到任何动态更新的选择器视图示例,因此希望有人可以帮助或为我指明正确的方向。 剩下的代码我相信是相当标准的,但我显然在更新过程中遗漏了一些东西。
override func viewDidLoad() {
super.viewDidLoad()
flvPicker = UIPickerView()
flvPicker.delegate = self
flvPicker.dataSource = self
flvPicker.tag = 0
}
func numberOfComponents(in pickerView: UIPickerView) -> Int {
switch pickerView.tag {
case 0:
return 1
case 1:
etc...
}
}
var numberOfRowsInComponent = 0
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
switch pickerView.tag {
case 0:
return flvPickerData.count
case 1:
etc...
}
}
func pickerView(_
pickerView: UIPickerView,
titleForRow row: Int, forComponent component: Int) -> String? {
switch pickerView.tag {
case 0:
return flvPickerData[row]
case 1:
etc...
}
}
func pickerView( _ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
switch pickerView.tag {
case 0:
flavourSelected = flvPickerData[row]
lastFlavourSelected = row
case 1: etc...
}
}
我认为问题实际上是如何让 UIPickerView 在更改其数据源并因此更改行数后正确更新。
【问题讨论】:
标签: ios swift xcode ios-simulator