iOS中自定义弹出pickerView效果(DEMO)

2020-01-18 19:36:18于海丽

 UIPickerView平常用的地方好像也不是很多,顶多就是一些需要选择的地方,这次项目需要这一个功能,我就单独写了一个简单的demo,效果图如下:

新增主页面弹出view,在主页面添加的代码

有个小问题就是第四个直接添加在主页弹出来的view好像被导航栏给覆盖了,我还没去研究,就着急的先吧功能写了。大家谅解下

ios,pickerview

最初版本

ios,pickerview

    话说我终于弄了gif了,再也不要去截图每张图都发一遍了!!

    这个demo呢,等于是可以拿来直接用的第三方了吧,只需要传数据就可以了,弹出的三个框显示的数据也不一样,我的封装能力不行,所以都是单独写了,在这里呢,我先把链接发上,大家要是没有耐心的其实可以直接看demo,下载了,看下代码基本上就会了。YLSPicker。

    实现的基本思路呢,其实也挺简单的。我这里就说下我实现的过程,然后贴上代码片段,大家可以看一下。

第一步:主页面的设置

    这里其实也没啥好说的,页面上三个不能输入的三个文本框,然后点击会弹出东西来。


//宏定义
#define YLSRect(x, y, w, h) CGRectMake([UIScreen mainScreen].bounds.size.width * x, [UIScreen mainScreen].bounds.size.height * y, [UIScreen mainScreen].bounds.size.width * w, [UIScreen mainScreen].bounds.size.height * h)
@interface ViewController ()<UITextFieldDelegate>
//声明
/** text1 */
@property (nonatomic,strong) UITextField *text1;
/** text2 */
@property (nonatomic,strong) UITextField *text2;
/** text3 */
@property (nonatomic,strong) UITextField *text3;
@end
 - (void)viewDidLoad {
 [super viewDidLoad];
 self.title = @"Picker";
 //placeholder数组
 NSArray *placeholderArr = @[@"Picker OneVlaue",@"Picker TwoVlaue",@"Picker ThreeVlaue"];
 //循环添加文本框
 for (int i = 0; i < 3; i ++)
 {
  UITextField *text = [[UITextField alloc]initWithFrame:YLSRect(100/375, (140 + i * 60)/667, 175/375, 30/667)];
  text.borderStyle = UITextBorderStyleRoundedRect;
  text.backgroundColor = [UIColor lightGrayColor];
  text.tag = i + 1000;
  text.placeholder = placeholderArr[i];
  text.delegate = self;
  [self.view addSubview:text];
  if(text.tag == 1000)
  {
   self.text1 = text;
  }else if(text.tag == 1001)
  {
   self.text2 = text;
  }else
  {
   self.text3 = text;
  }
 } 
} 

    很多像我这样的新手,对textfiled的代理都不是很清楚,像我这个点击文本框不进行编辑,然后还能弹出自定义view的事件应该在哪里实现呢,答案就是在