Почему мои кнопки не позволяют отображать окно выбора?

Вот код, по которому я получил помощь ранее, я просто не могу точно сказать, чего не хватает для работы моего кода. Я настроил его так, чтобы была нажата кнопка, чтобы появилось окно выбора, а затем выбор появился на этикетке. Но когда я нажимаю на кнопки, окно выбора не появляется. Я думаю, из того, что я могу сказать, проблема в том, что я пропускаю соединение, которое вызовет одно, чтобы заставить другое появиться, мое окно выбора установлено скрытым, а также оно появляется поверх стека, когда оно должно появиться.

    import UIKit

class CalculatorViewController: UIViewController, UIPickerViewDataSource, UIPickerViewDelegate {

@IBOutlet weak var firstButton: UIButton!
@IBOutlet weak var secondButton: UIButton!
@IBOutlet weak var thirdButton: UIButton!
@IBOutlet weak var fourthButton: UIButton!
@IBOutlet weak var fifthButton: UIButton!
@IBOutlet weak var nextPageButton: UIButton!

@IBOutlet weak var firstTextField: UITextField!
@IBOutlet weak var secondTextField: UITextField!
@IBOutlet weak var thirdTextField: UITextField!
@IBOutlet weak var fourthTextField: UITextField!
@IBOutlet weak var fifthTextField: UITextField!

@IBOutlet weak var pickerView: UIPickerView!

var firstButtonDataSource = ["1", "2", "3", "4"];
var secondButtonDataSource = ["White", "Red", "Green", "Blue"];
var thirdButtonDataSource = ["Mike", "Steve", "Ben", "Peter"];
var fourthButtonDataSource = ["Large", "Medium", "Small", "Extra-small"];
var fithButtonDataSource = ["USA", "UK", "France", "Germany"];

var lastPressedButton: UIButton?

override func viewDidLoad() {
    super.viewDidLoad()

    firstButton.addTarget(self, action:#selector(buttonClicked(sender:)), for: .touchUpInside)
    secondButton.addTarget(self, action:#selector(buttonClicked(sender:)), for: .touchUpInside)
    thirdButton.addTarget(self, action:#selector(buttonClicked(sender:)), for: .touchUpInside)
    fourthButton.addTarget(self, action:#selector(buttonClicked(sender:)), for: .touchUpInside)
    fifthButton.addTarget(self, action:#selector(buttonClicked(sender:)), for: .touchUpInside)

    self.pickerView.dataSource = self;
    self.pickerView.delegate = self;
}

@objc func buttonClicked(sender:UIButton!) {

    lastPressedButton = sender

    if lastPressedButton == firstButton {
        firstTextField.inputView = pickerView
    } else if lastPressedButton == secondButton {
        secondTextField.inputView = pickerView
    } else if lastPressedButton == thirdButton {
        thirdTextField.inputView = pickerView
    } else if lastPressedButton == fourthButton {
        fourthTextField.inputView = pickerView
    } else if lastPressedButton == fifthButton {
        fifthTextField.inputView = pickerView
    }
}

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

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

    if lastPressedButton == firstButton {
        return firstButtonDataSource.count;
    } else if lastPressedButton == secondButton {
        return secondButtonDataSource.count;
    } else if lastPressedButton == thirdButton {
        return thirdButtonDataSource.count;
    } else if lastPressedButton == fourthButton {
        return fourthButtonDataSource.count;
    } else if lastPressedButton == fifthButton {
        return fithButtonDataSource.count;
    }

    return 0
}

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

    if lastPressedButton == firstButton {
        return firstButtonDataSource[row];
    } else if lastPressedButton == secondButton {
        return secondButtonDataSource[row];
    } else if lastPressedButton == thirdButton {
        return thirdButtonDataSource[row];
    } else if lastPressedButton == fourthButton {
        return fourthButtonDataSource[row];
    } else if lastPressedButton == fifthButton {
        return fithButtonDataSource[row];
    }

    return ""
}

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

    if lastPressedButton == firstButton {
        self.firstTextField.text = firstButtonDataSource[row]
    } else if lastPressedButton == secondButton {
        self.secondTextField.text = secondButtonDataSource[row]
    } else if lastPressedButton == thirdButton {
        self.thirdTextField.text = thirdButtonDataSource[row]
    } else if lastPressedButton == fourthButton {
        self.fourthTextField.text = fourthButtonDataSource[row]
    } else if lastPressedButton == fifthButton {
        self.fifthTextField.text = fithButtonDataSource[row]
    }
}
}

1 ответ

Решение

Похоже, вы никогда не устанавливаете правильное текстовое поле в качестве первого респондента.

Кстати, всего твоего if/else if/else if... конструкции были бы чище как операторы switch, или вы могли бы даже установить словари с кнопками в качестве ключа, а затем структуру, содержащую источник данных и представление выбора для этой кнопки:

struct ButtonData {
  let buttonDataSource: [String]
  let buttonTextField: UITextField
}

let buttonsDict = [
  firstButton: ButtonData(buttonDataSource: ["1", "2", "3", "4"],
    buttonTextField: firstTextField),
  secondButton: ButtonData(buttonDataSource: ["White", "Red", "Green", "Blue"],
    buttonTextField: secondTextField),
  thirdButton: ButtonData(buttonDataSource: ["Mike", "Steve", "Ben", "Peter"],
    buttonTextField: thirdTextField),
  fourthButton: ButtonData(buttonDataSource: ["Large", "Medium", "Small", "Extra-small"],
    buttonTextField: fourthTextField),
  fifthButton: ButtonData(buttonDataSource: ["USA", "UK", "France", "Germany"],
    buttonTextField: fifthTextField)
]

И тогда код, как ваше действие кнопки, может использовать словарь:

@objc func buttonClicked(sender:UIButton!) {

    lastPressedButton = sender

    guard let buttonStruct = buttonsDict[lastPressedButton] else { return }

    let textField = buttonsStruct.buttonTextField

    textField.inputView = pickerView

    //I think this the code you need to show the picker
    textField.becomeFirstResponder() 
}
Другие вопросы по тегам