十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
IOS 開發(fā)之PickerView自定義視圖的實(shí)例詳解
成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、德安網(wǎng)絡(luò)推廣、重慶小程序開發(fā)公司、德安網(wǎng)絡(luò)營(yíng)銷、德安企業(yè)策劃、德安品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供德安建站搭建服務(wù),24小時(shí)服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
例如選擇國(guó)家,左邊是名稱右邊是國(guó)家,不應(yīng)該使用兩列,而是自定義PickerView的一列,可以通過xib來實(shí)現(xiàn)。
注意,雖然PickerView也是一列,但是數(shù)據(jù)源方法是@required,所以必須實(shí)現(xiàn)。
因此,核心思想就是一列,自定義PickerView的行視圖。
使用viewForRow方法可以設(shè)定行視圖。

這樣的視圖可以通過xib和它的控制器進(jìn)行封裝:

Xib的控制器繼承自UIView類即可。
控制器維護(hù)一個(gè)用于設(shè)置數(shù)據(jù)的模型對(duì)象flag,重寫flag的set方法,即可在傳入模型的時(shí)候設(shè)置Xib內(nèi)部控件的屬性。
返回Xib的方式:從mainBundle讀取xib,使用loadNibNamed...,注意返回的是數(shù)組,使用lastObject(一般數(shù)組里只有一個(gè)元素,因此lastObject也是第一個(gè))。
[[[NSBundle mainBundle] loadNibNamed:@"#xibName#" owner:nil options:nil] lastObject];
一個(gè)細(xì)節(jié):PickerView的viewForRow的view是可以循環(huán)利用的,注意viewForRow的方法傳入的是一個(gè)resusingView:
[[[NSBundle mainBundle] loadNibNamed:@"#xibName#" owner:nil options:nil] lastObject];
因此應(yīng)該對(duì)這個(gè)view進(jìn)行判斷(在Xib控制其中),如果不是nil,說明從緩存池中拿到了數(shù)據(jù),應(yīng)該強(qiáng)轉(zhuǎn)類型為FlagView然后返回,如果是nil,則返回一個(gè)新建的Xib(通過mainBundle的loadNibNamed創(chuàng)建,不要忘了返回的是一個(gè)元素的數(shù)組)。
因此應(yīng)該在FlagView中重寫一個(gè)初始化方法,用來得到一個(gè)可重用的view:
+ (instancetype)flagViewWithResuingView:(UIView *)resuingView
{
if (resuingView == nil) {
return [[[NSBundle mainBundle] loadNibNamed:@"FlagView" owner:nil options:nil] lastObject];
} else {
return (FlagView *)resuingView; //注意直接得到的可重用視圖是UIView類型,應(yīng)該轉(zhuǎn)換為FlagView才能接收模型。
}
}
另一個(gè)細(xì)節(jié):由于PickerView的行寬是由Xib決定的,因此應(yīng)該提供一個(gè)類方法來返回行高:
+ (CGFloat)flagViewHeight
{
return 44;
} 以上就是IOS 開發(fā)之PickerView自定義視圖的實(shí)例,如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!