上篇介绍了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 基础控件(下)的更多相关文章

  1. [iOS基础控件 - 5.5] 代理设计模式 (基于”APP列表"练习)

    A.概述      在"[iOS基础控件 - 4.4] APP列表 进一步封装,初见MVC模式”上进一步改进,给“下载”按钮加上效果.功能      1.按钮点击后,显示为“已下载”,并且不 ...

  2. [iOS基础控件 - 6.11.3] 私人通讯录Demo 控制器的数据传递、存储

    A.需求 1.搭建一个"私人通讯录"Demo 2.模拟登陆界面 账号 密码 记住密码开关 自动登陆开关 登陆按钮 3.退出注销 4.增删改查 5.恢复数据(取消修改)   这个代码 ...

  3. [iOS基础控件 - 6.9] 聊天界面Demo

    A.需求 做出一个类似于QQ.微信的聊天界面 1.每个cell包含发送时间.发送人(头像).发送信息 2.使用对方头像放在左边,我方头像在右边 3.对方信息使用白色背景对话框,我方信息使用蓝色背景对话 ...

  4. iOS基础 - 控件属性

    一.控件的属性 1.CGRect frame 1> 表示控件的位置和尺寸(以父控件的左上角为坐标原点(0, 0)) 2> 修改这个属性,可以调整控件的位置和尺寸 2.CGPoint cen ...

  5. [iOS基础控件 - 7.0] UIWebView

    A.基本使用 1.概念 iOS内置的浏览器控件 Safari浏览器就是通过UIWebView实现的   2.用途:制作简易浏览器 (1)基本请求 创建请求 加载请求 (2)代理监听webView加载, ...

  6. [iOS基础控件 - 6.12.3] @property属性 strong weak copy

    A.概念 @property 的修饰词   strong: 强指针/强引用(iOS6及之前是retain) weak: 弱智真/弱引用(iOS6及之前是assign)   默认情况所有指针都是强指针 ...

  7. [iOS基础控件 - 6.10.2] PickerView 自定义row内容 国家选择Demo

    A.需求 1.自定义一个UIView和xib,包含国家名和国旗显示 2.学习row的重用   B.实现步骤 1.准备plist文件和国旗图片     2.创建模型 // // Flag.h // Co ...

  8. [iOS基础控件 - 6.6.1] 展示团购数据代码

      1.主控制器: // // ViewController.m // GroupPurchase // // Created by hellovoidworld on 14/12/3. // Cop ...

  9. [iOS基础控件 - 5.1] UIScrollView

    A.需要掌握 UIScrollView 是一个能够滚动的视图控件,可以用来展示大量内容,如手机的“设置” 1.常见属性 2.常用代理方法 3.缩放 4.UIScrollView和UIPageContr ...

随机推荐

  1. HTML5文件上传插件 Huploadify V2.1发布

    月初发布了HUploadify2.0版本,增加了文件的断点续传功能,得到了不少朋友的好评.本着按照Uploadify原样复制的原则,本次在一些朋友的建议中采纳了几点,做了一次较小的改动,定为2.1版本 ...

  2. node访问iis使用keep-alive设置不当

    iis默认的连接超时时间为2分钟 ,因此node程序使用keep-alive访问时,keep-alive的时间不应该超过2分钟,否则在请求完成后,node端继续保持连接,2分钟后iis断开连接,会导致 ...

  3. [.NET自我学习]Delegate 泛型

    阅读导航 委托Delegate 泛型 1. 委托Delegate 继承自MulticastDelegate 声明委托定义签名: public delegate int DemoDelegate(int ...

  4. sizeof && strlen 的区别

    本文主要记录了 sizeof 操作符 和 strlen() 函数的区别,以及各自的用途.(在下才疏学浅,发现错误,还请留言指正) sizeof 和 strlen 的区别 示例代码如下: #includ ...

  5. PHP数据库操作:从MySQL原生API到PDO

    本文将举详细例子向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对象.PDO操作MySQL数据库的. 为了后面的测试,先建立数据库表test.包含表名user,s ...

  6. Android开发学习之路-下拉刷新以及GridView的使用

    GridView是类似于ListView的控件,只是GridView可以使用多个列来呈现内容,而ListView是以行为单位,所以用法上是差不多的. 主布局文件,因为要做下拉刷新,所以加了一个Prog ...

  7. Node.js入门:Node.js&NPM的安装与配置

    Node.js安装与配置      Node.js已经诞生两年有余,由于一直处于快速开发中,过去的一些安装配置介绍多数针对0.4.x版本而言的,并非适合最新的0.6.x的版本情况了,对此,我们将在0. ...

  8. iOS-ARC

    1. 本文的主要内容: ARC的本质 ARC的开启与关闭 ARC的修饰符 ARC与Block ARC与Toll-Free Bridging ARC的本质 ARC是编译器(时)特性,而不是运行时特性,更 ...

  9. spring容器对bean生命周期的管理三中方式

    spring容器对bean的生命周期管理主要在两个时间点:bean的初始化完成(包括属性值被完全注入),bean的销毁(程序结束,或者引用结束)方式一:使用springXML配置中的init-meth ...

  10. Python字符进度条

    Python字符进度条 看看这个神奇的module from tqdm import trange from time import sleep for r in trange(10, 1, -1): ...