iOS UIPickerView的简单封装示例
程序员文章站
2023-12-01 21:30:10
前言
在ios实际项目中,经常会出现界面中多个地方需要使用uipickerview,如果在每个需要用到的地方都创建一个uipickerview不仅更耗性能,而且还会让你的...
前言
在ios实际项目中,经常会出现界面中多个地方需要使用uipickerview,如果在每个需要用到的地方都创建一个uipickerview不仅更耗性能,而且还会让你的代码变得更加杂乱、冗余,因此我在这里向大家介绍一下我对uipickerview的一些简单封装。
所需属性
/** pickerview*/ @property (nonatomic, strong) uipickerview pickerview; /* pickerview背景*/ @property (nonatomic, strong) uiview pickerbackgroundview; /* 背景*/ @property (nonatomic, strong) uiview backgroundview; /* 确认按钮*/ @property (nonatomic, strong) uibutton surebutton; /* 取消按钮*/ @property (nonatomic, strong) uibutton cancelbutton; /* 单列pickerview*/ @property (nonatomic, strong) nsmutablearray sldataarray; /* 双列pickerview*/ @property (nonatomic, strong) nsmutablearray *muldataarray;
如果只需要一列的话,只需要传入一个数据数组:sldataarray,如果需要两行,则两个数组都需要赋值。
实现uipickerview代理方法
-(nsinteger)numberofcomponentsinpickerview:(uipickerview *)pickerview{ if (self.muldataarray.count == 0) { return 1; }else { return 2; } } -(nsinteger)pickerview:(uipickerview *)pickerview numberofrowsincomponent:(nsinteger)component{ if (component == 0) { return self.sldataarray.count; }else { return self.muldataarray.count; } } -(nsstring *)pickerview:(uipickerview *)pickerview titleforrow:(nsinteger)row forcomponent:(nsinteger)component{ if (component == 0) { return self.sldataarray[row]; }else { return self.muldataarray[row]; } }
这里根据两个数组来初始化pickerview的内容,即判断第二个数组(muldataarray)是否有数据,有数据的话代表加载两列的pickerview,否则加载一列。
功能实现
-(void)pickerviewselectrow:(nsinteger)row { self.selectrow = row; [self.pickerview selectrow:row incomponent:0 animated:no]; } -(void)pickerviewselectrow:(nsinteger)row lastrow:(nsinteger)lastrow{ [self.pickerview selectrow:row incomponent:0 animated:no]; [self.pickerview selectrow:lastrow incomponent:1 animated:no]; }
第一个方法是只有一列的pickerview初始化是让其选中哪行,第二个则是两列的选择方法。
-(void)showorhidepickerview:(bool)isshow{ if (isshow) { if (self.ispickershow == no) { [self addsubview:self.backgroundview]; [self addsubview:self.pickerbackgroundview]; [uiview animatewithduration:0.3 animations:^{ self.backgroundview.alpha = 0.5; self.pickerbackgroundview.frame = cgrectmake(0, screen_height -220, screen_width, 220); } completion:^(bool finished) { self.ispickershow = yes; }]; } }else { if (self.ispickershow) { [uiview animatewithduration:0.3 animations:^{ self.backgroundview.alpha = 0.0; self.pickerbackgroundview.frame = cgrectmake(0, screen_height, screen_width, 220); } completion:^(bool finished) { [self.backgroundview removefromsuperview]; [self.pickerbackgroundview removefromsuperview]; self.ispickershow = no; }]; } } }
这个方法是显示或者隐藏pickerview,通过动画的方式,背景慢慢变黑或者透明,pickerview从下往上出现或者从上往下消失。
-(void)pickerviewreloaddata{ [self.pickerview reloadallcomponents]; }
刷新pickerview数据,加载另一个pickerview时,调用该方法刷新。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。