iOS开发UI篇—使用picker View控件完成一个简单的选餐应用

一、实现效果

  说明:点击随机按钮,能够自动选取,下方数据自动刷新。

  

二、实现思路

1.picker view的有默认高度为162,不可修改。

2.显示数据,需要设置数据源,也有两种方式(成为数据源,遵守协议)

3.实现数据源里面的两个方法

1)返回一共有多少列

2)在这一列中一共有多少行

4.通过代理告诉它那一列的哪一行显示哪些数据(设置其代理为控制器)

5.使用懒加载,加载所有的食物

6.完成基本数据的展示(列,行,内容)

7.自动更新选中的食物信息。(使用一个大的view,上面放6个label)

1)给3个lab赋值,添加三个属性(水果,主菜,饮料)

2)监听选中了哪一行(监听有两种思想,一个是代理,一个是通知),先查看有没有代理的方法(didselectRow)这个方法当选中了某一行的的时候调用,会将选中的列号和行号当做参数传入进去。能够获取到对应的列号和行号。

3)完成选中时调用的监听方法

4)在viewdidload里面设置默认选中的内容,设置为[0][1]

5)提高可扩展性(手动的调用那几行-使用一个for循环)

8.随机功能的实现

1)怎么让代码选中某一行(selectrow),调用该方法可以指定让它滚动到那一列的哪一行

2)实现头部的功能(使用一个大的uiview,里面放两个子控件)

3)设置高度44,怎么让随机按钮的位置居中?可以设置它的高度为44,最大的Y值为64。

4)设置随机按钮的点击事件randomFood,让pickerview主动选中某一行。

5)生成随机数的方法(生成随机数的限制,不超过当前的总数)

6)缺点,将来数据改变之后,会报错(模于几)[self.foods[0] count]?为什么不用简写 点语法?(切记要记住)

7)随机数的处理不严谨,有的时候生成的随机数可能是相等的,那么这样的话列就不会滚动,获取到对应列的数据总数,如何拿到上一次产生的随机值(也就是当前选中的行),比较上一次的行号和当前生成的随机数是否相同,如果相同则重写生成

9.解决另外一个问题,下面的数据随机刷新失效了,通过代码选中某一行。

三、实现代码示例

1.项目文档结构和storyboard文件

storyboard文件大的界面设置:

2.代码示例

主控制器文件代码:

  1 //
  2 //  YYViewController.m
  3 //  06-简单选菜系统的实现
  4 //
  5 //  Created by apple on 14-6-5.
  6 //  Copyright (c) 2014年 itcase. All rights reserved.
  7 //
  8
  9 #import "YYViewController.h"
 10
 11 //遵守数据源和代理协议
 12 @interface YYViewController ()<UIPickerViewDataSource,UIPickerViewDelegate>
 13 /**
 14  *  水果
 15  */
 16 @property (strong, nonatomic) IBOutlet UILabel *fruitLab;
 17 /**
 18  *  主菜
 19  */
 20 @property (strong, nonatomic) IBOutlet UILabel *stapleLab;
 21 /**
 22  *  饮料
 23  */
 24 @property (strong, nonatomic) IBOutlet UILabel *drinkLab;
 25 /**
 26  *  保存所有的数据
 27  */
 28 @property(nonatomic,strong)NSArray *foods;
 29 @property (weak, nonatomic) IBOutlet UIPickerView *pickerView;
 30 - (IBAction)randomFood:(id)sender;
 31
 32 @end
 33
 34 @implementation YYViewController
 35
 36 - (void)viewDidLoad
 37 {
 38     [super viewDidLoad];
 39
 40     //在这里设置下方数据刷新部分的初始显示
 41     for (int component = 0; component<self.foods.count; component++) {
 42         [self pickerView:nil didSelectRow:0 inComponent:component];
 43     }
 44 }
 45
 46 #pragma mark-使用懒加载,把数据信息加载进来
 47 -(NSArray *)foods
 48 {
 49     if (_foods==nil) {
 50         NSString *fullpath = [[NSBundle mainBundle] pathForResource:@"foods.plist" ofType:nil];
 51         NSArray *arrayM = [NSArray arrayWithContentsOfFile:fullpath];
 52         _foods = arrayM;
 53     }
 54     return _foods;
 55 }
 56
 57 #pragma mark-处理随机按钮的点击事件
 58 - (IBAction)randomFood:(id)sender {
 59
 60     // 让pickerView主动选中某一行
 61     // 让pickerView选中inComponent列的Row行
 62     //    [self.pickerView selectRow:1 inComponent:0 animated:YES];
 63
 64     /*
 65      [self.pickerView selectRow: arc4random() % 12 inComponent:0 animated:YES];
 66      [self.pickerView selectRow: arc4random() % 15 inComponent:1 animated:YES];
 67      [self.pickerView selectRow: arc4random() % 10 inComponent:2 animated:YES];
 68      */
 69
 70     //    [self.foods objectAtIndex:0]; == self.foods[0];
 71     //    [self.foods[0] count];
 72
 73     /*
 74      // 根据每一列的元素个数生成随机值
 75      [self.pickerView selectRow: arc4random() % [self.foods[0] count] inComponent:0 animated:YES];
 76      [self.pickerView selectRow: arc4random() % [self.foods[1] count] inComponent:1 animated:YES];
 77      [self.pickerView selectRow: arc4random() % [self.foods[2] count] inComponent:2 animated:YES];
 78      */
 79
 80     // 设置一个随机数
 81     for (int component = 0; component < self.foods.count; component++) {
 82         // 获取当前列对应的数据元素的个数
 83         int total = [self.foods[component] count];
 84         // 根据每一列的总数生成随机数(当前生成的随机数)
 85         int randomNumber = arc4random() % total;
 86
 87         // 获取当前选中的行(上一次随机后移动到的行)
 88         int oldRow = [self.pickerView selectedRowInComponent:component];
 89
 90         // 比较上一次的行号和当前生成的随机数是否相同,如果相同的话则重新生成
 91         while (oldRow == randomNumber) {
 92                 randomNumber = arc4random() % total;
 93         }
 94
 95         // 让pickerview滚动到指定的某一行
 96         [self.pickerView selectRow:randomNumber inComponent:component animated:YES];
 97         // 模拟,通过代码选中某一行
 98         [self pickerView:nil didSelectRow:randomNumber inComponent:component];
 99     }
100 }
101
102 #pragma mark - 设置数据
103 // 一共多少列
104 -(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
105 {
106     return self.foods.count;
107 }
108
109 // 每列对应多少行
110 -(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
111 {
112     // 1.获取当前的列
113     NSArray *arayM = self.foods[component];
114     //2.返回当前列对应的行数
115     return arayM.count;
116 }
117
118 // 每列每行对应显示的数据是什么
119 -(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component
120 {
121     // 1.获取当前的列
122     NSArray *arayM = self.foods[component];
123     // 2.获取当前列对应的行的数据
124     NSString *name = arayM[row];
125     return name;
126 }
127
128 #pragma mark-设置下方的数据刷新
129 // 当选中了pickerView的某一行的时候调用
130 // 会将选中的列号和行号作为参数传入
131 // 只有通过手指选中某一行的时候才会调用
132 -(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component
133 {
134     // 获取对应列,对应行的数据
135     NSString *name = self.foods[component][row];
136     // 赋值
137     if (0 == component) {
138         self.fruitLab.text = name;
139     }else if(1 == component)
140     {
141         self.stapleLab.text = name;
142     }else
143         self.drinkLab.text = name;
144 }
145
146 #pragma mark-隐藏状态栏
147 -(BOOL)prefersStatusBarHidden
148 {
149     return YES;
150 }
151 @end

四、重要补充

请注意在代码实现中为什么使用 [self.foods[0] count]; 而不是直接使用点语法self.foods[0].count取值。    

[self.foods objectAtIndex:0]; == self.foods[0];//这两句的效果等价,而self调用objectAtIndex:0这个方法,返回的是一个id类型的万能指针,它的真实类型要到实际运行的时候才能检测得到,因此不能直接使用self.foods[0].count。

时间: 2025-01-02 17:32:18

iOS开发UI篇—使用picker View控件完成一个简单的选餐应用的相关文章

iOS开发UI篇—使用picker View控件完成一个简单的选餐应用 - 文顶顶

原文  http://www.cnblogs.com/wendingding/p/3771047.html iOS开发UI篇—使用picker View控件完成一个简单的选餐应用 一.实现效果 说明: 点击随机按钮,能够自动选取,下方数据自动刷新. 二.实现思路 1.picker view的有默认高度为162,不可修改. 2.显示数据,需要设置数据源,也有两种方式(成为数据源,遵守协议) 3.实现数据源里面的两个方法 1)返回一共有多少列 2)在这一列中一共有多少行 4.通过代理告诉它那一列的哪

使用picker View控件完成一个简单的选餐应用

使用picker View控件完成一个简单的选餐应用 一.实现效果 说明:点击随机按钮,能够自动选取,下方数据自动刷新. 二.实现思路 1.picker view的有默认高度为162,不可修改. 2.显示数据,需要设置数据源,也有两种方式(成为数据源,遵守协议) 3.实现数据源里面的两个方法 1)返回一共有多少列 2)在这一列中一共有多少行 4.通过代理告诉它那一列的哪一行显示哪些数据(设置其代理为控制器) 5.使用懒加载,加载所有的食物 6.完成基本数据的展示(列,行,内容) 7.自动更新选中

iOS开发UI篇—DatePicker和UIToolBar控件简单介绍

iOS开发UI篇—DatePicker和UIToolBar控件简单介绍 一.Date Picker控件 1.简单介绍: Date Picker显示时间的控件 有默认宽高,不用设置数据源和代理 如何改成中文的? (1)查看当前系统是否为中文的,把模拟器改成是中文的 (2)属性,locale选择地区 如果默认显示不符合需求.时间有四种模式可以设置,在model中进行设置 时间可以自定义(custom). 设置最小时间和最大时间,超过就会自动回到最小时间. 最大的用途在于自定义键盘:弹出一个日期选择器

iOS开发UI篇—自定义瀑布流控件(蘑菇街数据刷新操作)

iOS开发UI篇—自定义瀑布流控件(蘑菇街数据刷新操作) 一.简单说明 使用数据刷新框架: 该框架提供了两种刷新的方法,一个是使用block回调(存在循环引用问题,_ _weak),一个是使用调用. 问题:在进行下拉刷新之前,应该要清空之前的所有数据(在刷新数据这个方法中). 移除正在显示的cell: (1)把字典中的所有的值,都从屏幕上移除 (2)清除字典中的所有元素 (3)清除cell的frame,每个位置的cell的frame都要重新计算 (4)清除可复用的缓存池. 该部分的代码如下: 1

iOS开发UI篇—自定义瀑布流控件(基本实现)

iOS开发UI篇—自定义瀑布流控件(基本实现) 一.基本实现 说明:在View加载的时候,刷新数据. 1.实现代码 YYViewController.m文件 1 // 2 // YYViewController.m 3 // 06-瀑布流 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "YYViewControll

iOS开发UI篇—自定义瀑布流控件(蘑菇街实现)

iOS开发UI篇—自定义瀑布流控件(蘑菇街瀑布流) 一.简单说明 关于瀑布流 1.是使用UIScrollView实现的 2.刷新数据(reloadData)方法里面做哪些事情 3.layoutSubviews方法里面做哪些事情 4.模仿UItableView进行设计 完善: 瀑布流控件第一次显示到屏幕上的时候自动的向数据源索要数据,而不需要手动调用.这需要监听View的显示,View的显示有一个方法,叫做willMoveToSuperview:在该方法中直接刷新一次数据即可. 二.把自定义的瀑布

iOS开发UI篇—自定义瀑布流控件(接口设计)

iOS开发UI篇—自定义瀑布流控件(接口设计) 一.简单说明 1.关于瀑布流 电商应用要展示商品信息通常是通过瀑布流的方式,因为每个商品的展示图片,长度和商都都不太一样. 如果不用瀑布流的话,展示这样的格子数据,还有一种办法是使用九宫格. 但利用九宫格有一个缺点,那就是每个格子的宽高是一样的,如果一定要使用九宫格来展示,那么展示的商品图片可能会变形. 为了保证商品图片能够按照原来的宽高比进行展示,一般采用的是瀑布流的方式. 2.瀑布流的特点: 由很多的格子组成,但是每个格子的宽度和高速都是不确定

iOS开发UI篇—自定义瀑布流控件(cell的循环利用)

iOS开发UI篇—自定义瀑布流控件(cell的循环利用) 一.简单说明 当滚动的时候,向数据源要cell. 当UIScrollView滚动的时候会调用layoutSubviews在tableView中也是一样的,因此,可以用这个方法来监听scrollView的滚动,可以在在这个地方向数据源索要对应位置的cell(frame在屏幕上的cell). 示例: 当scrollView在屏幕上滚动的时候,离开屏幕的cell应该放到缓存池中去,询问即将(已经)进入到屏幕的cell,对于还没有进入到屏幕的ce

ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布局

本文转自 :http://www.cnblogs.com/wendingding/p/3761730.html ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布局 一.实现效果 二.使用纯代码自定义一个tableview的步骤 1.新建一个继承自UITableViewCell的类 2.重写initWithStyle:reuseIdentifier:方法 添加所有需要显示的子控件(不需要设置子控件的数据和frame,  子控件要添加到contentView中