UI控件之UIView与动画
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与动画的更多相关文章
- UI控件(复习一下)
如何修改控件状态• 可见,确实需要经常修改控件状态• 那如何去修改控件的状态呢?方法很简单➢ 每一个UI控件都是一个对象➢ 修改UI控件的状态,其实就是修改控件对象的属性➢ 比如修改UILabel显示 ...
- AppleWatch___学习笔记(二)UI布局和UI控件
1.UI布局 直接开发,你会发现Apple Watch并不支持AutoLayout,WatchKit里有个类叫做WKInterfaceGroup,乍一看像是UIView,但是这货其实是用来布局的.从 ...
- 【IOS 开发】基本 UI 控件详解 (UIDatePicker | UIPickerView | UIStepper | UIWebView | UIToolBar )
转载注明出处 : http://blog.csdn.net/shulianghan/article/details/50348982 一. 日期选择器 (UIDatePicker) UIDatePic ...
- Swift UI控件详细介绍(上)
UI控件 首先介绍一下AppDelegate.swift@UIApplicationMain 调用了OC中的UIApplicationMain函数:UIApplicationMain是iOS应用程序的 ...
- iOS基础UI控件介绍-Swift版
iOS基础UI控件总结 iOS基础控件包括以下几类: 1.继承自NSObject:(暂列为控件) UIColor //颜色 UIImage //图像 2.继承自UIView: 只能相应手势UIGest ...
- ANDROID L——Material Design详解(UI控件)
转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...
- IOS学习资源收集--开发UI控件相关
收集的一些本人了解过的iOS开发UI控件相关的代码资源(本文持续补充更新) 内容大纲: 1.本人在github上也上传了我分装好的一些可重复利用的UI控件 2.计时相关的自定义UILabel控件 正文 ...
- 《深入理解Windows Phone 8.1 UI控件编程》基于最新的Runtime框架
<深入理解Windows Phone 8.1 UI控件编程>本书基于最新的Windows Phone 8.1 Runtime SDK编写,全面深入地论述了最酷的UI编程技术:实现复杂炫酷的 ...
- [WP8.1UI控件编程]Windows Phone动画方案的选择
8.1 动画方案的选择 Windows Phone的动画实现方式有线性插值动画(3种类型).关键祯动画(4种类型)和基于帧动画,甚至还有定时器动画,然后动画所改变的UI元素属性可以是普通的UI元素属性 ...
随机推荐
- 基于HTML5 audio元素播放声音jQuery小插件
by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=1609 一.前面的些唠 ...
- svn版本库目录结构
该文是svn源代码分析系列文章服务端架构中的一篇,主要描述svn服务端版本库数据存储目录结构,并且对这些文件以及目录的作用进行简单分析.使用“svnmadin create”命令创建初始化版本库后 ...
- 去OpenCVManager,大部分为转载,仅当自己学习使用
去OpenCVManager方法,可以参考这篇博客http://blog.csdn.net/yanzi1225627/article/details/27863615,可以用,挺好的.我这里只是做个总 ...
- Python使用MySQL数据库的
然而,2016年开始,我从Python2切换到了Python3,Python2已经基本不再使用,MySQLdb驱动从2014年1月停止了维护.所以,打算重新再来写这篇博客. Python2 ---&g ...
- OpenCV学习笔记:opencv_ml模块
一,简介 该模块为opencv的机器学习(machine learning,ml)代码库,包含各种机器学习算法: 0, class CvStatModel ; class CvMLData; stru ...
- 【动态规划】skiing
[动态规划]skiing 时间限制: 1 Sec 内存限制: 128 MB提交: 34 解决: 15[提交][状态][讨论版] 题目描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激. ...
- 现代 PHP 新特性系列
生成器的创建和使用 http://laravelacademy.org/post/4317.html
- MM/PP/SD/FICO 模块常用事物码(T-code)、SAP快捷键
MM/PP/SD/FICO MM常用T-CODE MM01 创建一般物料 Create Material – GeneralMM02 修改一般物料 Change MaterialMM03 显示一般物料 ...
- poj3177Redundant Paths tarjan缩点
//给一个连通图,问最少须要加入多少条边才干使得 //随意两个点都有两条不同的路走到 //对于一个强连通分量的全部随意两点都能有两点能够到达 //先用tarjan缩点,缩点以后就是一棵树,对于这个树考 ...
- iOS 设置Label中特定的文字大小和颜色
直接上代码: _price = @"27"; NSMutableAttributedString *attributedString = [[NSMutableAttributed ...