欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

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时,调用该方法刷新。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。