简体   繁体   English

如何在 UIPicker 的两列之间添加标签?

[英]How would you add a label between two columns in a UIPicker?

I am trying to build the following picker.我正在尝试构建以下选择器。 How would one create the "to" label in between to the components of the picker?如何在选择器的组件之间创建“to”标签?

在此处输入图像描述

As commented by @Paulw11, here you have a demo implementation.正如@Paulw11 所评论的,这里有一个演示实现。

enum PickerComponents: CaseIterable {
    case timeFrom
    case to
    case timeTo
    
}

enum TimeFrom: String, CaseIterable {
    case now = "Now"
    case tenAM = "10:00AM"
    case quarterToTenAM = "10:15AM"
}

enum TimeTo: String, CaseIterable {
    case fiveThirtyPM = "5:30PM"
    case fiveFortyFive = "5:45PM"
    case sixPM = "6:00PM"
}

class ViewController: UIViewController {

    @IBOutlet weak var pickerView: UIPickerView!
    
    private let pickerComponents = PickerComponents.allCases
    
    override func viewDidLoad() {
        super.viewDidLoad()
        self.pickerView.delegate = self
        self.pickerView.dataSource = self
    }
}

extension ViewController: UIPickerViewDataSource, UIPickerViewDelegate {
    func numberOfComponents(in pickerView: UIPickerView) -> Int {
        return pickerComponents.count
    }
    
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        let component = pickerComponents[component]
        
        switch component {
        case .timeFrom:
            return TimeFrom.allCases.count
        case .to:
            return 1
        case .timeTo:
            return TimeTo.allCases.count
        }
    }
    
    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        let component = pickerComponents[component]
        
        switch component {
        case .timeFrom:
            return TimeFrom.allCases[row].rawValue
        case .to:
            return "to"
        case .timeTo:
            return TimeTo.allCases[row].rawValue
        }
    }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM