UITextField в пользовательской ячейке таблицы.Показывать вид сборщика при нажатии на ячейку / текстовое поле - PullRequest
0 голосов
/ 16 мая 2018

У меня есть UITextField в пользовательской ячейке таблицы. когда пользователь нажимает на ячейку (или на UITextField), вместо клавиатуры должна отображаться панель выбора .... Я использую текстовые поля "inputview" и "accesoryview" для достижения этой цели.

хорошо. Поэтому, когда я выбираю ячейку, окно выбора отображается с его значениями выбора ... однако, когда я выбираю само текстовое поле (которое находится внутри ячейки), отображается окно выбора, но значения выбора не отображаются .. .i вижу только одну пустую ячейку в окне выбора.

какой подход я должен использовать, чтобы при нажатии пользователем текстового поля или ячейки происходила одна и та же вещь (т. Е. Представление выбора отображалось со значениями выбора). Сверху очевидно, что может быть причиной этой проблемы?

Поле UIText в TableViewCell. Показать UIPickerView

Я удалил весь беспорядок из своего кода и сохранил только часть, относящуюся к вопросу (надеюсь, я не опустил соответствующий код):

import UIKit

class EditProfileViewController: UIViewController, UITableViewDelegate,UITableViewDataSource, UIPickerViewDelegate, UIPickerViewDataSource, UITextFieldDelegate,UITextViewDelegate {
    let properties = ["Name","Birthday","Diet"]
    let diets:NSArray = ["Vegan","Plant-based","Vegetarian","Meat Eater"]
    var userEditProfileTable : UITableView!
    var reminderCells = (1...3).map{ _ in EditProfileTableViewCell()}
    var toolBar : UIToolbar!
    var i:Int!
    var myUIPicker = UIPickerView()
    var editorViewController: EditorViewController!
    var myValues: NSArray!



override func viewDidLoad() {
    super.viewDidLoad()

    view.backgroundColor = UIColor.blue

    let barHeight: CGFloat = UIApplication.shared.statusBarFrame.size.height
    let displayWidth: CGFloat = self.view.frame.width
    let displayHeight: CGFloat = self.view.frame.height
    userEditProfileTable = UITableView(frame: CGRect(x: 0, y: barHeight, width: displayWidth, height: displayHeight - barHeight))

    userEditProfileTable.delegate = self
    userEditProfileTable.dataSource = self
    userEditProfileTable.rowHeight = 40

    userEditProfileTable.register(EditProfileTableViewCell.self, forCellReuseIdentifier: "cellId")

    self.userEditProfileTable.reloadData()
    self.view.addSubview(userEditProfileTable)

}


func generalPicker(){
    myUIPicker.becomeFirstResponder()
    self.myUIPicker.delegate = self
    self.myUIPicker.dataSource = self
}

@objc func donePicker() {
    reminderCells[i].valueTextField.resignFirstResponder()

}


func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

    reminderCells[indexPath.item].valueTextField.becomeFirstResponder()
    i = indexPath.item
    print(properties[indexPath.item])
    switch properties[indexPath.item] {
    case "Name":
        print("jkehdfgjdhj")
    case "Birthday":
        print("jhkjhjh")
    case "Diet":
        myValues = diets
        generalPicker()
        print(properties[indexPath.item])
    default:
        print("Some other character")
    }
}

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    // retuen no of rows in sections
    return properties.count
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    // retuen your custom cells
    print(indexPath)
    let cell = tableView.dequeueReusableCell(withIdentifier: "cellId", for: indexPath) as! EditProfileTableViewCell
    cell.backgroundColor = UIColor.clear
    cell.property.text = properties[indexPath.item]
    cell.isUserInteractionEnabled = true
    cell.valueTextField.isUserInteractionEnabled = true
    cell.valueTextField.delegate = self

    toolBar = UIToolbar()
    toolBar.sizeToFit()

    switch properties[indexPath.item]{
        case "Birthday":
            print("bonita")
        case "Diet":
            let doneButton = UIBarButtonItem(title: "Done", style: UIBarButtonItemStyle.plain, target: self, action: #selector(donePicker))
            toolBar.setItems([doneButton], animated: false)
            cell.valueTextField.inputAccessoryView = toolBar
            cell.valueTextField.inputView = myUIPicker
        default:
            print("mamacita")
    }

    reminderCells[indexPath.item] = cell
    return cell
}

// data method to return the number of column shown in the picker.
func numberOfComponents(in pickerView: UIPickerView) -> Int {
    return 1
}

// data method to return the number of row shown in the picker.
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {

    print(myValues.count)
    return myValues.count
}

// delegate method to return the value shown in the picker
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
    print("mjkhjkhkj")
    print(myValues[row])
    return myValues[row] as? String
}

// delegate method called when the row was selected.
func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
    print("row: \(row)")
    print("value: \(myValues[row])")

    reminderCells[i].valueTextField.text = myValues[row] as? String
}

}

1 Ответ

0 голосов
/ 16 мая 2018

Вы устанавливаете источник данных для средства выбора в didSelect, вам нужно добавить его в текстовое поле, делегировать эту строку myValues ​​= diets

// UITextField Delegates
    func textFieldDidBeginEditing(_ textField: UITextField) {
         myValues = diets  // be addedd
         generalPicker()
    }
...