作者:Arthur Knopper湾戳,原文鏈接广料,原文日期:2017/04/05
譯者:Crystal Sun艾杏;校對(duì):walkingway;定稿:CMB
picker view 看起來像是自動(dòng)販?zhǔn)蹤C(jī)或者角子老虎機(jī)畅铭,用于展示一組或者多組數(shù)值勃蜘。用戶通過滾輪來選擇數(shù)值缭贡,選中的值處在同一行中。Xcode 里的 User Interface 提供了 picker view 控件谍失,展示可選的組件和行莹汤。組件就是滾輪,有很多行,每行都有固定的 index 值攒巍。本教程使用的是 Xcode 8.3 和 iOS 10.3。
創(chuàng)建工程
打開 Xcode荒勇,創(chuàng)建一個(gè) Single View Application柒莉。
Product Name 使用 IOS10PickerViewTutorial,填寫自己的 Organization Name 和 Organization Identifier沽翔,Language 一欄選擇 Swift兢孝,Devices 一欄選擇 iPhone。
設(shè)置 Storyboard
打開 Storyboard仅偎,添加一個(gè) Picker View跨蟹,然后選中,點(diǎn)擊右下角的 Auto Layout 的 Pin 按鈕窗轩,如下圖所示,選中上座咆、左痢艺、右三個(gè)方向,點(diǎn)擊 “Add 3 Constants”介陶。
點(diǎn)擊 Assistant Editor堤舒,確保 ViewController.swift 文件可見。使用 Control 拖拽法將 Picker View 和 ViewController 類創(chuàng)建下列 Outlet:
Storyboard 看起來應(yīng)如下圖所示:
寫代碼
打開 ViewController.swift 文件哺呜,Picker View 必須遵循 UIPickerViewDataSource 和 UIPickerViewDelegate 協(xié)議舌缤,在類的聲明里,將代碼改成如下所示:
class ViewController: UIViewController, UIPickerViewDelegate, UIPickerViewDataSource {
將 viewDidLoad 方法改成如下所示:
override func viewDidLoad() {
super.viewDidLoad()
pickerView.delegate = self
pickerView.dataSource = self
}
還需要給 Picker View 提供數(shù)值某残,在 ViewController 類中添加下列數(shù)組:
let colors = ["Red","Yellow","Green","Blue"]
colors 數(shù)組就是 Picker View 的數(shù)據(jù)源(data source)国撵,UIPickerViewDataSource 協(xié)議需要特定的方法來定義 picker 的組件和行數(shù)。實(shí)現(xiàn)下列方法:
func numberOfComponents(in pickerView: UIPickerView) -> Int {
return 1
}
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
return colors.count
}
我們定義了 picker 的行數(shù)等于數(shù)組的元素?cái)?shù)量驾锰。接下來卸留,將數(shù)組對(duì)應(yīng)的元素內(nèi)容賦值給對(duì)應(yīng)的行:
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
return colors[row]
}
運(yùn)行工程
運(yùn)行工程,現(xiàn)在可以在 Picker View 里選擇不同的顏色了椭豫。
可以從 github 上下載 IOS10PickerViewTutorial 教程的源碼耻瑟。
本文由 SwiftGG 翻譯組翻譯,已經(jīng)獲得作者翻譯授權(quán)赏酥,最新文章請(qǐng)?jiān)L問 http://swift.gg喳整。