首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何使用Done按钮创建两个UIPickerView

使用Done按钮创建两个UIPickerView的步骤如下:

  1. 创建两个UIPickerView对象,并设置其数据源和代理为当前视图控制器。
  2. 在视图控制器的界面中添加一个工具栏,用于放置Done按钮。
  3. 创建一个UIBarButtonItem对象,并将其样式设置为UIBarButtonItemStyleDone。
  4. 将UIBarButtonItem对象添加到工具栏中。
  5. 在点击Done按钮时,调用相应的方法来获取选中的UIPickerView的数值,并进行相应的处理。

下面是一个示例代码:

代码语言:txt
复制
import UIKit

class ViewController: UIViewController, UIPickerViewDataSource, UIPickerViewDelegate {
    
    let pickerView1 = UIPickerView()
    let pickerView2 = UIPickerView()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        pickerView1.dataSource = self
        pickerView1.delegate = self
        pickerView2.dataSource = self
        pickerView2.delegate = self
        
        let toolbar = UIToolbar(frame: CGRect(x: 0, y: 0, width: view.frame.size.width, height: 44))
        let doneButton = UIBarButtonItem(barButtonSystemItem: .done, target: self, action: #selector(doneButtonTapped))
        toolbar.setItems([doneButton], animated: true)
        
        let textField1 = UITextField(frame: CGRect(x: 0, y: 100, width: view.frame.size.width, height: 44))
        textField1.inputView = pickerView1
        textField1.inputAccessoryView = toolbar
        view.addSubview(textField1)
        
        let textField2 = UITextField(frame: CGRect(x: 0, y: 200, width: view.frame.size.width, height: 44))
        textField2.inputView = pickerView2
        textField2.inputAccessoryView = toolbar
        view.addSubview(textField2)
    }
    
    @objc func doneButtonTapped() {
        let selectedValue1 = pickerView1.selectedRow(inComponent: 0)
        let selectedValue2 = pickerView2.selectedRow(inComponent: 0)
        
        // 处理选中的数值
        print("PickerView 1: \(selectedValue1)")
        print("PickerView 2: \(selectedValue2)")
        
        // 其他处理逻辑...
        
        view.endEditing(true)
    }
    
    // UIPickerViewDataSource方法
    func numberOfComponents(in pickerView: UIPickerView) -> Int {
        return 1
    }
    
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        // 返回相应的行数
        return 10
    }
    
    // UIPickerViewDelegate方法
    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        // 返回每行的标题
        return "Row \(row)"
    }
}

这段代码创建了两个UIPickerView对象,并将其数据源和代理设置为当前视图控制器。在视图控制器的界面中添加了一个工具栏,并在工具栏中放置了一个Done按钮。当点击Done按钮时,会调用doneButtonTapped方法来获取选中的UIPickerView的数值,并进行相应的处理。

注意:这只是一个示例代码,实际使用时需要根据具体需求进行适当的修改和扩展。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

11分18秒

day18_IDEA的使用与多线程/14-尚硅谷-Java语言高级-创建过程中两个问题的说明

11分18秒

day18_IDEA的使用与多线程/14-尚硅谷-Java语言高级-创建过程中两个问题的说明

11分18秒

day18_IDEA的使用与多线程/14-尚硅谷-Java语言高级-创建过程中两个问题的说明

6分46秒

数据可视化BI报表(续):零基础快速创建BI数据报表之Hello World

7分33秒

058.error的链式输出

4分18秒

SOLIDWORKS培训课程之制作漫步机动画 SW让小区漫步机“渲”起来

34秒

PS使用教程:如何在Photoshop中合并可见图层?

6分27秒

083.slices库删除元素Delete

2分10秒

服务器被入侵攻击如何排查计划任务后门

8分40秒

10分钟学会一条命令轻松下载各大视频平台视频:yt-dlp的安装配置与使用

2分7秒

使用NineData管理和修改ClickHouse数据库

6分12秒

Newbeecoder.UI开源项目

领券