热门标签 | HotTags
当前位置:  开发笔记 > IOS > 正文

iOS动画特效之立方体翻转

今天起为大家带来iOS动画特效合集之立方体翻转,APP如美女,动画如衣裳,赶紧为她披上漂亮的衣装吧!

先来看看效果:

下面进入正题,是时候展现真正的技术了:

首先在控制器里添加一个scrollView,再在scrollView上的对应位置上添加要展示的imageView(立方体视图组),当然也可以放上其它子控制器的view实现更多功能这个随意不是重点

//*******添加scrollView*******
  [self createScrollView];

//******创建立方体视图组******
  [self createCubicViewArray];
//添加视图到scrollView上
  for (int i=0; i<_viewArray.count; i++) {

    UIImageView *transView=_viewArray[i];

    //视图在scrollView上对应的位置
    transView.x=self.view.bounds.size.width * i;

监听scrollView的滑动事件,在这里要先获取到显示的当前页、上一页、下一页,然后让这三个页面同时做3DTransform变换

#pragma mark - scrollView滑动事件
-(void)scrollViewDidScroll:(UIScrollView *)scrollView{

  //当前页数
  NSInteger currentPage=_currentPage;

  //当前视图
  UIView *currentView=_viewArray[currentPage];

  //上一个视图
  UIView *lastView=nil;

  if (currentPage-1>=0) {

    lastView=_viewArray[currentPage-1];
  }

  //下一个视图控制器视图
  UIView *nextView;

  if (currentPage+1<=3) {

    nextView=_viewArray[currentPage+1];
  }

  //本次偏移距离
  CGFloat currentOffset=scrollView.contentOffset.x-currentPage*self.view.bounds.size.width;

  //本次偏移角度
  CGFloat deltaAngle=currentOffset/self.view.bounds.size.width * M_PI_2;

  //****************当前视图移动变幻***************

  //设置锚点
  currentView.layer.anchorPoint=CGPointMake(0.5, 0.5);

  //向屏幕前方移动
  CATransform3D move = CATransform3DMakeTranslation(0, 0, self.view.bounds.size.width/2);

  //旋转
  CATransform3D rotate = CATransform3DMakeRotation(-deltaAngle, 0, 1, 0);

  //平移
  CATransform3D plaintMove=CATransform3DMakeTranslation( currentOffset, 0, 0);

  //向屏幕后方移动
  CATransform3D back = CATransform3DMakeTranslation(0, 0, -self.view.bounds.size.width/2);

  //连接
  CATransform3D cOncat=CATransform3DConcat( CATransform3DConcat(move, CATransform3DConcat(rotate, plaintMove)),back);

  CATransform3D transform=CATransform3DPerspect(concat, CGPointMake(currentOffset/2, self.view.bounds.size.height), 5000.0f);

  //添加变幻特效
  currentView.layer.transform=transform;

  //****************下一个视图移动变幻***************

  //设置锚点
  nextView.layer.anchorPoint=CGPointMake(0.5, 0.5);

  //向屏幕前方移动
  CATransform3D move2 = CATransform3DMakeTranslation(0, 0, self.view.bounds.size.width/2);

  //旋转
  CATransform3D rotate2 = CATransform3DMakeRotation(-deltaAngle+M_PI_2, 0, 1, 0);

  //平移
  CATransform3D plaintMove2=CATransform3DMakeTranslation( currentOffset-self.view.bounds.size.width, 0, 0);

  //向屏幕后方移动
  CATransform3D back2 = CATransform3DMakeTranslation(0, 0, -self.view.bounds.size.width/2);

  //拼接
  CATransform3D concat2=CATransform3DConcat( CATransform3DConcat(move2, CATransform3DConcat(rotate2, plaintMove2)),back2);

  CATransform3D transform2=CATransform3DPerspect(concat2, CGPointMake(self.view.bounds.size.width/2+currentOffset/2, self.view.bounds.size.height), 5000.0f);

  //添加变幻特效
  nextView.layer.transform=transform2;

  //****************上一个视图移动变幻***************

  //设置锚点
  lastView.layer.anchorPoint=CGPointMake(0.5, 0.5);

  //向屏幕前方移动
  CATransform3D move3 = CATransform3DMakeTranslation(0, 0, self.view.bounds.size.width/2);

  //旋转
  CATransform3D rotate3 = CATransform3DMakeRotation(-deltaAngle-M_PI_2, 0, 1, 0);

  //平移
  CATransform3D plaintMove3=CATransform3DMakeTranslation( currentOffset+self.view.bounds.size.width, 0, 0);

  //向屏幕后方移动
  CATransform3D back3 = CATransform3DMakeTranslation(0, 0, -self.view.bounds.size.width/2);

  //拼接
  CATransform3D concat3=CATransform3DConcat(CATransform3DConcat(move3, CATransform3DConcat(rotate3, plaintMove3)),back3);

  CATransform3D transform3=CATransform3DPerspect(concat3, CGPointMake(-self.view.bounds.size.width/2+currentOffset/2, self.view.bounds.size.height), 5000.0f);

  //添加变幻特效
  lastView.layer.transform=transform3;
}

这里记得要复原一下3D变换,不然滑快了会出现页面错乱

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{

  //改变选中页序号
  [self changeIndex];

  //3D变幻恢复原状态
  for (UIView * view in _viewArray) {

    view.layer.transform=CATransform3DIdentity;
  }
}

对了,记得添加一个很重要的透视变换函数,核心在于仿射矩阵的m34属性,这样才会产生远小近大的3D效果,让动画更炫酷

//3D透视函数
CATransform3D CATransform3DMakePerspective(CGPoint center, float disZ)
{
  CATransform3D transToCenter = CATransform3DMakeTranslation(-center.x, -center.y, 0);
  CATransform3D transBack = CATransform3DMakeTranslation(center.x, center.y, 0);
  CATransform3D scale = CATransform3DIdentity;
  scale.m34 = -1.0f/disZ;
  return CATransform3DConcat(CATransform3DConcat(transToCenter, scale), transBack);
}

这一篇文章就到这里了,大家有什么意见和问题记得及时反馈,希望本文对大家开发IOS有所帮助。


推荐阅读
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 如何高效创建和使用字体图标
    在Web和移动开发中,为什么选择字体图标?主要原因是其卓越的性能,可以显著减少HTTP请求并优化页面加载速度。本文详细介绍了从设计到应用的字体图标制作流程,并提供了专业建议。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文将详细介绍在Windows 7环境下,检查U盘启动盘是否制作成功的多种方法,包括通过BIOS设置和使用模拟启动工具。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
author-avatar
otion
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有