iOS-省市区选择的实现
一、简介
该文主要实现的是省市区的选择,可在个人修改地址的地方使用。
二、需要的东西
制作这个首先需要一个area.plist文件,该文件中保存这所有的关于省市区的信息,下载地址:http://pan.baidu.com/s/1qWFPf8g。
三、制作原理
通过一个UIPickerView来显示,将UIPickerView分成三部分,省、市、区。进而加载数据。
四、实现效果
图片展示:
五、具体实现步骤:
1、首先,新建一个Single View APplication,然后在Storyboard中添加一个UIpicker View
,
2、实现UIPicker View的代理方法 --这里的数据是暂时的,还没添加数据
#pragma mark - UIPickerViewDelegate
/**
*返回每一列的数据个数
*/
-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
{
if(component==)
{
return ;
}else if (component==)
{
return ;
}else
{
return ;
}
}
/**
*返回pickerView分几列,因为是省市区选择,所以分3列
*/
-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
{
return ;
}
/**
*触发的事件
*/
-(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component
{
NSLog(@"ss");
}
/**
*通过自定义view去显示pickerView中的内容,这样做的好处是可以自定义的调整pickerView中显示内容的格式
*/
-(UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view
{
UILabel *myView = nil;
myView = [[UILabel alloc] initWithFrame:CGRectMake(0.0, 0.0, , )];
myView.textAlignment = NSTextAlignmentCenter;
myView.font = [UIFont systemFontOfSize:]; //用label来设置字体大小
if (component==) {
myView.text = @"";
}else if (component==)
{
myView.text = @"";
}else
{
myView.text = @"";
}
return myView;
}
3、接下来就是把刚才下载的那个area.plist文件中的数据加入到picker View中
①、首先定义三个NSArray。
NSArray *provinceArr,*cityArr,*areaArr;
②、先设置provinceArr.cityArr,areaArr.
provinceArr = [[NSMutableArray alloc] initWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"area.plist" ofType:nil]];
cityArr = [[provinceArr objectAtIndex:] objectForKey:@"cities"];
areaArr = [[cityArr objectAtIndex:] objectForKey:@"areas"];
默认的province列先显示的第一列,此时刚好让city显示第一列的city,让area显示第一个city的area。
注:(此处这样设置是因为这个area.plist文件的结构的原因,你可以自己看一下这个plist文件)。
4、此时数据便有了,但是当滚动第一列时,第二列和第三列都没有变化,其实本质上就是在设置pickerView内容的代理方法中设置内容改变。重头戏来了。--修改上面的这个代理方法。
-(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component
{
if (component==) { //当是省的时候
cityArr = [[provinceArr objectAtIndex:row] objectForKey:@"cities"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
if ([cityArr count]!=) {
areaArr = [[cityArr objectAtIndex:] objectForKey:@"areas"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
}
}
else if (component==)
{
areaArr = [[cityArr objectAtIndex:row] objectForKey:@"areas"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
}
}
注:不要忘了重新设置每一列的数据个数
if (component==) {
return [provinceArr count];
}else if(component==)
{
return [cityArr count];
}else
{
return [areaArr count];
}
5、附加:
获取三列的内容
province= [[provinceArr objectAtIndex:[self.areaPicker selectedRowInComponent:]] objectForKey:@"state"]; //获取province
city= [[cityArr objectAtIndex:[self.areaPicker selectedRowInComponent:]] objectForKey:@"city"];
if ([areaArr count]!=) {
area = [areaArr objectAtIndex:[self.areaPicker selectedRowInComponent:]];
}
6、完成,附上源码。(故事版上的设置大家自己设置就行了)
//
// ViewController.m
// ProvinceCityDownTownChoose
//
// Created by xiaoguizi on 15/2/9.
// Copyright (c) 2015年 xiaoguizi. All rights reserved.
//
------.m文件------
#import "ViewController.h"
@interface ViewController ()
{
NSArray *provinceArr,*cityArr,*areaArr;
}
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
provinceArr = [[NSMutableArray alloc] initWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"area.plist" ofType:nil]];
cityArr = [[provinceArr objectAtIndex:] objectForKey:@"cities"];
areaArr = [[cityArr objectAtIndex:] objectForKey:@"areas"];
}
#pragma mark - UIPickerViewDelegate
/**
*返回每一列的数据个数
*/
-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
{
if (component==) {
return [provinceArr count];
}else if(component==)
{
return [cityArr count];
}else
{
return [areaArr count];
}
}
/**
*返回pickerView分几列,因为是省市区选择,所以分3列
*/
-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
{
return ;
}
/**
*触发的事件
*/
-(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component
{
if (component==) {
cityArr = [[provinceArr objectAtIndex:row] objectForKey:@"cities"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
if ([cityArr count]!=) {
areaArr = [[cityArr objectAtIndex:] objectForKey:@"areas"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
}
}
else if (component==)
{
areaArr = [[cityArr objectAtIndex:row] objectForKey:@"areas"];
[pickerView selectRow: inComponent: animated:NO];
[self.areaPicker reloadComponent:];
}
}
/**
*通过自定义view去显示pickerView中的内容,这样做的好处是可以自定义的调整pickerView中显示内容的格式
*/
-(UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view
{
UILabel *myView = nil;
myView = [[UILabel alloc] initWithFrame:CGRectMake(0.0, 0.0, , )];
myView.textAlignment = NSTextAlignmentCenter;
myView.font = [UIFont systemFontOfSize:]; //用label来设置字体大小
if (component==) {
myView.text =[[provinceArr objectAtIndex:row] objectForKey:@"state"];
}else if (component==)
{
myView.text =[[cityArr objectAtIndex:row] objectForKey:@"city"];
}else
{
myView.text =[areaArr objectAtIndex:row];
}
return myView;
}
@end
------.h文件------
//
// ViewController.h
// ProvinceCityDownTownChoose
//
// Created by xiaoguizi on 15/2/9.
// Copyright (c) 2015年 xiaoguizi. All rights reserved.
//
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController<UIPickerViewDataSource,UIPickerViewDelegate>
@property (weak, nonatomic) IBOutlet UIPickerView *areaPicker;
@end
iOS-省市区选择的实现的更多相关文章
- IOS 如何选择delegate、notification、KVO?
IOS 如何选择delegate.notification.KVO? 博客分类: IOS 前面分别讲了delegate.notification和KVO的实现原理,以及实际使用步骤,我们心中不禁有 ...
- iOS解析XML实现省市区选择
1.具体内容就不再赘述了.直接看关键代码. viewController.h // // ViewController.h // ParseXmlToRealizeChooseCityDemo // ...
- iOS 正确选择图片加载方式
正确选择图片加载方式能够对内存优化起到很大的作用,常见的图片加载方式有下面三种: //方法1 UIImage *imag1 = [UIImage imageNamed:@"image.png ...
- IOS 如何选择delegate、notification、KVO?(转)
前面分别讲了delegate.notification和KVO的实现原理,以及实际使用步骤,我们心中不禁有个疑问,他们的功能比较类似,那么在实际的编程中,如何选择这些方式呢? 在网上看到一个博客上详细 ...
- js三级省市区选择
<!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...
- IOS 日期选择
传统方式 一般情况下弹出日期选择的场景是:用户点击UITextField弹出日期选择,关键代码如下: 点击UITextField弹出日期选择 1 2 3 UITextField *textField; ...
- OS X升级到10.11后Xcode6.4界面无iOS device选择栏的解决办法
原来在Xcode6.4项目运行按钮右侧会有一个可以选择设备或模拟器的选择栏,但是升级后没有了.但是Xcode7.0.1打开同样的项目会有显示. 简单找了一下无果后,发现咋Xcode顶部菜单里可以找到切 ...
- iOS 载入图片选择imageNamed 方法还是 imageWithContentsOfFile?
Apple官方的文档为生成一个UIImage对象提供了两种方法: 1. imageNamed,其參数为图片的名字. 2. imageWithContentsOfFile,其參数也是图片文件的路径. 那 ...
- iOS 可选择的购物车
最近看了淘宝的购物车,于是做了一个可选择的购物车模板. 如果有好的建议请提出,带我日后更新.
- ios uiimagepickercontroller 选择相册或者拍照上传
首先需要实现UIImagePickerControllerDelegate 代理 实现其imagePickerController 方法 这里用于选择图片或的拍照回调 //调用相机拍照 或者 图库选 ...
随机推荐
- Java 面试基础总结(一)
1.九种基本数据类型的大小以及它们的封装类 java提供的九种基本数据类型:boolean.byte(1).char(2).short(2).int(4).long(8).float(4).doubl ...
- 图像处理之Retinex增强算法(SSR、MSR、MSRCR)
视网膜-大脑皮层(Retinex)理论认为世界是无色的,人眼看到的世界是光与物质相互作用的结果,也就是说,映射到人眼中的图像和光的长波(R).中波(G).短波(B)以及物体的反射性质有关 其中I是人眼 ...
- leetcode — two-sum-iii-data-structure-design
import java.util.HashMap; import java.util.Map; /** * Source : https://oj.leetcode.com/problems/two- ...
- Django 学习笔记(五) --- Ajax 传输数据
人生苦短 ~ Tips:仅适用于 Python 3+(反正差别不大,py2 改改也能用).因为据 Python 之父 Guido van Rossum 说会在 2020 年停止对 Python 2 的 ...
- xshell远程终端操作Ubuntu server安装LAMP环境之最详细笔记之二PHP开发环境配置
前言: 昨天学会了安装server,今天试着通过远程终端xshell来安装LAMP,搭配一下开发环境,也有集成环境可以一键安装使用,还是瞎折腾一下,手动一步一步搭建一下这个开发环境. 接上一篇:ubu ...
- [SCOI2012] 喵星球上的点名
Description 给定 \(N\) 个姓名串和 \(M\) 个点名串.询问每个点名串点到了多少姓名和每个姓名串被点到了几次.\(N\leq 5\cdot 10^4,M\leq 10^5\). S ...
- .net core Identity集成IdentityServer4 (1)基本操作
一. 新建asp.net core identity项目 新建项目->asp.net core web应用程序-> web应用程序(模型视图控制器)&更改身份验证为个人. 新建一个 ...
- 修改git分支名称
场景:将分支名称为 oldbranch 改为 newbranch 步骤: 1.将本地分支oldbranch切一个分支到本地 git branch -m oldbranch newbranch 2.删除 ...
- Tomcat报failed to parse the expression [${xxx}]异常(javax.el.ELException)的解决方法
Tomcat 7 'javax.el.ELException' 的解决方式tomcat 7对EL表达式的语法要求比较严格,例如"${owner.new}"因包含关键字new就会导致 ...
- 23种设计模式+J2EE设计模式学习笔记-初识设计模式
设计模式简介: 设计模式是一套被反复使用的.多数人知晓的.经过分类编目的.代码设计经验的总结.(个人理解:设计模式是不关乎业务,逻辑实现,针对普遍问题的一种解决方案). 设计模式的类型: 传统23种设 ...