如果您想从 Interface Builder 中执行此操作,则可以在 StoryBoard 中添加 UIPickerView 并最初隐藏该 UIPickerView 并在您点击按钮时显示它。
如果你想通过编码来做到这一点,那么你可以试试这个。
将此定义为全局。
var toolBar = UIToolbar()
var picker = UIPickerView()
在您的按钮点击操作中添加以下代码。我在工具栏中添加了Done 按钮来关闭选择器。
注意:如果您不想这样做,我会在按钮操作中编写整个代码,只需在 viewDidLoad 中编写所有代码并在您的按钮操作 self.view.addSubview(picker) 和 @ 中仅编写这些行987654327@
@IBAction func YOUR_BUTTON__TAP_ACTION(_ sender: UIButton) {
picker = UIPickerView.init()
picker.delegate = self
picker.dataSource = self
picker.backgroundColor = UIColor.white
picker.setValue(UIColor.black, forKey: "textColor")
picker.autoresizingMask = .flexibleWidth
picker.contentMode = .center
picker.frame = CGRect.init(x: 0.0, y: UIScreen.main.bounds.size.height - 300, width: UIScreen.main.bounds.size.width, height: 300)
self.view.addSubview(picker)
toolBar = UIToolbar.init(frame: CGRect.init(x: 0.0, y: UIScreen.main.bounds.size.height - 300, width: UIScreen.main.bounds.size.width, height: 50))
toolBar.barStyle = .blackTranslucent
toolBar.items = [UIBarButtonItem.init(title: "Done", style: .done, target: self, action: #selector(onDoneButtonTapped))]
self.view.addSubview(toolBar)
}
在完成按钮上,您可以删除 toolBar 以及 PickerView。
@objc func onDoneButtonTapped() {
toolBar.removeFromSuperview()
picker.removeFromSuperview()
}
UIPickerView的委托方法
func numberOfComponents(in pickerView: UIPickerView) -> Int {
return 1
}
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
return YOUR_DATA_ARRAY.COUNT
}
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
return YOUR_DATA_ARRAY[row]
}
func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
print(YOUR_DATA_ARRAY[row])
}