Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/swift/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Swift 如何从领域设置UIPickerView选定值?_Swift_Realm_Uipickerview_Uitoolbar - Fatal编程技术网

Swift 如何从领域设置UIPickerView选定值?

Swift 如何从领域设置UIPickerView选定值?,swift,realm,uipickerview,uitoolbar,Swift,Realm,Uipickerview,Uitoolbar,我已经设置了一个viewcontroller,其中有7个“问题”和7个“答案”。我创建了一个UIPickerView,允许用户在单击答案的UITextField时选择答案,并将其保存在realm中 但是,当用户已经选择了一个答案(例如:“Agree”)时,当我单击该答案的UITextField时,“Agree”不会显示为UIPickerView中的选定行 如何将UIPickerview的默认值或“selectedrow”设置为显示在UITextField中并保存在Realm中的答案 import

我已经设置了一个viewcontroller,其中有7个“问题”和7个“答案”。我创建了一个UIPickerView,允许用户在单击答案的UITextField时选择答案,并将其保存在realm中

但是,当用户已经选择了一个答案(例如:“Agree”)时,当我单击该答案的UITextField时,“Agree”不会显示为UIPickerView中的选定行

如何将UIPickerview的默认值或“selectedrow”设置为显示在UITextField中并保存在Realm中的答案

import UIKit
import RealmSwift

class QuestionViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        setupDelegateForPickerView()
        setupDelegatesForTextFields()
    }

    override func viewWillAppear(_ animated: Bool) {
        loadAnswers()
    }

    @IBOutlet weak var Question1TextField: UITextField!

    @IBOutlet weak var Question2TextField: UITextField!

    @IBOutlet weak var Question3TextField: UITextField!

    @IBOutlet weak var Question4TextField: UITextField!

    @IBOutlet weak var Question5TextField: UITextField!

    @IBOutlet weak var Question6TextField: UITextField!

    @IBOutlet weak var Question7TextField: UITextField!

    // Setting up a UIPickerview from the ToolbarPickerView class

    let realm = try! Realm()

    var answers: Results<Answer>?

    var answerArray = [UITextField]()

    func loadAnswers() {
        var answersGiven = realm.objects(Answer.self).filter("id = 1")
        for answer in answersGiven {
            Question1TextField.text = answer.Answer1
            Question2TextField.text = answer.Answer2
            Question3TextField.text = answer.Answer3
            Question4TextField.text = answer.Answer4
            Question5TextField.text = answer.Answer5
            Question6TextField.text = answer.Answer6
            Question7TextField.text = answer.Answer7
        }
    }

    let pickerView = ToolbarPickerView()

    let Menu = ["Strongly Disagree",
                "Disagree",
                "Neutral",
                "Agree",
                "Strongly Agree"]

    var selectedMenu : String?

    func setupDelegatesForTextFields() {
        //appending textfields in an array
        answerArray += [Question1TextField, Question2TextField, Question3TextField, Question4TextField, Question5TextField, Question6TextField, Question7TextField]
        //using the array to set up the delegates, inputview for pickerview and also the inputAccessoryView for the toolbar
        for answer in answerArray {
            answer.delegate = self
            answer.inputView = pickerView
            answer.inputAccessoryView = pickerView.toolbar
        }
    }

    func setupDelegateForPickerView() {
        pickerView.dataSource = self
        pickerView.delegate = self
        pickerView.toolbarDelegate = self
    }

    func setDefaultValue(item: String, inComponent: Int){
     if let indexPosition = Menu.firstIndex(of: item){
       pickerView.selectRow(indexPosition, inComponent: inComponent, animated: true)
     }
    }

        // Dismissing Keyboard on tapped
        override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
            self.view.endEditing(true)
        }
    }

extension QuestionViewController : UITextFieldDelegate {
    func textFieldDidBeginEditing(_ textField: UITextField) {
        self.pickerView.reloadAllComponents()
    }
}

extension QuestionViewController : UIPickerViewDelegate, UIPickerViewDataSource {
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        return self.Menu.count
    }

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

    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        return self.Menu[row]
    }


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

        let answer = Answer()
        answer.id = 1


        // Check if the textfield isFirstResponder.
        if Question1TextField.isFirstResponder {
            Question1TextField.text = self.Menu[row]
            answer.Answer1 = Question1TextField.text

            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer1": self.Menu[row]], update: .modified)
            }
        } else if Question2TextField.isFirstResponder {
            Question2TextField.text = self.Menu[row]
            answer.Answer2 = Question2TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer2": self.Menu[row]], update: .modified)
            }
        } else if Question3TextField.isFirstResponder {
            Question3TextField.text = self.Menu[row]
            answer.Answer3 = Question3TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer3": self.Menu[row]], update: .modified)
            }
        } else if Question4TextField.isFirstResponder {
            Question4TextField.text = self.Menu[row]
            answer.Answer4 = Question4TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer4": self.Menu[row]], update: .modified)
            }
        } else if Question5TextField.isFirstResponder {
            Question5TextField.text = self.Menu[row]
            answer.Answer5 = Question5TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer5": self.Menu[row]], update: .modified)
            }
        } else if Question6TextField.isFirstResponder {
            Question6TextField.text = self.Menu[row]
            answer.Answer6 = Question6TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer6": self.Menu[row]], update: .modified)
            }
        } else if Question7TextField.isFirstResponder {
            Question7TextField.text = self.Menu[row]
            answer.Answer7 = Question7TextField.text
            try! realm.write {
                realm.create(Answer.self, value: ["id": 1, "Answer7": self.Menu[row]], update: .modified)
            }
        } else {
        //log errors
        }
    }
}

extension QuestionViewController: ToolbarPickerViewDelegate {

    func didTapDone() {
      let row = self.pickerView.selectedRow(inComponent: 0)
      self.pickerView.selectRow(row, inComponent: 0, animated: false)
      selectedMenu = self.Menu[row]
        self.view.endEditing(true)
    }

    func didTapCancel() {
       self.view.endEditing(true)
    }
}

不知道你为什么把所有的代码都放在这里。在选择器视图中选择行与编写它一样简单
self.pickerView.selectRow(行,不完整:0,动画:false)
。不管您是否从领域获取数据。试着得到你需要的那一排。似乎您将选中的行设置为选中行,而这不起任何作用。试着看这一行,我想这就是你的问题所在:
let row=self.pickerView.selectedRow(不完整:0)
,它位于func didTapDone()中,只有当用户点击“完成”按钮时才会运行。我同意self.pickerView.selectRow(或可能的.selectedRow)很可能是显示域中保存的正确答案所需的函数。但是,当我单击UITextField查找以前已回答(并保存在Realm中)的答案时,如何确保在加载UIPickerView时该答案是默认选中的行?

import UIKit

protocol ToolbarPickerViewDelegate: class {
    func didTapDone()
    func didTapCancel()
}

class ToolbarPickerView: UIPickerView {

    public private(set) var toolbar: UIToolbar?
    public weak var toolbarDelegate: ToolbarPickerViewDelegate?

    override init(frame: CGRect) {
        super.init(frame: frame)
        self.commonInit()
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        self.commonInit()
    }

    private func commonInit() {
        let toolBar = UIToolbar()
        toolBar.sizeToFit()

        let doneButton = UIBarButtonItem(title: "Done", style: .plain, target: self, action: #selector(self.doneTapped))
        let spaceButton = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: nil, action: nil)
        let cancelButton = UIBarButtonItem(title: "Cancel", style: .plain, target: self, action: #selector(self.cancelTapped))

        toolBar.setItems([cancelButton, spaceButton, doneButton], animated: false)
        toolBar.isUserInteractionEnabled = true

        toolBar.backgroundColor = UIColor(red: 0/255.0, green: 142.0/255.0, blue: 44.0/255.0, alpha: 0.5)
                    toolBar.tintColor = UIColor(red: 0/255.0, green: 142.0/255.0, blue: 44.0/255.0, alpha: 0.5)
                    UIBarButtonItem.appearance().setTitleTextAttributes([NSAttributedString.Key.foregroundColor : UIColor(red: 0/255.0, green: 142.0/255.0, blue: 44.0/255.0, alpha: 1.0),
                    NSAttributedString.Key.font: UIFont(name: "Clinton", size: 14)], for: UIControl.State.normal)

        self.toolbar = toolBar
    }

    @objc func doneTapped() {
        self.toolbarDelegate?.didTapDone()
    }

    @objc func cancelTapped() {
        self.toolbarDelegate?.didTapCancel()
    }
}

extension String {
    // formatting text for currency textField
    func currencyFormatting() -> String {
        if let value = Double(self) {
            let formatter = NumberFormatter()
            formatter.numberStyle = .currency
            formatter.maximumFractionDigits = 0
            if let str = formatter.string(for: value) {
                return str
            }
        }
        return ""
    }
}