Многочисленные ошибки UIPickerview

Я просто хочу сообщить вам, что версия Xcode, над которой я работаю, - это 7.1.1. Приступая к делу, у меня есть три варианта выбора, как показано на рисунке ниже. Главный сборщик, левый сборщик и правый сборщик.

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

Я пометил основной сборщик с 1, левый сборщик с 2 и правый сборщик с 3. Кроме того, все сборщики я связал их с "dataSource" & "делегат".

http://s12.postimg.org/fj72kg29p/main_View.png


Основная цель:

Я хочу, чтобы когда я выбирал имя, т.е. "Область" из основного средства выбора, его группа должна отображаться или отображаться в левом и правом средствах выбора и так далее.

Я сделал то, что сделал, но я получил следующую ошибку:

http://s1.postimg.org/523f3smwf/Screen_Shot_2015_11_27_at_12_39_20_AM.png

Вот мой код:

import UIKit

class ViewController: UIViewController, UIPickerViewDataSource, UIPickerViewDelegate, UITextFieldDelegate {

    @IBOutlet weak var mainPicker: UIPickerView!
    @IBOutlet weak var leftPicker: UIPickerView!
    @IBOutlet weak var rightPicker: UIPickerView!
    @IBOutlet weak var textFieldLeft: UITextField!
    @IBOutlet weak var textFielfRight: UITextField!
    @IBOutlet weak var equal: UILabel!

    //var mainPickerData = []
    var leftPickerData = []
    var rightPickerData = []

    var dataDict:NSMutableDictionary!
    var mainPickerData:NSArray!
    var leftRightPickerData:NSArray!

    //yourPicker.backgroundColor = UIColor(patternImage: UIImage(named: "back.jpg")!)


    override func viewDidLoad() {
        super.viewDidLoad()



        // Connect data:
        self.mainPicker.delegate = self
        self.mainPicker.dataSource = self

        self.leftPicker.delegate = self
        self.leftPicker.dataSource = self

        self.rightPicker.delegate = self
        self.rightPicker.dataSource = self

        let theWidth = view.frame.size.width
        let theHeight = view.frame.size.height

        mainPicker.center = CGPointMake(theWidth/2, theHeight/2 - 182.5)
        leftPicker.center = CGPointMake(theWidth/2 - 100, theHeight/2)
        rightPicker.center = CGPointMake(theWidth/2 + 100, theHeight/2)
        textFieldLeft.center = CGPointMake(theWidth/2 - 90, theHeight/2 + 110)
        textFielfRight.center = CGPointMake(theWidth/2 + 90, theHeight/2 + 110)
        equal.center = CGPointMake(theWidth/2, theHeight/2 + 110)



        let dataDict:NSMutableDictionary = ["Area":["Square Mile", "Square Yard", "Square Foot", "Square Inch", "Hectare", "Acre", "Square Kilometer", "Square Meter", "Square Centimeter", " Square Millimeter"]
            ,"Energy":["Btus", "Calories", "Ergs", "Foot-Pounds", "Joules", "Kilogram-Calories", "Kilogram-Meters", "Kilowatt-Hours", "Newton-Meters", "Watt-Hours"], "Length":["Mile", "Yard", "Foot", "Inch", "Kilometer", "Meter", "Centimeter", "Millimeter"], "Power": ["Btus/Minute", "Foot-Pounds/Min", "Foot-Pounds/Sec", "Horsepower", "Kilowatts", "Watts"], "Pressure": ["Pounds/Sqr Ft", "Pounds/Sqr In", "Atmospheres", "Bars", "In of Mercury", "Cm of Mercury", "Kilograms/Sqr Meter", "Pascals"], "Speed": ["Knots", "Miles/Hr", "Miles/Min", "Feet/Min", "Feet/Sec", "Kilometers/Hr", "Kilometer/Min", "Meters/Sec"], "Temperature": ["Celsius C˚", "Fahrenheit", "Kelvin"], "Time": ["Years", "Months", "Weeks", "Days", "Hours", "Minutes", "Seconds", "Millisconds", "Microseconds", " Nanoseconds"], "Volume": ["Cupic Feet","Cubic Meter", "Gallon (Imp)", "Gallon (US)", "Quart (US)", "Pint (US)", "Fluid Oz", "Cup", "Tablespoon", "Teaspoon", "Dram (US)", "Liter"], "Weight": ["Short Ton (US)","Long Ton (UK)", "Pound (U.S)", "Ounce (US)", "Stone", "Metric Ton", "Kilogram", "Gram"]]
        mainPickerData = dataDict.allKeys;
        leftRightPickerData = dataDict.objectForKey(mainPickerData.firstObject as! String) as! NSArray

        // Linking the textFields with the pickerViews.
        textFieldLeft.inputView = leftPicker;
        textFielfRight.inputView = rightPicker;


        }

    // The number of columns of data
    func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
        return 1
    }

    // The number of rows of data
    func pickerView(pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {

        switch (pickerView.tag) {

        case mainPicker.tag:

            return mainPickerData.count

        case leftPicker.tag,rightPicker.tag:

            let currentSelectedIndex = mainPicker.selectedRowInComponent(0)
            leftRightPickerData = (dataDict.objectForKey(mainPickerData[currentSelectedIndex] as! String) as! NSArray)

            return leftRightPickerData.count;

        default:
            break;
        }
        return 0;
    }

    // The data to return for the row and component (column) that's being passed in
    func pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {

        if leftPicker.tag == 1 {

            return leftPickerData[row] as? String

        }else {

            return rightPickerData[row] as? String

        }


    }

    // Catpure the picker view selection
    func pickerView(pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        // This method is triggered whenever the user makes a change to the picker selection.
        // The parameter named row and component represents what was selected.

        if(pickerView.tag == 1 ){

            let currentSelectedIndex = mainPicker.selectedRowInComponent(0)
            leftRightPickerData = (dataDict.objectForKey(mainPickerData[currentSelectedIndex] as! String) as! NSArray)

            leftPicker.reloadAllComponents();
            rightPicker.reloadAllComponents();
        }

    }

    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {

        self.view.endEditing(true)

    }

    func pickerView(pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {
        let titleData = mainPickerData[row]
        let myTitle = NSAttributedString(string: titleData as! String, attributes: [NSFontAttributeName:UIFont(name: "Georgia", size: 15.0)!,NSForegroundColorAttributeName:UIColor.blueColor()])
        return myTitle
    }



}

1 ответ

Решение

Также в вашем func pickerView(pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? правильно обрабатывать атрибутивный текст для всех сборщиков, иначе ваш код будет аварийно завершен. Вы просто должны определить attributedTitle за mainPicker, Сделайте это для других, как показано ниже. Внесите изменения в соответствии с вашими потребностями.

func pickerView(pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {

    let titleData : String?
    if(pickerView.tag == mainPicker.tag){
        titleData = mainPickerData[row] as? String;

    }
    else{

        let currentSelectedIndex = mainPicker.selectedRowInComponent(0)
        leftRightPickerData = (dataDict.objectForKey(mainPickerData[currentSelectedIndex] as! String) as! NSArray)

        titleData = leftRightPickerData[row] as? String;
    }

    let myTitle = NSAttributedString(string: titleData!, attributes: [NSFontAttributeName:UIFont(name: "Georgia", size: 15.0)!,NSForegroundColorAttributeName:UIColor.blueColor()])
    return myTitle;

}