iOS - UIView 动画

简介: 1、UIView 动画核心动画 和 UIView 动画 的区别:核心动画一切都是假象,并不会真实的改变图层的属性值,如果以后做动画的时候,不需要与用户交互,通常用核心动画(转场)。UIView 动画必须通过修改属性的真实值,才有动画效果。

1、UIView 动画

  • 核心动画 和 UIView 动画 的区别:

    • 核心动画一切都是假象,并不会真实的改变图层的属性值,如果以后做动画的时候,不需要与用户交互,通常用核心动画(转场)。
    • UIView 动画必须通过修改属性的真实值,才有动画效果。

1.1 block 方式

  • 设置控件位置、尺寸、透明度等的代码,放在 animateWithDuration: block 中,将自动以动画的方式改变。

        // 开始动画,动画持续时间 2 秒
        [UIView animateWithDuration:1.0 animations:^{
    
            // 设置动画结束后的效果值
    
            // 改变控件的位置和尺寸,改变后的位置或大小
            self.redView.frame = CGRectMake(150, 50, 50, 50);
    
        } completion:^(BOOL finished) {
    
            // 动画完成后的操作
    
            // 开始一个新的动画
            [UIView animateWithDuration:1.0 animations:^{
    
                // 改变控件的位置和尺寸,改变后的位置或大小
                self.redView.frame = CGRectMake(50, 150, 80, 80);
            }];
        }];
    • 效果

      animation66

  • 弹簧效果的动画

        [UIView animateWithDuration:1.0
                              delay:0
             usingSpringWithDamping:0.2
              initialSpringVelocity:0
                            options:UIViewAnimationOptionCurveEaseInOut
                         animations:^{
    
            // SpringWithDamping: 弹性系数,越小弹簧效果越明显
    
            self.redView.frame = CGRectMake(150, 50, 50, 50);
    
        } completion:nil];
    • 效果

      animation83

1.2 动画块方式

  • 设置控件位置、尺寸、透明度等的代码,放在 beginAnimations: 和 commitAnimations 之间,将自动以动画的方式改变。

        // 开始一个动画块
        [UIView beginAnimations:nil context:nil];
    
        // 动画设置
    
            // 设置动画时间
            [UIView setAnimationDuration:1.0];                                      // default = 0.2
    
            // 设置延时
            [UIView setAnimationDelay:0.0];                                         // 设置指定的时间后开始执行动画,default = 0.0
    
            // 设置动画执行节奏
            /*
                UIViewAnimationCurveEaseInOut,         // slow at beginning and end  开始和结束慢速,默认
                UIViewAnimationCurveEaseIn,            // slow at beginning          开始慢速
                UIViewAnimationCurveEaseOut,           // slow at end                结束慢速
                UIViewAnimationCurveLinear             //                            匀速
             */
            [UIView setAnimationCurve:UIViewAnimationCurveLinear];
    
            // 设置重复次数
            [UIView setAnimationRepeatCount:MAXFLOAT];                              // default = 0.0.  May be fractional
    
            // 设置是否自动返回,以动画的方式返回
            [UIView setAnimationRepeatAutoreverses:YES];                            // default = NO. used if repeat count is non-zero
    
            // 设置是否从当前状态开始动画
            [UIView setAnimationBeginsFromCurrentState:YES];                        // default = NO
    
            // 设置代理
            [UIView setAnimationDelegate:self];                                     // default = nil
    
            // 设置动画开始时执行的代理方法,自定义方法
            [UIView setAnimationWillStartSelector:@selector(startAnimations)];      // default = NULL
    
            // 设置动画结束时执行的代理方法,自定义方法
            [UIView setAnimationDidStopSelector:@selector(stopAnimations)];         // default = NULL
    
        // 动画之行后效果值
    
            // 设置透明度,改变后的透明度
            self.redView.alpha = 1.0;
    
            // 改变控件的位置和尺寸,改变后的位置或大小
            self.redView.frame = CGRectMake(150, 150, 80, 80);
    
        // 结束一个动画块
        [UIView commitAnimations];
    
        // 动画开始时执行的代理方法,自定义方法
        - (void)startAnimations {
    
            NSLog(@"startAnimations");
        }
    
        // 动画结束时执行的代理方法,自定义方法
        - (void)stopAnimations {
    
            NSLog(@"stopAnimations");
        }
    • 效果

      animation67

目录
相关文章
|
3月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户点击按钮时,按钮将从圆形变为椭圆形,颜色从蓝色渐变到绿色;释放按钮时,动画以相反方式恢复。通过UIView的动画方法和弹簧动画效果,实现平滑自然的过渡。
94 1
|
4月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
【10月更文挑战第18天】本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户按下按钮时,按钮将从圆形变为椭圆形并从蓝色渐变为绿色;释放按钮时,动画恢复原状。通过UIView的动画方法和弹簧动画效果,实现平滑自然的动画过渡。
79 5
|
5月前
|
Swift iOS开发 UED
揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【9月更文挑战第5天】本文通过具体案例介绍如何在iOS应用中使用Swift与UIKit实现自定义按钮动画,当用户点击按钮时,按钮将从圆形变为椭圆形并从蓝色渐变到绿色,释放后恢复原状。文中详细展示了代码实现过程及动画平滑过渡的技巧,帮助读者提升应用的视觉体验与特色。
87 11
|
6月前
|
Swift iOS开发 UED
【绝妙创意】颠覆你的视觉体验!揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【8月更文挑战第13天】本文通过一个具体案例,介绍如何使用Swift与UIKit在iOS应用中创建独特的按钮动画效果。当按钮被按下时,其形状从圆形变化为椭圆形,颜色则从蓝色渐变为绿色;释放后,动画反向恢复原状。利用UIView动画方法及弹簧动画效果,实现了平滑自然的过渡。通过调整参数,开发者可以进一步优化动画体验,增强应用的互动性和视觉吸引力。
75 7
|
9月前
|
iOS开发
iOS设备功能和框架: 如何使用 Core Animation 创建动画效果?
iOS设备功能和框架: 如何使用 Core Animation 创建动画效果?
156 0
|
编译器 iOS开发 异构计算
读iOS核心动画笔记
读iOS核心动画笔记
71 0
|
API iOS开发
iOS 自定义转场动画 UIViewControllerTransitioning
iOS 自定义转场动画 UIViewControllerTransitioning
131 0
|
iOS开发
iOS 动画绘制圆形
iOS 动画绘制圆形
100 1
|
iOS开发
iOS 常用阅读软件打开书籍的转场动画
iOS 常用阅读软件打开书籍的转场动画
115 0
|
API iOS开发
iOS 核心动画
iOS 核心动画
93 0

热门文章

最新文章

  • 1
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    24
  • 2
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    32
  • 3
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    27
  • 4
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    23
  • 5
    uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
    143
  • 6
    【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
    232
  • 7
    app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
    90
  • 8
    深入探索iOS开发中的SwiftUI框架
    143
  • 9
    ios样式开关按钮jQuery插件
    58
  • 10
    Android与iOS生态差异深度剖析:技术架构、开发体验与市场影响####
    75