绘制动画,核心动画

暂记......


一、Core Animation简介

(1)Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果

(2)Core Animation的动画执行过程都是在后台操作的,不会阻塞主线程。

(3)Core Animation是直接作用在CALayer上的,并非UIView。

二、Core Animation的使用步骤

1.使用它需要先添加QuartzCore.framework框架和引入主头文件

2.初始化一个CAAnimation对象,并设置一些动画相关属性

3.通过调用CALayer的addAnimation:forKey:方法增加CAAnimation对象到CALayer中,这样就能开始执行动画了

4.通过调用CALayer的removeAnimationForKey:方法可以停止CALayer中的动画

1.过渡动画(转场动画)

CATransition

(1)视图切换

(2)控制器切换

2.关键帧动画

CAKeyframeAnimation

(1)values

(2)path

(3)输入框输入错误动画

(4)视图抖动效果

(5)点赞动画

calculationMode是控制关键帧动画时间的另一种方法。我们通过将其设置为kCAAnimationPaced,让Core Animation向被驱动的对象施加一个恒定速度,不管路径的各个线段有多长。

additive属性为YES能够对所有形式的需要更新的元素重用相同的动画,且无需提前知道它们的位置。

3.基本动画

CABasicAnimation

(1)旋转

(2)摇一摇

byValue和toValue的区别,前者是在当前的位置上增加多少,后者是到指定的位置。

4.CAAnimationGroup动画组

使用函数CGContextAddCurveToPoint去 使用一个三次Bezier 曲线,要我们指定control point和endpoint。下图是一个三次的Bezier曲线,有两个控制点。两个控制点的定义了曲线的几何形状。如果两个控制点都在起点和终点的下 面,则则曲线向上供。如果第二个控制点相比第一个控制点更接近起点,则曲线会构成一个循环。


使用函数CGContextAddQuadCurveToPoint 去使用添加一个二次Bezier曲线,要我们指定一个control point和endpoint。下图展示了相同的endpoint,不同的control point的结果。control point定义了曲线的供的方向。利用二次Bezier曲线不可能创造用三次Bezier曲线那么多的有趣的曲线。例如,用二次不可能创造一个交叉的曲 线。






-(void)addProductsAnimationWithImageView:(UIImageView*)imageView

{

//将rect由rect所在视图转换到目标视图view中,返回在目标视图view中的rect

//把UITableViewCell中的subview(btn)的frame转换到self.view中

CGRectmyFrame = [imageViewconvertRect:imageView.boundstoView:self.view];

//CGFloat Ix = myFrame.origin.x;

//CGFloat Iy = myFrame.origin.y;

//[self.view addSubview:self.imgView];

//self.imgView.frame = CGRectMake(Ix , Iy , 25, 25);

CALayer*layer1 = [[CALayeralloc]init];

layer1.frame= myFrame;

//layer1.frame = self.imgView.frame;

//layer1.contents = self.imgView.layer.contents;

layer1.contents= imageView.layer.contents;

[self.view.layeraddSublayer:layer1];

[self.myLayersArraddObject:layer1];

//*********

// **图片初始的位置

CGPointbeginPoint = layer1.position;

// **购物车左上角圆圆的红点位置

CGPointendPoint =CGPointMake(SCREENWIDTH-SCREENWIDTH/4-SCREENWIDTH/8-6,SCREENHEIGHT-40);

// 2.创建一个CGMutablePathRef的可变路径,并返回其句柄

CGMutablePathRefpath =CGPathCreateMutable();

CGPathMoveToPoint(path,nil, beginPoint.x, beginPoint.y);

CGPathAddCurveToPoint(path,nil, beginPoint.x, beginPoint.y-30, endPoint.x, beginPoint.y-30, endPoint.x, endPoint.y);

//1.创建核心动画

CAKeyframeAnimation*positionAnimation = [CAKeyframeAnimationanimation];

positionAnimation.keyPath=@"position";

positionAnimation.path= path;

//*********

CABasicAnimation*opacityAnimation = [CABasicAnimationanimationWithKeyPath:@"opacity"];

opacityAnimation.fromValue= [NSNumbernumberWithFloat:1];

opacityAnimation.toValue= [NSNumbernumberWithFloat:0.9];

opacityAnimation.fillMode=kCAFillModeForwards;

opacityAnimation.removedOnCompletion=YES;

//*********

CABasicAnimation*transformAnimation = [CABasicAnimationanimationWithKeyPath:@"transform"];

transformAnimation.fromValue= [NSValuevalueWithCATransform3D:CATransform3DIdentity];

transformAnimation.toValue= [NSValuevalueWithCATransform3D:CATransform3DScale(CATransform3DIdentity,0.2,0.2,1)];

//*********

CAAnimationGroup*groupAnimation = [CAAnimationGroupanimation];

//groupAnimation.animations = @[positionAnimation, transformAnimation, opacityAnimation];

groupAnimation.animations= [NSArrayarrayWithObjects:positionAnimation, transformAnimation, opacityAnimation,nil];

groupAnimation.duration=0.8;

groupAnimation.delegate=self;

//**********

[layer1addAnimation:groupAnimationforKey:@"cartParabola"];

//[self.view.layer addAnimation:groupAnimation forKey:nil];

}

#pragma mark -重写方法

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

{

if(self.myLayersArr.count>0) {

CALayer*tempLayer =self.myLayersArr[0];

tempLayer.hidden=YES;

self.imgView.hidden=YES;

[tempLayerremoveFromSuperlayer];

[self.myLayersArrremoveAllObjects];

[self.view.layerremoveAnimationForKey:@"cartParabola"];

}

}

#pragma mark - setter and getter

-(NSMutableArray*)myLayersArr

{

if(!_myLayersArr) {

_myLayersArr= [NSMutableArrayarray];

}

return_myLayersArr;

}

-(UIImageView*)imgView

{

if(!_imgView) {

_imgView= [[UIImageViewalloc]initWithImage:[UIImageimageNamed:@"v2_test_entry_icon"]];

}

return_imgView;

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容