CoreAnimation 核心动画一 (一些常用属性 和 方法)
1、常用属性:
frame bounds center alpha Transition 过渡 transform 动画效果
2、常用方法:
+(void)setAnimationDelegate:(id)delegate;
+(void)setAnimationWillStartSelector:(SEL)selector; 当动画结束的时候,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector
+ (void)setAnimationDidStopSelector:(SEL)selector; 当动画结束时,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector
+ (void)setAnimationDuration:(NSTimeInterval)duration; 动画的持续时间,秒为单位
+ (void)setAnimationDelay:(NSTimeInterval)delay; 动画延迟delay秒后再开始
+ (void)setAnimationStartDate:(NSDate *)startDate; 动画的开始时间,默认为now
+ (void)setAnimationCurve:(UIViewAnimationCurve)curve; 动画的节奏控制(过渡)
+ (void)setAnimationRepeatCount:(float)repeatCount; 动画的重复次数
+ (void)setAnimationRepeatAutoreverses:(BOOL)repeatAutoreverses; 如果设置为YES,代表动画每次重复执行的效果会跟上一次相反
+ (void)setAnimationTransition:(UIViewAnimationTransition)transition forView:(UIView *)view cache:(BOOL)cache; 设置视图view的过渡效果, transition指定过渡类型, cache设置YES代表使用视图缓存,性能较好
#import "ViewController.h" @interface ViewController ()
{
UIImageView *imageView;
}
@end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; imageView = [[UIImageView alloc]initWithFrame:self.view.frame];
imageView.image = [UIImage imageNamed:@"7.jpg"];
// imageView.contentMode = UIViewContentModeScaleAspectFit;
[self.view addSubview:imageView]; UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
button.frame = CGRectMake(, , , );
button.center = self.view.center;
button.backgroundColor = [UIColor brownColor];
[button addTarget:self action:@selector(viewAnimation3) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:button]; } #pragma mark -- 1、frame bounds center alpha ---
- (void)viewAnimation1 {
#pragma mark - 方法1
// 在一段时间内 执行完命令
// [UIView animateWithDuration:3 animations:^{
// imageView.alpha = 0.5;
// }]; #pragma mark - 方法2
// 开始动画
[UIView beginAnimations:@"animation" context:nil]; // 这只动画的持续时间
[UIView setAnimationDuration:]; // ..... 动画效果
imageView.alpha = 0.5;
imageView.bounds = CGRectMake(, , , );
imageView.center = CGPointMake(, );
// imageView.frame = CGRectMake(100, 100, 100, 100); // 提交动画 会去执行动画
[UIView commitAnimations];
} #pragma mark - 2、Transition
/*
typedef NS_ENUM(NSInteger, UIViewAnimationTransition) {
UIViewAnimationTransitionNone,
UIViewAnimationTransitionFlipFromLeft, 从左面翻转
UIViewAnimationTransitionFlipFromRight,从右面翻转
UIViewAnimationTransitionCurlUp, 向上翻页
UIViewAnimationTransitionCurlDown,向下翻页
};
*/
- (void)viewAnimation2 {
// 开始动画
[UIView beginAnimations:nil context:nil];
// 设置动画持续时间
// [UIView setAnimationDuration:3];
// 设置 UIView 的过渡动画
[UIView setAnimationTransition:UIViewAnimationTransitionCurlUp forView:imageView cache:YES]; #pragma mark - 3、UIViewAnimationCurve
/*
typedef NS_ENUM(NSInteger, UIViewAnimationCurve) {
UIViewAnimationCurveEaseInOut, // slow at beginning and end 慢进慢出
UIViewAnimationCurveEaseIn, // slow at beginning 快进
UIViewAnimationCurveEaseOut, // slow at end 快出
UIViewAnimationCurveLinear 匀速
};
*/
[UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
// 设置 代理(检测动画结束)
[UIView setAnimationDelegate:self];
[UIView setAnimationDidStopSelector:@selector(finishAnimation)];
// 提交动画
[UIView commitAnimations]; } // 动画结束之后触发的方法
- (void)finishAnimation {
[UIView beginAnimations:@"o" context:nil];
[UIView setAnimationDuration:];
imageView.alpha = 0.1;
imageView.bounds = CGRectZero;
imageView.center = CGPointMake(, ); [UIView commitAnimations];
} #pragma mark - 4、transform
/*
imageView.transform=CGAffineTransformScale(imageView.transform, 0.5, 0.5); // 实现的是放大和缩小imageView.transform=CGAffineTransformRotate(imageView.transform, M_PI_4); //实现的是旋转 imageView.transform=CGAffineTransformTranslate(imageView.transform, 20, 0); //实现的是平移
*/
- (void)viewAnimation3 { [UIView beginAnimations:@"animation" context:nil];
[UIView setAnimationDuration:];
// transform 如果没有还原transform 他会保持 改变后的模样
imageView.transform = CGAffineTransformScale(imageView.transform, 0.5, 0.5); [UIView setAnimationDelegate:self];
[UIView setAnimationDidStopSelector:@selector(restore)];
[UIView commitAnimations]; } - (void)restore {
[UIView animateWithDuration: animations:^{
imageView.transform = CGAffineTransformIdentity; }];
}
模拟器效果截图:
方法一效果图:

方法二效果图:

方法三效果图:

CoreAnimation 核心动画一 (一些常用属性 和 方法)的更多相关文章
- iOS开发CoreAnimation解读之一——初识CoreAnimation核心动画编程
iOS开发CoreAnimation解读之一——初识CoreAnimation核心动画编程 一.引言 二.初识CoreAnimation 三.锚点对几何属性的影响 四.Layer与View之间的关系 ...
- UIView的一些常用属性和方法
UIView的一些常用属性和方法 1. UIView的属性 UIView继承自UIResponder,拥有touches方法. - (instancetype)initWithFrame:(CGRec ...
- SVG DOM常用属性和方法介绍(1)
12.2 SVG DOM常用属性和方法介绍 将以Adobe SVG Viewer提供的属性和方法为准,因为不同解析器对JavaScript以及相关的属性和方法支持的程度不同,有些方法和属性是某个解析 ...
- 第190天:js---String常用属性和方法(最全)
String常用属性和方法 一.string对象构造函数 /*string对象构造函数*/ console.log('字符串即对象');//字符串即对象 //传统方式 - 背后会自动将其转换成对象 / ...
- Node.js process 模块常用属性和方法
Node.js是常用的Javascript运行环境,本文和大家发分享的主要是Node.js中process 模块的常用属性和方法,希望通过本文的分享,对大家学习Node.js http://www.m ...
- ios基础篇(四)——UILabel的常用属性及方法
UILabel的常用属性及方法:1.text //设置和读取文本内容,默认为nil label.text = @”文本信息”; //设置内容 NSLog(@”%@”, label.text); //读 ...
- UITableView常用属性和方法 - 永不退缩的小白菜
UITableView常用属性和方法 - 永不退缩的小白菜 时间 2014-05-27 01:21:00 博客园精华区原文 http://www.cnblogs.com/zhaofucheng11 ...
- UIView常用属性与方法/UIKit继承结构
UIView常用属性与方法 @interface UIView : UIResponder<NSCoding, UIAppearance, UIAppearanceContainer, UIDy ...
- JavaScript中Number常用属性和方法
title: JavaScript中Number常用属性和方法 toc: false date: 2018-10-13 12:31:42 Number.MAX_VALUE--1.79769313486 ...
随机推荐
- 【PAT】1029. Median (25)
Given an increasing sequence S of N integers, the median is the number at the middle position. For e ...
- replace into
讨人喜欢的 MySQL replace into 用法(insert into 的增强版) 在向表中插入数据的时候,经常遇到这样的情况:1. 首先判断数据是否存在: 2. 如果不存在,则插入:3.如果 ...
- Redis_字典
阅读本文之前要了解的两件事情,第一,Redis是一种Key-Value数据库,第二,字典是一种保存键值对的抽象数据结构.所以不难猜出字典在Redis中应用一定很广泛,实际上,Redis数据库的底层实现 ...
- 【转】SoapUI5.0创建WebService接口模拟服务端
原文:http://blog.csdn.net/a19881029/article/details/26348627 使用SoapUI创建WebService接口模拟服务端需要接口描述文件 MathU ...
- 微信公共服务平台开发(.Net 的实现)11-------客服消息(定项消息推送 重要的OPENID)
这次我们来一起研究一下“客服消息”,首先明确一下“客服消息”的概念.这不同于之前的“被动响应消息”,也就是说并不是之前“你一言我一语的即时响应”,可能在某种情况下你需要给不同的人主动发送消息,例如你的 ...
- [Angular2 Router] Using snapshot in Router
In the application, we have heros list, when click each hero, will redirect to hero detail view. Tha ...
- UNIX/Linux网络编程基础:图解TCP/IP协议栈
目录 1.主机到网络层协议:以太网协议 2.IP协议 3.网际控制报文协议(ICMP) 4.传输控制协议(TCP) 5.用户数据报文协议(UDP) 6.流控制传输协议(SCTP) 7.地址解析协议(A ...
- QtInternal 之 高效使用QString
注意:本文翻译自 http://developer.qt.nokia.com 中的 UsingQStringEffectively ,中文译文见 简体中文版 ,如果你对翻译wiki感兴趣 ...
- shell导出和导入redis
1.导出redis #!/bin/bash REDIS_HOST=localhost REDIS_PORT=6379 REDIS_DB=1 KEYNAME=redis:hash:* KEYFILE=k ...
- SPA初试-1
本篇内容是在上一次的基础上进行改进,对状态的定义进行了修改,一个状态的定义如下: function state(stateName, template, templateUrl) { this.sta ...