#import "ViewController.h"
#import <QuartzCore/QuartzCore.h>

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    //创建一个
    UIView *view=[[UIView alloc]init];
    view.backgroundColor=[UIColor redColor];
    [self.view addSubview:view];
    view.tag=1001;
    
    //top 200 dowm 200 left 40 right 40
    [view setTranslatesAutoresizingMaskIntoConstraints:NO];
    NSArray *constraintH= [NSLayoutConstraint constraintsWithVisualFormat:@"H:|-40-[view]-40-|" options: 0 metrics:Nil views:NSDictionaryOfVariableBindings(view)];
    NSArray *constraintV=[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-200-[view(>=30)]-200-|" options:0 metrics:nil views:NSDictionaryOfVariableBindings(view)];
    [self.view addConstraints:constraintH];
    [self.view addConstraints:constraintV];
    
    UIButton *button=[UIButton buttonWithType:UIButtonTypeRoundedRect];
    [self.view addSubview:button];
    [button setTitle:@"开始动画" forState:UIControlStateNormal];
    [button setTranslatesAutoresizingMaskIntoConstraints:NO];
    NSArray *contraintButtonH=[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-40-[button(>=100)]-40-|" options:0 metrics:nil views:NSDictionaryOfVariableBindings(button)];
    NSArray *contraintButtonV=[NSLayoutConstraint constraintsWithVisualFormat:@"V:[button(30)]-20-[view]" options:0 metrics:nil views:NSDictionaryOfVariableBindings(button,view)];
    [self.view addConstraints:contraintButtonH];
    [self.view addConstraints:contraintButtonV];
    [button addTarget:self action:@selector(didClickAnimationButton:) forControlEvents:UIControlEventTouchUpInside];
    // Do any additional setup after loading the view, typically from a nib.
}

-(void)didClickAnimationButton:(UIButton *)button
{
    //获取要承载动画的视图..
    UIView *redView=[self.view viewWithTag:1001];
    /*
    //使用uiview类方法--1
    [UIView animateWithDuration:0.25 delay:0 options:UIViewAnimationOptionCurveEaseInOut animations:^{
        //视图的最终状态
        CGFloat r=arc4random()%1000/1000.f;
        CGFloat g=arc4random()%1000/1000.f;
        CGFloat b=arc4random()%1000/1000.f;
        
        redView.backgroundColor=[UIColor colorWithRed:r green:g blue:b alpha:1.0f];
        
        
        //加旋转
//        redView.transform=CGAffineTransformMakeRotation(M_PI_2*r);
        
    } completion:^(BOOL finished) {
        NSLog(@"finished....");
    }];
     */
    
    /*
    //使用UIView类方法2
    //开始设置动画
    [UIView beginAnimations:nil context:nil];
    //设置过渡效果是否从当前状态开始启动,否则为当前视图的最终状态开始启动
    [UIView setAnimationBeginsFromCurrentState:YES];
    //设置过渡效果的进度,慢入慢出,慢入,慢出,线性4中
    [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
    //设置过渡效果对否延迟
    [UIView setAnimationDelay:0];
    //设置过渡效果的过渡时间
    [UIView setAnimationDuration:0.25f];
    //设置过渡效果是否自动恢复
    [UIView setAnimationRepeatAutoreverses:YES];
    //设置过渡效果是否重复出现
    [UIView setAnimationRepeatCount:1.5];
    
    //设置
    [UIView setAnimationDelegate:self];
    [UIView setAnimationWillStartSelector:@selector(animationStart)];
    [UIView setAnimationDidStopSelector:@selector(animationStop)];
    
    
    CGFloat x=arc4random()%100+100;
    CGFloat y=arc4random()%100+100;
    redView.center=CGPointMake(x, y );
    
   // button.center=CGPointMake(x, y );
   // [button layoutIfNeeded];
    //提交过度动画效果
    [UIView commitAnimations];
     
     */
    
    /*
    //使用quartzCore框架内的对象--3
    //实例化过度对象
    CATransition *animation=[CATransition animation];
    //设置过度对象的时间
    animation.duration=0.5f;
    //设置过度对象的类型
    animation.type=kCATransitionFade;
    //设置过度对象的子类型
    //animation.subtype=
    [redView.layer addAnimation:animation forKey:nil];
    redView.layer.opacity=0.0f;//设置透明度
    */
    
    /*
    CABasicAnimation *animation=[CABasicAnimation animationWithKeyPath:@"anchorPoint"];
//    /设置过度对象的时间间隔
    animation.duration=0.5f;
    //设置过度对象的开始值
    animation.fromValue=[NSValue valueWithCGPoint:CGPointMake(0.5, 0.5)];
    animation.toValue=[NSValue valueWithCGPoint:CGPointMake(1.0, 1.0)];
    //将过度对象添加到视图层上
    [redView.layer addAnimation:animation forKey:nil];
    //设置视图层的最终状态
    redView.layer.anchorPoint=CGPointMake(1.0f, 1.0f);
     */
    
    
    
    /*
//    keyframe
    CAKeyframeAnimation *animation=[CAKeyframeAnimation animationWithKeyPath:@"position"];
    //设置过度对象时间间隔
    animation.duration=1;
    //设置过度对象的中间过度状态
    CGMutablePathRef path = CGPathCreateMutable();
    CGPathMoveToPoint(path, nil, 110, 200);
    CGPathAddQuadCurveToPoint(path, nil, 150, 250, 200, 200);
    animation.path=path;
    //将过度对象添加到视图
    [redView.layer addAnimation:animation forKey:nil];
     */
    
}

-(void)animationStart
{
    NSLog(@"begin-------------------");
}
-(void)animationStop
{
    NSLog(@"end--++++++++++++++++++++++++++++");
}

IOS 动画的各种实现方法的更多相关文章

  1. ios 动画效果CATransition笔记

    初学ios开发,很多概念还不清楚,所以只有边学边做例子.又怕学了后面忘了前面,因此用自己的博客来纪录自己的学习历程,也是对自己学习不要懈怠做个监督. 刚学ios做动画效果.因为ios封装得很好,实现i ...

  2. (转)iOS动画Core Animation

    文章转载:http://blog.sina.com.cn/s/blog_7b9d64af0101b8nh.html 在iOS中动画实现技术主要是:Core Animation. Core Animat ...

  3. 解析 iOS 动画原理与实现

    这篇文章不会教大家如何实现一个具体的动画效果,我会从动画的本质出发,来说说 iOS 动画的原理与实现方式. 什么是动画 动画,顾名思义,就是能“动”的画.人的眼睛对图像有短暂的记忆效应,所以当眼睛看到 ...

  4. IOS动画隐式,显式,翻页

    //  ViewController.m //  IOS动画0817 // //  Created by 张艳锋 on 15/8/17. //  Copyright (c) 2015年 张艳锋. Al ...

  5. iOS动画篇:UIView动画

    iOS的动画效果一直都很棒很,给人的感觉就是很炫酷很流畅,起到增强用户体验的作用.在APP开发中实现动画效果有很多种方式,对于简单的应用场景,我们可以使用UIKit提供的动画来实现. UIView动画 ...

  6. iOS动画原理

    1. iOS动画原理 本质:动画对象(这里是UIView)的状态,基于时间变化的反应 分类:可以分为显式动画(关键帧动画和逐帧动画)和隐式动画 关键帧和逐帧总结:关键帧动画的实现方式,只需要修改某个属 ...

  7. iOS 动画基础

    原文:http://www.cnblogs.com/lujianwenance/p/5733846.html   今天说一下有关动画的基础,希望能帮助到一些刚接触iOS动画或者刚开始学习iOS的同学, ...

  8. IOS动画总结

    IOS动画总结   一.基本方式:使用UIView类的UIViewAnimation扩展 + (void)beginAnimations:(NSString *)animationID context ...

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

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

随机推荐

  1. NT内存

    在NT/2K/XP中,操作系统利用虚拟内存管理技术来维护地址空间映像,每个进程分配一个4GB的虚拟地址空间.运行在用户态的应用程序,不能直接访问物理内存地址:而运行在核心态的驱动程序,能将虚拟地址空间 ...

  2. HDUOJ----1234 开门人和关门人(浙江大学考研题)

    开门人和关门人 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  3. hiphop-php 搭建 (CentOS)

    前提:只支持64位系统 升级GCC: https://github.com/jackywei/HOW-TO-BUILD-HHVM-WiKi/wiki/Build-&-Install-GCC4. ...

  4. PLSQL DEVELOPER 连接远程数据库 OCI客户端安装方法

    安装使用过PLSQL Dev都知道,要连接数据库,必须配置TNS(Transparence Network Substrate),而直接安装PLSQL Dev 之后,本机是没有Oracle HOME的 ...

  5. Collecting Bugs(POJ 2096)

    Collecting Bugs Time Limit: 10000MS   Memory Limit: 64000K Total Submissions: 3064   Accepted: 1505 ...

  6. YanYan Self Introduction

      My Website: http://finehappy.com/

  7. php定时执行PHP脚本一些方法总结

    本文章总结了php定时执行PHP脚本一些方法总结,有,linux中,windows,php本身的方法,有需要的朋友可参考参考. linux下定时执行php脚本 执行PHP脚本 方法1如果你想定时执行某 ...

  8. 安卓Json介绍(转)。

    1.JSON(JavaScript Object Notation) 定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式, ...

  9. PHP慢脚本日志和Mysql的慢查询日志(转)

      1.PHP慢脚本日志 间歇性的502,是后端 PHP-FPM 不可用造成的,间歇性的502一般认为是由于 PHP-FPM 进程重启造成的. 在 PHP-FPM 的子进程数目超过的配置中的数量时候, ...

  10. 套汇问题 Floyd

    问题:套汇. 思路:Floyd 代码: #include <cstdio> #include <cstdlib> #include <ctime> #define ...