UIView:用来展示用户的界面,响应用户的操作(继承自UIResponder)

UIView的作用:绘图、动画、处理事件

UIView可以包含和管理子视图,并且决定子视图的位置大小

获取所有的子视图(数组)

NSArray *subViews= self.window.subviews;

将子视图放在某个子视图上面

[self.window insertSubview:greenView aboveSubview:yellowView];

将子视图放在某个子视图下面

[self.window insertSubview:greenView belowSubview:blueView];

将子视图放在某个下标位置处

[self.window insertSubview:greenView atIndex:2];

将某个子视图移到最上层

[self.window bringSubviewToFront:redView];

将某个子视图移到最底层

[self.window sendSubviewToBack:blueView];

设置是否允许父视图裁剪子视图(子视图比父视图大时)

blackView.clipsToBounds=YES;

设置是否允许在父视图尺寸变化时自动调整子视图的尺寸

blackView.autoresizesSubviews=YES;

设置子视图的调整模式,自动调整子视图的高度和宽度

topView.autoresizingMask=

UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleWidth;

获取父视图

UIView *parentView= subView.superview;

将topView从父视图中移除(删除视图topView)

[topView removeFromSuperview];

UIView动画有2种:

属性动画:frame、bounds、center、backgroundColor、alpha、transform

翻转动画:实现方式2种:iOS4.0之前:采用[]设置;iOS4.0之后:采用block实现

1.iOS4.0之前:采用[]设置

开始设置动画,第一个参数是动画名字,第二个参数是对象,一般为nil

[UIView beginAnimations:@"animation" context:nil];

设置动画的持续时间

[UIView setAnimationDuration:1];

设置动画开始的延迟时间

[UIView setAnimationDelay:0];

设置动画重复次数

[UIView setAnimationRepeatCount:1];

设置动画模式

[UIView setAnimationCurve:UIViewAnimationCurveLinear];

UIViewAnimationCurveEaseIn:动画开始时效果缓慢

UIViewAnimationCurveEaseOut:动画结束时效果缓慢

UIViewAnimationCurveEaseInOut:动画开始和结束时效果缓慢

UIViewAnimationCurveLinear:动画的平滑效果

设置代理,采用执行下面2个方法

[UIView setAnimationDelegate:self];

设置动画结束后执行的选择器方法

[UIView setAnimationDidStopSelector:@selector(buttonClick:)];

设置动画开始之前执行的选择器方法

[UIView setAnimationWillStartSelector:@selector(buttonClick:)];

设置图片视图的中心点

imageView.center=CGPointMake(300, 600);

设置图片视图的透明度

imageView.alpha=0.1;

设置缩放比例值

imageView.transform=CGAffineTransformMakeScale(1.5, 1.5);

在imageview原来的transform值基础上宽度高度放大为1.5被再赋给imageview,连续放大

imageView.transform=CGAffineTransformScale(imageView.transform, 1.5, 1.5);

设置旋转动画,每次旋转90度

imageView.transform=CGAffineTransformRotate(imageView.transform, M_PI_2);

动画开始

[UIView commitAnimations];

2.iOS4.0后用block实现属性动画

可以设置动画的持续时间和动画内容

[UIView animateWithDuration:1 animations:^{ }];

设置动画的持续时间、动画内容和动画结束后执行的语句

[UIView animateWithDuration:2 animations:^{} completion:^(BOOL finished) {}];

设置动画持续时间、开始之前的延迟时间、动画效果、动画内容、动画结束后执行的block

[UIView animateWithDuration:2 delay:1 options:UIViewAnimationOptionCurveLinear animations:^{} completion:^(BOOL finished) {}];

设置翻转效果,第一个参数是翻转方向,第二个参数是操作的对象,

[UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:self.window cache:YES];

设置翻转动画:第1个参数是操作的对象,第2个参数是持续时间,第3个参数是翻转的方向,第4个参数是动画结束后执行的语句

[UIView transitionWithView:self.window duration:2 options:UIViewAnimationOptionTransitionCurlDown animations:^{

[self.window exchangeSubviewAtIndex:1 withSubviewAtIndex:2];

} completion:^(BOOL finished) {}];

CALayer:层,可以用来渲染图片、制作动画,每创建一个view时,自动创建一个layer,不能重新创建和赋值,但是可以修改某些属性

设置阴影颜色

imageView.layer.shadowColor=[UIColor redColor].CGColor;

设置阴影的偏移量

imageView.layer.shadowOffset=CGSizeMake(10, 10);

设置阴影的透明度,1不透明,0完全透明

imageView.layer.shadowOpacity=0.8;

设置边框的颜色

imageView.layer.borderColor=[UIColor blueColor].CGColor;

设置边框的宽度

imageView.layer.borderWidth=5;

设置圆角半径

imageView.layer.cornerRadius=50;

设置是否允许子视图被裁剪

imageView.clipsToBounds=YES;

UI控件之UIView与动画的更多相关文章

  1. UI控件(复习一下)

    如何修改控件状态• 可见,确实需要经常修改控件状态• 那如何去修改控件的状态呢?方法很简单➢ 每一个UI控件都是一个对象➢ 修改UI控件的状态,其实就是修改控件对象的属性➢ 比如修改UILabel显示 ...

  2. AppleWatch___学习笔记(二)UI布局和UI控件

    1.UI布局 直接开发,你会发现Apple Watch并不支持AutoLayout,WatchKit里有个类叫做WKInterfaceGroup,乍一看像是UIView,但是这货其实是用来布局的.从 ...

  3. 【IOS 开发】基本 UI 控件详解 (UIDatePicker | UIPickerView | UIStepper | UIWebView | UIToolBar )

    转载注明出处 : http://blog.csdn.net/shulianghan/article/details/50348982 一. 日期选择器 (UIDatePicker) UIDatePic ...

  4. Swift UI控件详细介绍(上)

    UI控件 首先介绍一下AppDelegate.swift@UIApplicationMain 调用了OC中的UIApplicationMain函数:UIApplicationMain是iOS应用程序的 ...

  5. iOS基础UI控件介绍-Swift版

    iOS基础UI控件总结 iOS基础控件包括以下几类: 1.继承自NSObject:(暂列为控件) UIColor //颜色 UIImage //图像 2.继承自UIView: 只能相应手势UIGest ...

  6. ANDROID L——Material Design详解(UI控件)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...

  7. IOS学习资源收集--开发UI控件相关

    收集的一些本人了解过的iOS开发UI控件相关的代码资源(本文持续补充更新) 内容大纲: 1.本人在github上也上传了我分装好的一些可重复利用的UI控件 2.计时相关的自定义UILabel控件 正文 ...

  8. 《深入理解Windows Phone 8.1 UI控件编程》基于最新的Runtime框架

    <深入理解Windows Phone 8.1 UI控件编程>本书基于最新的Windows Phone 8.1 Runtime SDK编写,全面深入地论述了最酷的UI编程技术:实现复杂炫酷的 ...

  9. [WP8.1UI控件编程]Windows Phone动画方案的选择

    8.1 动画方案的选择 Windows Phone的动画实现方式有线性插值动画(3种类型).关键祯动画(4种类型)和基于帧动画,甚至还有定时器动画,然后动画所改变的UI元素属性可以是普通的UI元素属性 ...

随机推荐

  1. 基于HTML5 audio元素播放声音jQuery小插件

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=1609 一.前面的些唠 ...

  2. svn版本库目录结构

      该文是svn源代码分析系列文章服务端架构中的一篇,主要描述svn服务端版本库数据存储目录结构,并且对这些文件以及目录的作用进行简单分析.使用“svnmadin create”命令创建初始化版本库后 ...

  3. 去OpenCVManager,大部分为转载,仅当自己学习使用

    去OpenCVManager方法,可以参考这篇博客http://blog.csdn.net/yanzi1225627/article/details/27863615,可以用,挺好的.我这里只是做个总 ...

  4. Python使用MySQL数据库的

    然而,2016年开始,我从Python2切换到了Python3,Python2已经基本不再使用,MySQLdb驱动从2014年1月停止了维护.所以,打算重新再来写这篇博客. Python2 ---&g ...

  5. OpenCV学习笔记:opencv_ml模块

    一,简介 该模块为opencv的机器学习(machine learning,ml)代码库,包含各种机器学习算法: 0, class CvStatModel ; class CvMLData; stru ...

  6. 【动态规划】skiing

    [动态规划]skiing 时间限制: 1 Sec  内存限制: 128 MB提交: 34  解决: 15[提交][状态][讨论版] 题目描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激. ...

  7. 现代 PHP 新特性系列

    生成器的创建和使用 http://laravelacademy.org/post/4317.html

  8. MM/PP/SD/FICO 模块常用事物码(T-code)、SAP快捷键

    MM/PP/SD/FICO MM常用T-CODE MM01 创建一般物料 Create Material – GeneralMM02 修改一般物料 Change MaterialMM03 显示一般物料 ...

  9. poj3177Redundant Paths tarjan缩点

    //给一个连通图,问最少须要加入多少条边才干使得 //随意两个点都有两条不同的路走到 //对于一个强连通分量的全部随意两点都能有两点能够到达 //先用tarjan缩点,缩点以后就是一棵树,对于这个树考 ...

  10. iOS 设置Label中特定的文字大小和颜色

    直接上代码: _price = @"27"; NSMutableAttributedString *attributedString = [[NSMutableAttributed ...