Picker View 教程

原文鏈接
作者:Arthur Knopper
原文日期:2017/04/05
譯者:Crystal Sun

picker view 看起來(lái)像是自動(dòng)販?zhǔn)蹤C(jī)或者角子老虎機(jī),用于展示一組或者多組數(shù)值。用戶(hù)滾動(dòng)輪子來(lái)選擇數(shù)值,選中的值處在同一行中。Xcode 里的 User Interface 提供了 picker view 控件,展示可選的組件和行。組件就是滾輪,有很多行,每行都有固定的 index 值。本教程使用的是 Xcode 8.3 和 iOS 10.3。

創(chuàng)建工程

打開(kāi) Xcode,創(chuàng)建一個(gè) Single View Application。

Product Name 使用 IOS10PickerViewTutorial,填寫(xiě)自己的 Organization Name 和 Organization Identifier,Language 一欄選擇 Swift,Devices 一欄選擇 iPhone。

設(shè)置 Storyboard

打開(kāi) Storyboard,添加一個(gè) Picker View,然后選中,點(diǎn)擊右下角的 Auto Layout 的 Pin 按鈕,如下圖所示,選中上、左、右三個(gè)方向,點(diǎn)擊 “Add 3 Constants”。

點(diǎn)擊 Assistant Editor,確保 ViewController.swift 文件可見(jiàn)。使用 Control 拖拽法將 Picker View 和 ViewController 類(lèi)創(chuàng)建下列 Outlet:

Storyboard 看起來(lái)應(yīng)如下圖所示:

寫(xiě)代碼

打開(kāi) ViewController.swift 文件,Picker View 必須遵循 UIPickerViewDataSource 和 UIPickerViewDelegate 協(xié)議,在類(lèi)的聲明里,將代碼改成如下所示:

class ViewController: UIViewController, UIPickerViewDelegate, UIPickerViewDataSource {

viewDidLoad 方法改成如下所示:

override func viewDidLoad() {
    super.viewDidLoad()
        
    pickerView.delegate = self
    pickerView.dataSource = self
}

還需要給 Picker View 提供數(shù)值,在 ViewController 類(lèi)中添加下列數(shù)組:

let colors = ["Red","Yellow","Green","Blue"]

colors 數(shù)組就是 Picker View 的數(shù)據(jù)源(data source),UIPickerViewDataSource 協(xié)議需要特定的方法來(lái)定義 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ù)量。接下來(lái),將數(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)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 作者:Arthur Knopper,原文鏈接,原文日期:2017/04/05譯者:Crystal Sun;校對(duì):w...
    梁杰_numbbbbb閱讀 909評(píng)論 0 0
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,083評(píng)論 4 61
  • 時(shí)光荏苒,歲月如風(fēng),一晃眼已是三年容貌老去,已由少女變?yōu)槿藡D。 回頭想想,少年時(shí)期的自己,那么脆弱軟弱,又那么溫暖...
    萌寶小指勾丶拉拉手閱讀 348評(píng)論 0 0
  • 2017年5月8月 唐駿媽媽?zhuān)镨麽? 今天下午的展能課由唐駿媽媽和田梓岑爸爸給小朋友們帶來(lái)了手工筆筒,考驗(yàn)小...
    芭蕾兔寶貝閱讀 2,292評(píng)論 0 0
  • 新興市場(chǎng)債券市場(chǎng)收到經(jīng)濟(jì)走軟和匯率貶值沖擊,收益率走高。相比之前,新興市場(chǎng)更多發(fā)行國(guó)內(nèi)債,風(fēng)險(xiǎn)相對(duì)更小。(華爾街日...
    海明威閱讀 167評(píng)論 0 1

友情鏈接更多精彩內(nèi)容