iOS图片折叠效果:Layer的contentsRect属性和渐变层
http://www.cocoachina.com/ios/20150722/12622.html

作者:@吖了个峥 授权本站转载。
前言
此次文章,讲述的是Layer的一个属性contentsRect,利用它可以控制图层内容的展示,然后还有利用渐变层(CAGradientLayer)做阴影效果。
如果喜欢我的文章,可以关注我,随着后续不断学习Swift中,陆续还会有更新ing....
0.什么是折叠效果?
就是让一张图片的某一部分,沿着X轴或者Y轴旋转,不能拿着整张图片旋转,整张图片会一起旋转,就不会有折叠效果了。但是有个疑问,如何让一整张图片的部分旋转。

1.如何制作图片折叠效果?
把一张图片分成两部分显示,上面一部分,下面一部分,折叠上面部分的内容。
2.如何把一张图片分成两部分显示。
搞两个控件,一个显示上半部分,一个显示下半部分,需要用到Layer(图层)的一个属性contentsRect,这个属性是可以控制图片显示的尺寸,可以让图片只显示上部分或者下部分,注意:取值范围是0~1.
CGRectMake(0, 0, 1, 0.5) : 表示显示上半部分
CGRectMake(0, 0.5, 1, 0.5) : 表示显示下半部分

3.如何快速的把两部分拼接成一张完整的图片。
3.1 首先了解折叠,折叠其实就是旋转,既然需要旋转就需要明确锚点,因为默认都是绕着锚点旋转的。
3.2 上部分内容绕着底部中心旋转,所以设置上部分的锚点为(0.5,1)
3.3 锚点设置好了,就可以确定位置了,这里需要了解其实View的中心点就是layer的position,锚点是决定layer上的哪个点显示在position上。
3.4 可以把上下部分重合在一起,然后分别设置上下部分的锚点,如图红色部分就是position点,上部分图层上的哪个点需要显示到这个位置,由锚点决定,上部分的锚点为(0.5,1),下部分的锚点为(0.5,0),就能快速重叠了。

4.如何折叠上部分内容。
因为整个图片都需要拖动,因此可以创建一个透明的view放在上面,给他提供拖动手势,这样就造成整个图片都能拖动的假象。
在拖动视图的时候,旋转上部分控件。修改transform属性。
可以在上部分和下部分底部添加一个拖动控件(拖动控件尺寸就是完整的图片尺寸),给这个控件添加一个pan手势,就能制造一个假象,拖动控件的时候,折叠图片。
计算Y轴每偏移一点,需要旋转多少角度,假设完整图片尺寸高度为200,当y = 200时,上部分图片应该刚好旋转180°,因此angle = offsetY * M_PI / 200;
上部分内容应该是绕着X轴旋转,逆时针旋转,因此角度需要为负数。
|
1
2
3
4
5
6
7
8
9
|
// 获取手指偏移量 CGPoint transP = [sender translationInView:_containV];// 初始化形变 CATransform3D transform3D = CATransform3DIdentity;// 设置立体效果 transform3D.m34 = -1 / 1000.0;// 计算折叠角度,因为需要逆时针旋转,所以取反 CGFloat angle = -transP.y / 200.0 * M_PI; _topView.layer.transform = CATransform3DRotate(transform3D, angle, 1, 0, 0); |
为了让折叠效果更加有效果,更加具有立体感,可以给形变设置m34属性,就能添加立体感。
|
1
2
|
// 设置M34就有立体感(近大远小)。 -1 / z ,z表示观察者在z轴上的值,z越小,看起来离我们越近,东西越大。transform3D.m34 = -1 / 1000.0; |
反弹效果
当手指抬起的时候,应该把折叠图片还原,其实就是把形变清空。
|
1
2
3
4
5
6
|
if (sender.state == UIGestureRecognizerStateEnded) { // 手指抬起 // 还原 [UIView animateWithDuration:0.5 delay:0 usingSpringWithDamping:0.1 initialSpringVelocity:3 options:UIViewAnimationOptionCurveEaseInOut animations:^{ _topView.layer.transform = CATransform3DIdentity; } completion:nil]; } |
阴影效果
当折叠图片的时候,底部应该有个阴影渐变过程。
利用CAGradientLayer(渐变图层)制作阴影效果,添加到底部视图上,并且一开始需要隐藏,在拖动的时候慢慢显示出来。
颜色应是由透明到黑色渐变,表示阴影从无到有。
|
1
2
3
4
5
6
7
8
9
|
// 创建渐变图层CAGradientLayer *shadomLayer = [CAGradientLayer layer];// 设置渐变颜色 shadomLayer.colors = @[(id)[UIColor clearColor],(id)[[UIColor blackColor] CGColor]]; shadomLayer.frame = _bottomView.bounds; _shadomLayer = shadomLayer;// 设置不透明度 0 shadomLayer.opacity = 0; [_bottomView.layer addSublayer:shadomLayer]; |
在拖动的时候计算不透明度值,假设拖动200,阴影完全显示,不透明度应该为1,因此 opacity = y轴偏移量 * 1 / 200.0;
|
1
2
|
// 设置阴影不透明度 _shadomLayer.opacity = transP.y * 1 / 200.0; |
在手指抬起的时候,需要把阴影设置隐藏,不透明度为0;
|
1
2
3
4
5
6
7
8
|
if (sender.state == UIGestureRecognizerStateEnded) { // 手指抬起 // 还原 [UIView animateWithDuration:0.5 delay:0 usingSpringWithDamping:0.1 initialSpringVelocity:3 options:UIViewAnimationOptionCurveEaseInOut animations:^{ _topView.layer.transform = CATransform3DIdentity; // 还原阴影 _shadomLayer.opacity = 0; } completion:nil]; } |
联系方式
如果你喜欢这篇文章,可以继续关注我,微博:吖了个峥,欢迎交流。
(PS:另外咱们公司小码哥,诚邀IT届有事业心,有能力,有拼劲,有干劲各路英豪加盟一起创业,详情可以点击小码哥,小码哥官方微博,或者微博私聊我)
iOS图片折叠效果:Layer的contentsRect属性和渐变层的更多相关文章
- Swift 2.0 封装图片折叠效果
文/猫爪(简书作者)原文链接:http://www.jianshu.com/p/688c491580e3著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 用Swift封装图片折叠效果 b ...
- iOS开发——UI进阶篇(十八)核心动画小例子,转盘(裁剪图片、自定义按钮、旋转)图片折叠、音量震动条、倒影、粒子效果
一.转盘(裁剪图片.自定义按钮.旋转) 1.裁剪图片 将一张大图片裁剪为多张 // CGImageCreateWithImageInRect:用来裁剪图片 // image:需要裁剪的图片 // re ...
- Core Animation一些Demo总结 (动态切换图片、大转盘、图片折叠、进度条等动画效果)
前一篇总结了Core Animation的一些基础知识,这一篇主要是Core Animation 的一些应用,涉及到CAShapeLayer.CAReplicatorLayer等图层的知识. 先看效果 ...
- WPF设置VistualBrush的Visual属性制作图片放大镜效果
原文:WPF设置VistualBrush的Visual属性制作图片放大镜效果 效果图片:原理:设置VistualBrush的Visual属性,利用它的Viewbox属性进行缩放. XAML代码:// ...
- 淡入淡出(折叠效果)and点击切换背景图片
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- ios图片轮播效果
代码地址如下:http://www.demodashi.com/demo/11959.html ImageCarousel 简单封装的图片轮播器 内存过大由于我加载的图片分辨率较高(4k) 文件目录 ...
- iOS各种动画效果
ios各种动画效果 最普通动画: //开始动画 [UIView beginAnimations:nil context:nil]; //设定动画持续时间 [UIView setAnimationDu ...
- 实现iOS图片等资源文件的热更新化(五): 一个简单完整的资源热更新页面
简介 一个简单的关于页面,有一个图片,版本号,App名称等,着重演示各个系列的文章完整集成示例. 动机与意义 这是系列文章的最后一篇.今天抽空写下,收下尾.文章本身会在第四篇的基础上,简单扩充下代码, ...
- 大屏iPhone的适配 +iOS 图片尺寸要求
摘自:http://blog.ibireme.com/2014/09/16/adapted_to_iphone6/ 苹果公司官网设计介绍到:Retina显示屏的超高像素密度已超过人眼能分辨的范围.Re ...
随机推荐
- 2019-8-31-C++-驱动开发-error-LNK2019-unresolved-external-symbol-__CheckForDebuggerJustMyCode-referenced-...
title author date CreateTime categories C++ 驱动开发 error LNK2019 unresolved external symbol __CheckFor ...
- Luogu P2831 愤怒的小鸟(状压+记忆化搜索)
P2831 愤怒的小鸟 题意 题目描述 Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于\((0,0)\)处,每次Kiana可以用它向第一象限发射 ...
- 【html、CSS、javascript-1】html基础
HTML 翻译成代码如下: web: import socket def handle_request(client): buf = client.recv(1024) client.sendal ...
- phpstudy安装好之后mysql无法启动(亲测可行)
安装好phpstudy后,Apache可以启动,Mysql无法启动. 尝试解决办法:可能是之前已经装过Mysql,要把系统服务里面的MySQL删除,留下MySQLa服务. 在cmd命令行下输入:sc ...
- PyCharm常用技巧集合
PyCharm常用技巧集合 一.添加或者修改文件模板 File>settings>Editor>File and Code Templates>Python Script 你可 ...
- Zookeeper 扫盲
Zookeeper 扫盲 :disappointed_relieved: 配置文件详解: tickTime:基本事件单元,以毫秒为单位,这个时间作为 Zookeeper 服务器之间或客户端之间维持心跳 ...
- Lua 调用C模块DLL失败
Lua中使用 local a = require "xxx" 的方式加载自己用C实现的DLL,DLL中有导出函数 luaopen_xxx . 调试过程中发现,luaopen_xxx ...
- 【CodeVS】1792 分解质因数
1792 分解质因数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 青铜 Bronze 题目描述 Description 编写一个把整数N分解为质因数乘积的程序. 输入描述 Inp ...
- 洛谷P1508 Likecloud-吃、吃、吃 [2017年4月计划 动态规划10]
P1508 Likecloud-吃.吃.吃 题目背景 问世间,青春期为何物? 答曰:“甲亢,甲亢,再甲亢:挨饿,挨饿,再挨饿!” 题目描述 正处在某一特定时期之中的李大水牛由于消化系统比较发达,最近一 ...
- 五.反馈(Hopfield)神经网络
前馈网络一般指前馈神经网络或前馈型神经网络.它是一种最简单的神经网络,各神经元分层排列.每个神经元只与前一层的神经元相连.接收前一层的输出,并输出给下一层,数据正想流动,输出仅由当前的输入和网络权值决 ...