繁体   English   中英

根据UIPickerView在If语句中选择的行更改标签

[英]Change Label According to UIPickerView's Selected Row in If Statement

我已经仔细搜索了多个页面和帖子,但不能完全满足我的需求。 我目前正在一个项目上,其中一个控制器具有多个文本字段,这些文本字段使用单个UIPickerView输出,有时标签需要根据用户的选择进行更改。

如何根据UIPickerView的选定行(尤其是在if语句中)更改标签?

我做了一个简单的测试代码和示例进行演示。

class TestViewController: UIViewController, UITextFieldDelegate {

@IBOutlet weak var categoryOutput: UITextField!
@IBOutlet weak var shapeOutput: UITextField!
@IBOutlet weak var lengthDiaOutput: UITextField!
@IBOutlet weak var heightOutput: UITextField!

@IBOutlet weak var dimensionLabel: UILabel!

let category = ["Perimeter", "Area"]
let shape = ["Rectangle", "Circle", "Triangle"]


// MARK: - viewDidLoad()

override func viewDidLoad() {
    super.viewDidLoad()

    createCategoryPicker()
    createShapePicker()
}


// MARK: - UIPickerViews

// Create a UIPickerView as an input text field for 'Category'.

func createCategoryPicker() {

    let categoryPicker = UIPickerView()
    categoryPicker.delegate = self
    categoryPicker.tag = 1

    categoryOutput.inputView = categoryPicker

    categoryPicker.backgroundColor  = UIColor(red: 238/255.0, green: 238/255.0, blue: 238/255.0, alpha: 1.0)
}

// Create a UIPickerView as an input text field for 'Shape'.

func createShapePicker() {
    let shapePicker = UIPickerView()
    shapePicker.delegate = self
    shapePicker.tag = 2

    shapeOutput.inputView = shapePicker

    shapePicker.backgroundColor = UIColor(red: 238/255.0, green: 238/255.0, blue: 238/255.0, alpha: 1.0) 
    }

}


// MARK: - Extensions

// Create a UIPickerView.

extension TestViewController: UIPickerViewDelegate, UIPickerViewDataSource {

// Set number of lists.

func numberOfComponents(in pickerView: UIPickerView) -> Int {

    return 1
}

// Set number of rows in list.

func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {

    if pickerView.tag == 1 {
        return category.count }
    if pickerView.tag == 2 {
        return shape.count }
    return 0
}

// Set content of list.

func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {

    if pickerView.tag == 1 {
        return category[row] }
    if pickerView.tag == 2 {
        return shape[row] }
    return nil
}

// Grab selection and change label.

func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {

    if pickerView.tag == 1 {
        categoryOutput.text = category[row] }
    if pickerView.tag == 2 {
        shapeOutput.text = shape[row]

        if component == 1 {
            dimensionLabel.text = "Diameter" }
        else {
            dimensionLabel.text = "Length" }
     }
}

// Set appearance of contents.

func pickerView(_ pickerView: UIPickerView, viewForRow row: Int, forComponent component: Int, reusing view: UIView?) -> UIView {

    var label: UILabel

    if let view = view as? UILabel {
        label = view } 
    else { label = UILabel() }

    if pickerView.tag == 1 {
        label.text = category[row] }
    if pickerView.tag == 2 {
        label.text = shape[row] }

    label.font = UIFont(name: "Avenir", size: 17)
    label.textColor = .black
    label.textAlignment = .center

    return label
    }
}

这是需要重点关注的部分。

func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {

    if pickerView.tag == 1 {
        categoryOutput.text = category[row] }
    if pickerView.tag == 2 {
        shapeOutput.text = shape[row]

        if component == 1 {
            dimensionLabel.text = "Diameter" }
        else {
            dimensionLabel.text = "Length" }
     }
}

在此处输入图片说明

选择时,文本标签Dimension不会更改为Diameter

func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {

    if pickerView.tag == 1 {
        categoryOutput.text = category[row] }
    if pickerView.tag == 2 {
        shapeOutput.text = shape[row]

        if row == 1 //Circle{
            dimensionLabel.text = "Diameter" }
        else {
            dimensionLabel.text = "Length" }
     }
}

您的两个选择器视图都只有一个组件,即组件0。

“ Circle”在第二行(第1行)中,因此您的if语句需要检查row == 1 ,而不是component == 1

暂无
暂无

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

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