UIPickerView

UIPickerView基本使用

  • 控件PickerView,拖线

  • 设置数据源,设置代理

    • self.pickView.dataSource = self
    • self.pickView.delegate = self
  • 遵守协议

    • UIPickerViewDataSource
    • UIPickerViewDelegate
  • 实现数据源方法

    • 共有多少列:numberOfComponentsInPickerView:
    • 每一列有多少行:numberOfRowsInComponents:
  • 实现代理方法

    • widthForComponents:每一列的宽度
    • rowHeightForComponents:每一行的行高
    • titleForRow:forComponent:每一列的每一行展示什么标题
    • pickerView:attributeedTitleForRow:forComponent:每一列的每一行展示带有属性的标题(属性:文字的大小颜色)
    • pickerView:viewForRow:forComponent:reusingView:每一列的每一行展示视图
    • pickerView:didSelectedRow:inComponent:当选中某一列的某一行的时候会自动调用
  • 展示数据

    • 定义数据的数组属性,懒加载
    • 获取plist路径
    • 从路径当中加载数组
  • Label展示选中的数据

    • didSelectedRow:InComponent:
    • 设置默认

自定义键盘

  • 搭建界面

  • textField,只能选择,不能输入(拦截用户输入)

    • 拦截文本框,设置textField代理
    • 设置代理,self.countryTextF.delegate = self
    • 遵守协议<UITextFieldDelegate>
    • 实现代理方法
      • textFieldShouldBeginEditing:是否允许开始编辑 YES
      • textFieldDidBeginEditing:开始编辑的时候调用,成为第一响应者弹出键盘
      • textFieldShouldEndEditing:是否允许结束编辑,如果设置为NO,就出不来了,所以要设置为YES
      • textFieldDidEndEditing:当结束编辑的时候调用
      • textField:shouldChangeCharactersInRange:replacementString:是否允许改变字符,NO
  • 点击textField弹出自定义的键盘

    • show in finder -> 新建文件夹 -> 把文件夹拖到工程里面 ->创建自定义类
    • 从storyboard或者xib绑定类的,加载完毕后,都会调用awakeFromNib方法
    • 修改键盘类型self.inputView输入的视图,默认是系统的键盘
    • 创建pickerView:alloc/init
    • 设置pickView的数据源和代理,遵守协议
    • 实现pickerView代理方法
    • self.inputView = pickerView
  • 通过代码,弹出pickerView,封装的思想

    • 重写initWithFrame:方法
    • 设置pickView的数据源和代理,遵守协议
    • 实现pickerView代理方法
    • self.inputView = pickerView
  • 注意:在同一个类中,把相同的代码,写到同一个方法当中,减少代码量,高内聚

  • pickerView内部展示国旗数据

    • 创建模型,加载plist文件,字典转模型
    • 验证数据是否加载成功
    • 列数:1
    • 行数:self.flagArray.count;
    • 每一行展示的UIView:pickerView:viewForRow:forComponent:reusingView:
      • xib描述view
        • 绑定view的类
      • 创建flagView
        • loadNibName:owner:options:
        • [0]
    • 取出数据,把数据给view,让view展示数据
      • 取出模型
      • flagV中提供一个模型
      • return flagView;
  • 设置行高

    • pickerView:rowHeightForComponent:
  • KVC的底层实现

    • 拿字符串与当前类的属性进行匹配,如果匹配到,就给该属性赋值。
    • setValuesForKeyWithDictionary:
    • 遍历字典[dict enumerateKeysAndObjectsUsingBlock:^(){
      内部调用setValue:obj ForKeyPath:key
      1.去找有没有跟key值相同名称的set方法,就会调用set方法,把obj传入
      2.如果没有set方法,那么它会去找有没有相同名称并且带有下划线的成员属性,如果有就会给该属性赋值
      3.如果也没有带有下划线的成员属性,有没有跟它相同名称的成员属性
      4.如果还没有跟它相同名称的成员属性,就会调用setValueForUndefinedKey:
      5.如果没有实现setValueForUndefinedKey:就直接报错

    }]

  • KVO的底层实现

    • 耗性能,少用KVO
    • 原理:监听某个属性值的改变
    • 在运行的过程中派生一个类,在这个类中,有一个属性,就是你要监听的属性,会在属性里重写set方法,在set方法内部,调用obsever的方法
  • 代码优化

    • 不要在view里面进行逻辑运算,把运算写到模型里面,赋值的时候,直接赋值,比如icon赋值
    • 重写icon的set方法
- (void)setIcon:(UIImage *)icon{ 
    if ([icon isKindOfClass:[NSSting class]]){
    UIImage *image = [UIImage imageNamed:(NSString*)icon];
    _icon = image;
    }else{
    _icon = icon;
    }
}       
  • 滚动过程中,把国家显示到文本框中
    • 代理didSelectRow:
    • 取出当前模型
    • self.text = item.name;

UIDatePicker

  • 生日键盘
  • 自定义键盘
    • awakeFromNib
    • ininWithFrame:
    • 修改键盘类型
      • UIDatePicker
      • 修改日期模式
      • .datePickerMode = ModeDate
      • 修改地区
      • .locale = [NSLocale localeWithLocalIdentifier:@"zh"]
      • iso编码
  • 滚动过程当中,把日期显示到文本框中去
    • UIDatePicker没有代理
    • target:继承UIControl
    • pickView addTarget:action:forControlEvent:
    • 事件类型:可以通过拖线的方式,看event有哪些
      • 获取当前datepick的日期
      • NSDate * currentDate = datepick.date
      • 把日期转成字符串
      • NSDateFormatter alloc/init
      • .dateFormat= @"yyyy-MM-dd"
      • stringFromDate:
      • 给当前文本框赋值
      • self.text = dateString

城市键盘

  • 自定义textField
    • awakeFromNib
    • initWithFrame:
    • 设置代理
    • 遵守协议
    • 实现代理方法
  • 展示数据
    • 创建模型
    • 懒加载
    • 字典转模型
  • 数据源代理方法
    • 两列

    • 第0列有多少行

      • self.proviceArray.count
    • 第1列有多少行

      • 定义一个属性,记录当前选中的是哪个省份
      • 取出模型self.proviceArray[self.provinceIndex]
      • 当前选中省份下,城市的个数
        • provinceItem.cities.count;
    • 每一列每一行展示什么内容

      • 第0列:返回省份的名称
      • 省模型:self.provinceArray[row]
      • return item.name
      • 第1列:选中省份下城市的名称
      • self.provinceArray[self.provinceIndex]
      • return provinceItem.cities[row];
  • 滚动省份,变化城市名称
    • didSelectRow:
    • 滚动第0列开始做处理
    • 更新index
    • self.provinceIndex = row
    • 变数据,刷新列表(重新调用数据源代理方法)
    • reloadAllComponents
    • 当滚动完毕之后,让第一列选中第0行
    • selectRow:inComponent:animated:
  • 省份的名称和城市的名称显示到textF中
    • 省份的模型self.provinceArray[self.provinceIndex]
    • provinceItem.name;
    • 获取当前选中省份下,当前选中的城市
      • 获取当前第一列选中的是哪一行
      • 获取第一列行号
      • rowIndex = selectedRowInComponent:1
      • provinceItem.cities[rowIndex]
    • 拼接
    • stingWithFormat:%@-%@
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容