UI- Layer的使用总结(附动画)
#pargma mark - Layer
1. 设置当前视图的背景颜色
self.view.backgroundColor = [UIColor lightGrayColor];
2. 创建一个视图,并且设置frame
UIView *myView = [[UIView alloc]initWithFrame:CGRectMake(50, 50, 100, 100)];
3. 将创建的视图添加到当前视图
[self.view addSubview:myView];
4. 设置创建视图的背景颜色
myView.backgroundColor = [UIColor blueColor];
5. 设置视图的层属性,每个视图都关联着一个Layer
设置 创建视图图层 的 背景颜色,即为 视图 本身 的 背景颜色 可通过Debug查看
myView.layer.backgroundColor = [UIColor redColor].CGColor;
// myView.backgroundColor = [UIColor yellowColor];
设置图层的边界宽度
myView.layer.borderWidth = 10;
设置图层的边界颜色 ,默认为黑色
myView.layer.borderColor = [UIColor whiteColor].CGColor;
设置拐点的圆角半径, 可以巧妙的利用该方法画圆(将圆角半径设置为视图宽度的一般即可)
myView.layer.cornerRadius = 50;
添加一张图片
myView.layer.contents = (__bridge id _Nullable)([UIImage imageNamed:@"btn_02"].CGImage);
将图片超出圆角半径的内容裁剪掉
myView.clipsToBounds = YES;
//myView.layer.masksToBounds = YES;
6.基础动画: 3种方式 --> 中心点移动/大小变化/旋转
CABasicAnimation *basicAnimation = [CABasicAnimation animation];
动画时间
basicAnimation.duration = 2;
动画重复次数
basicAnimation.repeatCount = 3;
basicAnimation.removedOnCompletion = YES;
//填充模式4中 至今木有弄懂 `backwards', `forwards', `both' and `removed'
// basicAnimation.fillMode = @"backwards";
6.1 中心点移动动画
basicAnimation.fromValue = [NSValue valueWithCGPoint: CGPointMake(50, 50) ];
basicAnimation.byValue = [NSValue valueWithCGPoint:CGPointMake(200, 200)];
basicAnimation.toValue = [NSValue valueWithCGPoint:CGPointMake(300, 300)];
basicAnimation.keyPath = @"position";
6.2 大小变化动画
basicAnimation.toValue = [NSValue valueWithCGRect:CGRectMake(0, 0, 300, 400)];
basicAnimation.keyPath = @"bounds";
6.3 旋转
basicAnimation.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeRotation(M_PI_4 + M_PI_2, 0, 0, 1)];
basicAnimation.keyPath = @"transform";
//注意:设置完动画后要添加动画
[myLayer addAnimation:basicAnimation forKey:nil];
7. 关键帧动画: 两种方式 --> 定义关键点/定义路径
CAKeyframeAnimation *keyFrameAni = [CAKeyframeAnimation animation];
keyFrameAni.duration = 2;
keyFrameAni.repeatCount = 3;
7.1 定义关键点
NSValue *value1 = [NSValue valueWithCGPoint: CGPointMake(50, 50) ];
NSValue *value2 = [NSValue valueWithCGPoint:CGPointMake(100, 200)];
NSValue *value3 = [NSValue valueWithCGPoint:CGPointMake(300, 300)];
keyFrameAni.keyPath = @"position";
keyFrameAni.values = @[value1,value2,value3];
7.2 定义路径
CGMutablePathRef path = CGPathCreateMutable();
//CGPathAddEllipseInRect(path, nil, CGRectMake(50, 50, 300, 400));
CGPathAddArc(path, nil, 100, 100, 50, M_PI_2, M_PI, YES);
keyFrameAni.path = path;
CGPathRelease(path);
keyFrameAni.keyPath = @"position";
[myLayer addAnimation:keyFrameAni forKey:nil];
8. 转换动画 --> 可有立体效果
CATransition *transAnimaiton = [CATransition animation];
transAnimaiton.duration = 3;
transAnimaiton.type = @"cube";
transAnimaiton.subtype = @"fromTop";
[myLayer addAnimation:transAnimaiton forKey:nil];
UI- Layer的使用总结(附动画)的更多相关文章
- iOS开发笔记7:Text、UI交互细节、两个动画效果等
Text主要总结UILabel.UITextField.UITextView.UIMenuController以及UIWebView/WKWebView相关的一些问题. UI细节主要总结界面交互开发中 ...
- 教你避雷!网页设计中常见的17个UI设计错误集锦(附赠设计技巧)
以下内容由摹客团队翻译整理,仅供学习交流,摹客iDoc是支持智能标注和切图的产品协作设计神器. 精心设计的用户界面对网站意义重大.具备所有最新功能和响应式设计有助于提高网站的搜索引擎排名,从而增加受众 ...
- UI控件之UIView与动画
UIView:用来展示用户的界面,响应用户的操作(继承自UIResponder) UIView的作用:绘图.动画.处理事件 UIView可以包含和管理子视图,并且决定子视图的位置大小 获取所有的子视图 ...
- Core Animation 文档翻译—附录A(Layer样貌相关属性动画)
前言 在渲染过程中,核心动画获取Layer的各种属性并以特定的顺序渲染他们.这个顺序决定了Layer的最终的样貌.本节将会阐述通过设置不同的Layer样貌相关属性对应产生的渲染结果. 注意:Mac ...
- NGUI Camera's raycast hit through the UI Layer issue
Raycast into GUI?http://forum.unity3d.com/threads/raycast-into-gui.263397/ << ; Ray myray = UI ...
- Android开发UI之给ListView设置布局动画效果
1.通过JAVA代码添加,资源文件基本上不修改 XML文件,只添加了一个ListView,就不贴XML文件的代码了. java代码: public class MainActivity extends ...
- UI设计篇·入门篇·简单动画的实现,为布局设置动画,用XML布置布局动画
不仅仅控件可以设置动画,一个布局也可以设置动画, 当给一个布局设置了动画的时候,这个布局里所包含的控件都会依赖执行这些动画. 为布局设置动画的实现步骤: 1.新建一个动画,设置需要实现的形式 2.新建 ...
- UI设计篇·入门篇·简单动画的实现,透明动画/旋转动画/移动动画/缩放动画,混合动画效果的实现,为动画设置监听事件,自定义动画的方法
基本的动画构成共有四种:透明动画/旋转动画/移动动画/缩放动画. 配置动画的方式有两种,一种是直接使用代码来配置动画效果,另一种是使用xml文档配置动画效果 相比而言,用xml文档写出来的动画效果,写 ...
- iOS CoreAnimation详解(一) 有关Layer的动画
以前由于项目需要 也写了一些动画 ,但是知识不系统,很散.这段时间趁着项目完成的空袭,来跟着大神的脚步系统的总结一下iOS中Core Animation的知识点. 原博客地址:http://blog. ...
随机推荐
- R中的data.table 快速上手入门
data.table包提供了一个非常简洁的通用格式:DT[i,j,by]. 可以理解为:对于数据集DT,选取子集行i,通过by分组计算j. 对比与dplyr等包,data.table的运行速度更快. ...
- laravel command命令行
生成类 为了创建一个新命令,你可以使用Artisan中的 command:make 命令生成一个骨架作为你的起点: 生成一个命令类 php artisan command:make FooComman ...
- go——切片
切片(slice)可以看作一种对数组的包装形式,它包装的数组为该切片的底层数组.反过来讲,切片是针对其底层数组中某个连续片段的描述,下面的代码声明了一个切片类型的变量: var ips = []str ...
- Nhibernate工具Profiler配置
1.使用之前需要确认Framework的Version,如果是4.0那么使用如下程序集需要在 创建ISessionFactory的项目中引用NHProfiler安装目录下的 HibernatingRh ...
- c# Datagridview 设置单位格为编辑状态(in editing mode)
private void dataGridView1_KeyDown(object sender, KeyEventArgs e) { if (e.KeyCode == Keys.Tab && ...
- LeetCode:棒球比赛【682】
LeetCode:棒球比赛[682] 题目描述 你现在是棒球比赛记录员.给定一个字符串列表,每个字符串可以是以下四种类型之一:1.整数(一轮的得分):直接表示您在本轮中获得的积分数.2. " ...
- 表单向controller传值如果没填controller取到的是null
jsp前端表单,向controller传数据,如果没有值,后台传入的是null,比如checkbox未选中,后台设置的Integer[] ids,接收到的ids=null,hidden标签如果没有值, ...
- hadoop12---java并发编程的一些总结
java并发编程的一些总结 %.1.不应用线程池的缺点 有些开发者图省事,遇到需要多线程处理的地方,直接new Thread(...).start(),对于一般场景是没问题的,但如果是在并发请求很高 ...
- input-file 部分手机不能拍照问题
曾经遇到一个需求,用户拍身份证上传验证, 然后我卡在了拍照这个点上. 最初采用的是微信的 api,wx.chooseImage, 但随后发现,返回的是一种只有微信才能预览的 url 格式, 但验证是要 ...
- Spring 之通过 XML 装配 bean
1.关于 使用传统标签还是 c- p- 命名空间定义的标签, 我的观点是能用 c- p- 命名空间定义的标签 就不用 传统标签(这样会比较简洁... 2.强依赖使用构造器注入,可选性依赖使用属性注入 ...