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. asp.net LINQ实现数据分页

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  2. Linux Svn 安装过程及配置

    重要的是第一步的安装,第二步配置可能没用,但是没试过,因为服务器上已经安装了第一步. 此处的第二步只为做个记录,说明一下里边的配置文件的用途. 3. 自己实际操作中的的配置记录(参照服务器别人的配置记 ...

  3. miniui中常用的状态显示方式

    1.查询sys_code表得到对应的状态 考生状态:<input class="mini-combobox" style="" textField=&qu ...

  4. oracle 字符转字符串函数

    select cast('addd' as varchar(4)) from dual;

  5. js对象的继承以及公有私有属性的定义和读写

    最近想写一些js工具,有些方面需要用到面向对象的方法,比如继承父类属性和方法.通过私有化隐藏某些对象的属性等,因为没有系统的学习js,所以不知道怎么做,觉得很伤脑筋. 今天受到技术群里朋友的提示,并查 ...

  6. windows与linux之间文件的传输方式总结(转)

    当然,windows与linux之间文件的传输的两种方式有很多,这里就仅仅列出工作中遇到的,作为笔记: 方法一:安装SSH Secure Shell Client客户端 安装即可登录直接拖拉到linu ...

  7. 关于 cellForRor中给cell setSelected的时机问题?

    我在  cell  里边 - (void)setSelected:(BOOL)selected animated:(BOOL)animated { [super setSelected:selecte ...

  8. 一个的unity学习系列的博客

    1.http://my.csdn.net/caoboya 2.http://my.csdn.net/OnafioO

  9. notepad++ 离线插件下载

    http://www.cnblogs.com/findumars/p/5180562.html

  10. 说一说line-height

    line-height这个样式相信大家一定不会陌生,我们经常用它来让文本上下居中,这样做一般不出出现什么问题,但是如果对这个属性不是很熟悉的话,可能会踩到一些坑,今天亲自去试验了一下,并总结了一下li ...