IOS 动画的各种实现方法
#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 动画的各种实现方法的更多相关文章
- ios 动画效果CATransition笔记
初学ios开发,很多概念还不清楚,所以只有边学边做例子.又怕学了后面忘了前面,因此用自己的博客来纪录自己的学习历程,也是对自己学习不要懈怠做个监督. 刚学ios做动画效果.因为ios封装得很好,实现i ...
- (转)iOS动画Core Animation
文章转载:http://blog.sina.com.cn/s/blog_7b9d64af0101b8nh.html 在iOS中动画实现技术主要是:Core Animation. Core Animat ...
- 解析 iOS 动画原理与实现
这篇文章不会教大家如何实现一个具体的动画效果,我会从动画的本质出发,来说说 iOS 动画的原理与实现方式. 什么是动画 动画,顾名思义,就是能“动”的画.人的眼睛对图像有短暂的记忆效应,所以当眼睛看到 ...
- IOS动画隐式,显式,翻页
// ViewController.m // IOS动画0817 // // Created by 张艳锋 on 15/8/17. // Copyright (c) 2015年 张艳锋. Al ...
- iOS动画篇:UIView动画
iOS的动画效果一直都很棒很,给人的感觉就是很炫酷很流畅,起到增强用户体验的作用.在APP开发中实现动画效果有很多种方式,对于简单的应用场景,我们可以使用UIKit提供的动画来实现. UIView动画 ...
- iOS动画原理
1. iOS动画原理 本质:动画对象(这里是UIView)的状态,基于时间变化的反应 分类:可以分为显式动画(关键帧动画和逐帧动画)和隐式动画 关键帧和逐帧总结:关键帧动画的实现方式,只需要修改某个属 ...
- iOS 动画基础
原文:http://www.cnblogs.com/lujianwenance/p/5733846.html 今天说一下有关动画的基础,希望能帮助到一些刚接触iOS动画或者刚开始学习iOS的同学, ...
- IOS动画总结
IOS动画总结 一.基本方式:使用UIView类的UIViewAnimation扩展 + (void)beginAnimations:(NSString *)animationID context ...
- IOS 动画专题 --iOS核心动画
iOS开发系列--让你的应用“动”起来 --iOS核心动画 概览 通过核心动画创建基础动画.关键帧动画.动画组.转场动画,如何通过UIView的装饰方法对这些动画操作进行简化等.在今天的文章里您可以看 ...
随机推荐
- hdu5879 Cure
题目链接:hdu5879 Cure 题解:用字符串输入.n很大时答案趋近与(π^2)/6. #include<cstdio> #include<algorithm> #incl ...
- 5月4日课堂内容:for循环的穷举、迭代
一.for循环拥有两类: 1.穷举: 把所有可能的情况都走一遍,使用if条件筛选出来满足条件的情况. 2.迭代: 从初始情况按照规律不断求解中间情况,最终推导出结果. 二.穷举练习 1.单位给发了一张 ...
- java使用dom4j解析xml文件
关于xml的知识,及作用什么的就不说了,直接解释如何使用dom4j解析.假如有如下xml: dom4j解析xml其实很简单,只要你有点java基础,知道xml文件.结合下面的xml文件和java代码, ...
- sed 替换
sed -i 's/i=0/i=2/g' test2.sh -i 在当前文档替换 g 替换所有文档 sed -i '3s/cccc/ccccc/' a.txt 将第三行的 cccc 替换成 ccccc ...
- 重点关注之Filter的使用(性能计数和错误处理)
Web API中的filter与MVC中的filter非常类似,最主要的不同是,MVC中的filter放在命名空间System.Web.Mvc下,而Web API中的filter则放在命名空间Syst ...
- treap 1286郁闷的出纳员.cpp
#include<cstdio>#include<cstdlib>#include<ctime>struct shu{ int l,r,sum,zhi,dui;}a ...
- 主机无法访问虚拟机上的elasticsearch服务器
问题: es在linux上搭建好,通过curl -XGET ip:port可以获得服务器信息展示,但是主机在浏览器上无法访问. 原因: 主机通过telnet访问linux的80端口,发现是不通的.可以 ...
- NOIP 2003解题报告
第一题(神经网络): 题目大意,给出一些点,每个点都有2个值,c和u,给出一些有向边,权值为w.入度为0的点的c已知,其它点的c未知,每个入度不为0的点node的c等于sum(c[k]*w[k][no ...
- Zooming MKMapView to fit annotation pins
http://stackoverflow.com/questions/4680649/zooming-mkmapview-to-fit-annotation-pins - (MKCoordinateR ...
- ASP.Net Chart Control -----Bar and Column Charts
StackedBar StackedColumn StackedArea <asp:CHART id="Chart1" runat="server" H ...