iOS 基础控件(下)
上篇介绍了UIButton、UILabel、UIImageView和UITextField,这篇就简短一点介绍UIScrollView和UIAlertView。
UIScrollView
顾名思义也知道这个是和滚动相关的控件,在Android开发时遇到过ScrollView,当内容的尺寸超出了屏幕范围之后,用ScrollView则可以通过滚动的方式使得超出屏幕的那部分内容通过滚动的方式显示出来,在Android里面有水平的ScrollView和垂直的ScrollView,在iOS里面就只有一个ScrollView,而且这个ScrollView的功能更大,某些功能已经超出了ScrollView的作用范围了。下面则看一下ScrollView的一些属性
- contentSize:CGSize类型,ScrollView的内容的实际大小;
- contentOffset:CGPoint类型,ScrollView当前滚动到的位置,以视图的左上角来定位;
- contentInset:UIEdgeInsets类型,用于增加ScrollView内容的滚动范围,相当于给ScrollView的四周补白;
下面则是其他属性
- bounces:BOOL类型,是否有弹簧效果
- scrollEnabled :BOOL类型,是否能滚动
- showsHorizontalScrollIndicator:BOOL类型,是否显示水平方向的滚动条
- showsVerticalScrollIndicator:BOOL类型,是否显示垂直方向的滚动条
- indicatorStyle:UIScrollViewIndicatorStyle类型,设定滚动条的样式,这个枚举类型有三个值
UIScrollViewIndicatorStyleDefault
UIScrollViewIndicatorStyleBlack
UIScrollViewIndicatorStyleWhite
- dragging:BOOL类型,是否正在被拖拽
- tracking:BOOL类型,当touch后还没有拖动的时候值是YES,否则NO
- decelerating:BOOL类型,是否正在减速
- zooming:BOOL类型, 是否正在缩放
ScrollView的最直接的功能就是滑动,但是但是它还兼备着手势缩放(在Android中需要在ImageView中使用Matrix),还有滑动翻页的功能(在Android中是通过ViewPager是实现),下面都通过代码来实现,在viewDidLoad方法中加入
UIImage *image=[UIImage imageNamed:@"Android Struct2.gif"];
self.imageView=[[UIImageView alloc]initWithImage:image];
self.imageView.tag=;
[self.scrollView addSubview:self.imageView];
单纯通过上面的代码则可以实现滑动查看一幅图片的功能,一个UIScrollView其实也是一个容器,它里面的子空间都是通过addSubview方法添加进去,而最重要的则是通过设置contentSize这个属性来告诉UIScrollView究竟子控件的尺寸有多大。
手势缩放的示例是在上面的基础上再作修改,如果只需要单纯地实现手势缩放,主要是实现了UIScrollView的- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView方法,同时也要设置UIScrollView的最大最小的缩放比例:minimumZoomScale属性和maximumZoomScale属性,在viewDidLoad方法中加入
UIImage *image=[UIImage imageNamed:@"Android Struct2.gif"];
self.imageView=[[UIImageView alloc]initWithImage:image];
self.imageView.tag=;
[self.scrollView addSubview:self.imageView]; self.scrollView.contentSize=imageView.image.size;
self.scrollView.maximumZoomScale=;
self.scrollView.minimumZoomScale=0.2;
self.scrollView.delegate=self;
在视图控制器里面的类中加入下面的方法
-(UIView*) viewForZoomingInScrollView:(UIScrollView*)scrollView
{
return self.imageView;
}
如果要额外加一些手势则需要使用UITapGestureRecognizer,在viewDidLoad中加入
UITapGestureRecognizer *twoFingerTapRecongizer=[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(scrollViewTwoFingerTapped)];
twoFingerTapRecongizer.numberOfTapsRequired=;
twoFingerTapRecongizer.numberOfTouchesRequired=;
[self.scrollView addGestureRecognizer:twoFingerTapRecongizer];
再定义下面这个方法
-(void)scrollViewTwoFingerTapped:(UITapGestureRecognizer*)recognizer
{
CGFloat newZoomScale=self.scrollView.zoomScale/1.5f;
newZoomScale =MAX(newZoomScale,self.scrollView.minimumZoomScale); [self.scrollView setZoomScale:newZoomScale animated:true];
}
接下来说的是翻页功能,要想翻页功能最好是结合另一个控件UIPageControl,关于这个控件有几个属性要列举一下
- numberOfPages : 总页数
- currentPage : 当前的页码
- hidesForSinglePage : 当只有一页的时候,是否要隐藏视图监听
要让UIScrollView进入翻页模式则需要设置pagingEnabled属性,把它设置成True。代码如下,在viewDidLoad中加入
CGFloat w=self.view.frame.size.width;
CGFloat h=self.view.frame.size.height;
for(int i=;i<;i++)
{
UIImageView *imageView=[[UIImageView alloc]init];
imageView.frame=CGRectMake(i*w, , w, h);
imageView.image=[UIImage imageNamed:@"African Daisy.gif"]; [self.scrollView addSubview:imageView];
} self.scrollView.contentSize=CGSizeMake( *w, );
self.scrollView.showsHorizontalScrollIndicator=false;
self.scrollView.pagingEnabled=true;
self.scrollView.delegate=self; UIPageControl *pagecontrol=[[UIPageControl alloc] init];
pagecontrol.center=CGPointMake(w*0.5,h-);
pagecontrol.bounds=CGRectMake(, , , );
pagecontrol.numberOfPages=; pagecontrol.pageIndicatorTintColor=[UIColor grayColor];
pagecontrol.currentPageIndicatorTintColor=[UIColor whiteColor]; pagecontrol.enabled=false;
[self.view addSubview:pagecontrol];
_pageControl=pagecontrol; -(void) scrollViewDidScroll:(UIScrollView *)scrollView
{
int page=scrollView.contentOffset.x/scrollView.frame.size.width;
_pageControl.currentPage=page;
}
UIAlertView
UIAlertView是消息弹窗,它的作用与效果不用多说了,要使用UIAlertView的就需要让控制器实现UIAlertViewDelegate协议。有用到的属性如下
- title:消息框的标题
- message:消息框的内容
- numberOfButtons:按钮总数
- cancelButtonTitle:取消按钮的标题
- cancelButtonIndex:取消按钮的索引
- firstOtherButtonIndex:第一个其他类型按钮的索引
- visible:消息框可视
- alertViewStyle:UIAlertViewStyle类型,是消息框的类型,它是一个枚举类型,它的值如下
- UIAlertViewStyleDefault 只弹信息和按钮
- UIAlertViewStyleSecureTextInput 有一个textfield加密框
- UIAlertViewStylePlainTextInput 有一个不加密的textfield
- UIAlertViewStyleLoginAndPasswordInput 有两个textfield,Login和password
对于上面提到的按钮索引,是取消按钮和其他按钮组成的一个集合,其中第一个一般是Cancel按钮,它的索引是0,如果Cancel按钮没有设置,则它会是-1,其他则按添加的顺序。在iOS的消息框中,只有Cancel有特有名称,其他按钮则没有特有名称,都统称为OtherButton。
消息框的其中一个构造函数如下
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"AlertViewTest"
message:@"message"
delegate:self
cancelButtonTitle:@"Cancel"
otherButtonTitles:@"OtherBtn1",@"OtherBtn2",@"OtherBtn3",nil];
上面otherButtonTitles参数可以添加多个按钮。添加按钮除了在构造函数里面弄之外,还可以通过方法添加。如果不需要Cancel按钮,则给参数传一个nil值
[alert addButtonWithTitle:@"addButton"];
让消息框显示则需要调用下面的方法
[alert show];
消息框还有一系列的事件
-(void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
//这个事件在消息框上面的按钮被点击之后触发,通过buttonIndex来确定究竟是哪个按钮被点击,然后采取相应的动作
}
还有其他6个事件方法
-(void)alertView:(UIAlertView *)alertView didDismissWithButtonIndex:(NSInteger)buttonIndex
{
//AlertView已经消失时执行的事件
} -(void)alertView:(UIAlertView *)alertView willDismissWithButtonIndex:(NSInteger)buttonIndex
{
//ALertView即将消失时的事件
} -(void)alertViewCancel:(UIAlertView *)alertView
{
//AlertView的取消按钮的事件,但这个事件一直我没有触发过
} -(void)didPresentAlertView:(UIAlertView *)alertView
{
//AlertView已经显示时的事件
} -(void)willPresentAlertView:(UIAlertView *)alertView
{
//AlertView即将显示时
} -(BOOL)alertViewShouldEnableFirstOtherButton:(UIAlertView *)alertView
{
//第一个触发的事件
}
对于上面一系列的事件大体可以分为两类,显示的事件,他们触发顺序如下
alertViewShouldEnableFirstOtherButton——>willPresentAlertView——>didPresentAlertView
另一类是消失的事件,是在点击后才会触发
clickedButtonAtIndex——>(如果会触发视图取消,则会调用alertViewCancel)willDismissWithButtonIndex——>didDismissWithButtonIndex
iOS 基础控件(下)的更多相关文章
- [iOS基础控件 - 5.5] 代理设计模式 (基于”APP列表"练习)
A.概述 在"[iOS基础控件 - 4.4] APP列表 进一步封装,初见MVC模式”上进一步改进,给“下载”按钮加上效果.功能 1.按钮点击后,显示为“已下载”,并且不 ...
- [iOS基础控件 - 6.11.3] 私人通讯录Demo 控制器的数据传递、存储
A.需求 1.搭建一个"私人通讯录"Demo 2.模拟登陆界面 账号 密码 记住密码开关 自动登陆开关 登陆按钮 3.退出注销 4.增删改查 5.恢复数据(取消修改) 这个代码 ...
- [iOS基础控件 - 6.9] 聊天界面Demo
A.需求 做出一个类似于QQ.微信的聊天界面 1.每个cell包含发送时间.发送人(头像).发送信息 2.使用对方头像放在左边,我方头像在右边 3.对方信息使用白色背景对话框,我方信息使用蓝色背景对话 ...
- iOS基础 - 控件属性
一.控件的属性 1.CGRect frame 1> 表示控件的位置和尺寸(以父控件的左上角为坐标原点(0, 0)) 2> 修改这个属性,可以调整控件的位置和尺寸 2.CGPoint cen ...
- [iOS基础控件 - 7.0] UIWebView
A.基本使用 1.概念 iOS内置的浏览器控件 Safari浏览器就是通过UIWebView实现的 2.用途:制作简易浏览器 (1)基本请求 创建请求 加载请求 (2)代理监听webView加载, ...
- [iOS基础控件 - 6.12.3] @property属性 strong weak copy
A.概念 @property 的修饰词 strong: 强指针/强引用(iOS6及之前是retain) weak: 弱智真/弱引用(iOS6及之前是assign) 默认情况所有指针都是强指针 ...
- [iOS基础控件 - 6.10.2] PickerView 自定义row内容 国家选择Demo
A.需求 1.自定义一个UIView和xib,包含国家名和国旗显示 2.学习row的重用 B.实现步骤 1.准备plist文件和国旗图片 2.创建模型 // // Flag.h // Co ...
- [iOS基础控件 - 6.6.1] 展示团购数据代码
1.主控制器: // // ViewController.m // GroupPurchase // // Created by hellovoidworld on 14/12/3. // Cop ...
- [iOS基础控件 - 5.1] UIScrollView
A.需要掌握 UIScrollView 是一个能够滚动的视图控件,可以用来展示大量内容,如手机的“设置” 1.常见属性 2.常用代理方法 3.缩放 4.UIScrollView和UIPageContr ...
随机推荐
- C#Light v0.007 又一次重大更新
上次给大家介绍过C#Lite是一个小巧的脚本语言,现在C#更加强大了. 下文白色是脚本代码,黑色是VS中的c#代码 目前这段代码已经可以正确执行 这个Vector3的原型如下 添加这个Vector3的 ...
- JVM内存回收机制简述
JVM内存回收机制涉及的知识点太多了,了解越多越迷糊,汗一个,这里仅简单做个笔记,主要参考<深入理解Java虚拟机:JVM高级特性与最佳实践(第二版)> 目前java的jdk默认虚拟机为H ...
- 案例研究:CopyToAsync
返回该系列目录<基于Task的异步模式--全面介绍> 把一个流拷贝到另一个流是有用且常见的操作.Stream.CopyTo 方法在.Net 4中就已经加入来满足要求这个功能的场景,例如在一 ...
- 如何把IP转换成经纬度(Java版)
经常有这种需求,拥有用户的IP地址,想要在地图上显示用户的访问量.这个时候就需要用到经纬度...应为一般的地图插件都是基于经纬度的. 那么问题来了,如何把IP转换成经纬度? 百度API 最国产的方式, ...
- CKFinder_AspDotNet_2.4 破解方法 去版权
CKFinder是一个比较好用的Web端文件管理器,虽然UI不是很好看,但是因为能搞到源码,所以比起网上那些只有付费之后才能下载到源码的Web端文件管理器要好许多,至少你可以在确定该控件是否能用在你的 ...
- css图片叠加和底部定位
css图片叠加和底部定位 css图片叠加 两张图片需要叠在一起显示,如何定位 容器先对定位 第一张图片正常摆放 第二张图片绝对定位,top:0px 这样便实现了两张图片叠加在一起了,设置z-index ...
- Java多线程synchronized同步
非线程安全问题 “非线程安全”问题存在于“实例变量”中,如果是方法内部的私有变量,则不存在“非线程问题”.也即是说,方法中的变量永远是线程安全的. 如果多个线程共同访问1个对象中的实例变量,则可能线程 ...
- zabbix 3.0 安装 ubuntu环境
zabbix 3.0 安装 标签(空格分隔): 开发 [TOC] 下载deb # wget http://repo.zabbix.com/zabbix/3.0/ubuntu/pool/main/z/z ...
- 快速入门系列--WCF--01基础概念
转眼微软的WCF已走过十个年头,它是微软通信框架的集大成者,将之前微软所有的通信框架进行了整合,提供了统一的应用方式.记得从自己最开始做MFC时,就使用过Named Pipe命名管道,之后做Winfo ...
- Linux快速入门04-扩展知识
这部分是快速学习的最后一部分知识,其中最重要的内容就是源码的打包和软件的安装的学习,由于个人的Linux学习目的就是自己能在阿里云Ubuntu上搭建一个简单的nodejs发布环境. Linux系列文章 ...