Main.storyboard

ViewController.m

//

//  ViewController.m

//  8A08.动画总结

//

//  Created by huan on 16/2/6.

//  Copyright © 2016年 huanxi. All rights reserved.

//

#import "ViewController.h"

@interface ViewController ()

@property (weak, nonatomic) IBOutlet UIImageView *imageView;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

//打印中心点 position anchorPoint

#warning 默认图层的"position" 就是“控件”的中心点

NSLog(@"中心点 %@",  NSStringFromCGPoint(self.imageView.center));

NSLog(@"position %@",  NSStringFromCGPoint(self.imageView.layer.position));

NSLog(@"anchorPoint %@",  NSStringFromCGPoint(self.imageView.layer.anchorPoint));

}

-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{

//动画总结

//    [self test1];

//    [self test2];

//    [self test3];

//    [self test4];

}

//1. UIView动画

-(void)test1{

[UIView beginAnimations:nil context:nil];

//设置时间

[UIView setAnimationDuration:3];

//监听动画的完成

[UIView setAnimationDelegate:self];

[UIView setAnimationDidStopSelector:@selector(stop)];

//实现动画代码

self.imageView.center = CGPointMake(200, 200);

[UIView commitAnimations];

}

//2.UIView的block动画

-(void)stop{

NSLog(@"%s", __func__);

}

-(void)test2{

[UIView animateWithDuration:3 animations:^{

self.imageView.center = CGPointMake(200, 200);

} completion:^(BOOL finished) {

NSLog(@"动画完成");

}];

}

//3.UIView的转场动画

-(void)test3{

//    UIViewAnimationOptionTransitionNone            = 0 << 20, // default

//    UIViewAnimationOptionTransitionFlipFromLeft    = 1 << 20,

//    UIViewAnimationOptionTransitionFlipFromRight   = 2 << 20,

//    UIViewAnimationOptionTransitionCurlUp          = 3 << 20,

//    UIViewAnimationOptionTransitionCurlDown        = 4 << 20,

//    UIViewAnimationOptionTransitionCrossDissolve   = 5 << 20,

//    UIViewAnimationOptionTransitionFlipFromTop     = 6 << 20,

//    UIViewAnimationOptionTransitionFlipFromBottom  = 7 << 20,

[UIView transitionWithView:self.imageView duration:3 options:UIViewAnimationOptionTransitionFlipFromLeft animations:^{

//更改图片

self.imageView.image = [UIImage imageNamed:@"2.jpg"];

} completion:^(BOOL finished) {

NSLog(@"动画完成");

}];

}

//核心动画  核心动画是一个假象

-(void)test4{

//    self.imageView.image = [UIImage imageNamed:@"2.jpg"];

//    //转场动画

//    CATransition *animation = [CATransition animation];

//    animation.type = @"push";

//

//    [self.imageView.layer addAnimation:animation forKey:nil];

//核心动画是一个假象 给你一个效果(效果之后就恢复)

//平移动画

CABasicAnimation *positionAni = [CABasicAnimation animation];

positionAni.keyPath = @"position";

NSLog(@"核心动画之前的position %@", NSStringFromCGPoint(self.imageView.layer.position));

positionAni.toValue = [NSValue valueWithCGPoint:CGPointMake(200, 300)];

//核心动画 要监听动画完成 设置代理

#warning 核心动画的代理是NSObject的分类,所以不需要遵守协议

positionAni.delegate = self;

[self.imageView.layer addAnimation:positionAni forKey:nil];

}

#pragma mark 核心动画的代理

-(void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag{

//    NSLog(@"动画完成");

NSLog(@"核心动画之后的position %@", NSStringFromCGPoint(self.imageView.layer.position));

}

@end

动画总结(UIView的动画)的更多相关文章

  1. iOS动画-从UIView到Core Animation

    首先,介绍一下UIView相关的动画. UIView普通动画: [UIView beginAnimations: context:]; [UIView commitAnimations]; 动画属性设 ...

  2. IOS 动画专题 --iOS核心动画

    iOS开发系列--让你的应用“动”起来 --iOS核心动画 概览 通过核心动画创建基础动画.关键帧动画.动画组.转场动画,如何通过UIView的装饰方法对这些动画操作进行简化等.在今天的文章里您可以看 ...

  3. iOS开发UI篇—核心动画(UIView封装动画)

    iOS开发UI篇—核心动画(UIView封装动画) 一.UIView动画(首尾) 1.简单说明 UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画 ...

  4. 核心动画与UIView的区别

    核心动画与UIView的区别 1.核心动画只作用于layer,使用核心动画之前,必须有layer 2.核心动画只是假象,并没有移动实际位置 什么时候使用核心动画,什么时候使用UIView动画 1.当不 ...

  5. 核心动画和UIView动画的区别

    核心动画和UIView动画的区别 1.核心动画制作用在Layer 2.核心动画的修改的属性都是假象,他的真实位置没有发生变化()

  6. UIView简单动画

    UIView动态实现的效果有以下几种: 1.动态改变frame 2.动态改变color 3.动态改变alpha 4.动态改变bounds 首先,我们先看几种BasicView动画 #pragma ma ...

  7. ios uiview封装动画(摘录)

    iOS开发UI篇—核心动画(UIView封装动画) 一.UIView动画(首尾) 1.简单说明 UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画 ...

  8. iOS开发——动画编程Swift篇&(一)UIView基本动画

    UIView基本动画 // MARK: - UIView动画 ------------------------------------- // MARK: - UIView动画-淡入 @IBActio ...

  9. IOS UIVIEW layer动画 总结(转)

    转发自:http://www.aichengxu.com/article/%CF%B5%CD%B3%D3%C5%BB%AF/16306_12.html   IOS UIVIEW layer动画 总结, ...

随机推荐

  1. Android菜鸟成长记12 -- ORMLite的简单使用

    在我们的开发中,为了提高开发效率,我们一般都会使用到框架,ormilte则是我们必不可少的数据库框架. 对于ORMLite我也是今天才刚刚接触,我们先从一个简单的项目来了解它吧. ORMLite ja ...

  2. 单位换算(格式化十进制数-B),获取时间工具类CommenUtil

    package com.example.administrator.filemanager.utils;import java.text.DecimalFormat;import java.text. ...

  3. tesseract配置过程

    tesseract配置过程: 1. 为了避免配置环境变量,可以先下载一个 tesseract-ocr-setup-3.02.02.exe(tesseract配置文件夹里有),然后安装(假设安装目录为D ...

  4. <![CDATA[ ]]> 的作用

    在xml文件中 一些特殊字符需要去除其本意,就要用到 <![CDATA[    ]]>,,比如 ibitis的sqlmap.xml 中  要比较大小不能直接用 < 或者 > , ...

  5. java keytool证书工具使用小结

    java keytool证书工具使用小结 在Security编程中,有几种典型的密码交换信息文件格式: DER-encoded certificate: .cer, .crt    PEM-encod ...

  6. eclipse error pages打红X的解决方法

    当我在关闭eclipse时,漫长的等待进度条,我情急之下强关了系统.悲催的是再打开eclipse时新建动态web项目时,总是出现error pages打红X问题,程序执行等都不受影响,就是看着不爽.网 ...

  7. POJ2553

    题意:很难懂!但是大体意思就是求有向图中从一个节点出发到达的点也能反向到达该节点的点.如a能到{b1,b2.....bx}这些点,而这些点也能到a,则a为要求的点.题目是求出所有的这种点. 对图进行缩 ...

  8. 测试webAPP时图标背景一片黑色

    写了个web小程序,打包成APP后安装到手机里,在魅族手机里显示是正常的,但是在EMUI和MIUI中却显示一片黑色,搞了半天才发现原来是因为EMUI会自动给应用的图标裁剪圆角并加上背景色,背景色是系统 ...

  9. C/C++入门---运算符

    1, 运算符的优先级 C语言的运算符共有15个优先级,各运算符及其优先级和结合律如下: 运算符 结合律 ()[]-> 从左到右 !~++ -- +(正号) -(负号) *(指针取址符) (typ ...

  10. 一份不错的vue.js基础笔记!!!!

    第一章 Vue.js是什么? Vue(法语)同view(英语) Vue.js是一套构建用户界面(view)的MVVM框架.Vue.js的核心库只关注视图层,并且非常容易学习,非常容易与其他库或已有的项 ...