【code_小马】OC沿着曲线运动的动画

我们是工程师 ——加油 !

CALayer篇:

  • CALayer有很多子类,如果只是用来显示图形、文字,CALayer完全可以替代UIView的展示功能,但是CALayer不是继承与UIResponder,所以不能添加触摸事件,因此不能代替UIView的添加响应事件功能。
  • 这个帖子展示的是CALayer的一个子类:CAReplicatorLayer 与UIBezierPath 实现曲线运动的动画效果(里边有曲线,直线)。
  • 一共有五个动画效果,本帖子先举出一个,接下来还会更新更多,如果喜欢,希望大家多多鼓励。

来 ~ 先上gif图

1.复制图层" instanceCount"设置为多个时候的效果

_replicatorLayer.instanceCount = 30.0
more instance.gif

2.复制图层" instanceCount"设置为一个时候的效果

_replicatorLayer.instanceCount = 1.0
oneInstance.gif
  • 代码量很小,先拿去复制粘贴吧
#import "ViewController.h"

#define H self.view.frame.size.height
#define W self.view.frame.size.width

@interface ViewController ()
/**图片*/
@property (nonatomic , weak) UIImageView *imageView;
/**replicatorLayer*/
@property (nonatomic , weak) CAReplicatorLayer *replicatorLayer;

@end

#pragma mark - 添加图片
- (void)addImageView {
    UIImageView *imageView = [[UIImageView alloc]init];
    [self.view addSubview:imageView];
    
    imageView.contentMode = UIViewContentModeScaleAspectFit;
    _imageView = imageView;
}
#pragma mark - 设置ReplicatorLayer 
- (void)addReplicatorLayer {
    
    CAReplicatorLayer *replicatorLayer = [CAReplicatorLayer layer];
    
    replicatorLayer.bounds = self.view.bounds;
    replicatorLayer.position = self.view.center;
    
    replicatorLayer.preservesDepth = YES;
    
    replicatorLayer.instanceColor = [UIColor whiteColor].CGColor;
    
    [replicatorLayer addSublayer:_imageView.layer];
    [self.view.layer addSublayer:replicatorLayer];
    _replicatorLayer = replicatorLayer;
    
    
}

#pragma mark - 设置动画

- (void)code_XMAnimationTwo{
    _imageView.contentMode = UIViewContentModeScaleAspectFit;
    /**初始位置*/
    _imageView.frame = CGRectMake(20, 600, 15, 15);
    
    _imageView.backgroundColor = [UIColor orangeColor];
    _imageView.image = [UIImage imageNamed:@"hei"];
    _imageView.layer.cornerRadius = 7.5;
    _imageView.layer.masksToBounds = YES;
    
    CGFloat count = 30.0;
    CGFloat duration = 3;
    _replicatorLayer.instanceCount = count;/**复制图层个数*/
    _replicatorLayer.instanceDelay = duration / count;/**复制延迟*/
    _replicatorLayer.instanceAlphaOffset = 0.1;
    
    /**规划路径----UIBezierPath*/
    UIBezierPath *path = [UIBezierPath bezierPath];
    [path moveToPoint:CGPointMake(20, 600)];/**动画开始的点--基准点*/
    [path addLineToPoint:CGPointMake(20, 100)];/**第一条直线终点(也是第二条直线的开始点)*/
    [path addCurveToPoint:CGPointMake(200, 400) controlPoint1:CGPointMake(200, 20) controlPoint2:CGPointMake(20, 400)];/**曲线的  起点(也是第二条直线的终点) 、 控制点1 、控制点2*/
    [path addLineToPoint:CGPointMake(280, 90)];/**直线*/
    [path addLineToPoint:CGPointMake(380, 280)];/**直线*/
    [path addLineToPoint:CGPointMake(240, 400)];/**直线*/
    [path addLineToPoint:CGPointMake(400, 500)];/**最后一条直线终点*/
    
    CAKeyframeAnimation *keyFrameAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
    keyFrameAnimation.path = CGPathCreateCopyByTransformingPath(path.CGPath, NULL);
    keyFrameAnimation.duration = duration;
    keyFrameAnimation.repeatCount = 2;/**重复次数*/
    [_imageView.layer addAnimation:keyFrameAnimation forKey:nil];
    
}

  • 属性简介解

// CAReplicatorLayer可以将自己的子图层复制指定的次数,并且复制体会保持被复制图层的各种基础属性以及动画

//基本属性

instanceCount
 Int 型   拷贝图层的次数,包括其所有的子图层,默认值是1,也就是没有任何子图层被复制


instanceDelay
CFTimeInterval 类  在短时间内的复制延时,一般用在动画上(支持动画的延时)



instanceTransform
 CATransform3D 类  复制图层在被创建时产生的和上一个复制图层的位移(位移的锚点时CAReplicatorlayer的中心点)



preservesDepth
 Bool 型  如果设置为YES,图层将保持于CATransformLayer类似的性质和相同的限制



instanceColor
CGColor 类 设置多个复制图层的颜色,默认位白色



instanceRedOffset
 Float 型  设置每个复制图层相对上一个复制图层的红色偏移量



instanceGreenOffset
 Float 型  设置每个复制图层相对上一个复制图层的绿色偏移量



instanceBlueOffset
 Float 型    设置每个复制图层相对上一个复制图层的蓝色偏移量



instanceAlphaOffset
Float 型  设置每个复制图层相对上一个复制图层的透明度偏移量

【code_小马】

晌午时光

很喜欢的一篇文章,拿出来和大家分享
【第九集】

........ 我决定去巷口接一接如风,我拿起一把伞,开门走了出去。    我没想到,在开门的一霎那,我的命运彻底发生了改变……    我开门的时候恰巧三个阿飞驾着机车从狭窄的巷子里飞驰而过,随着一声尖锐的刹车声,我们摔作一团。    “X你娘!没长眼啊?”三个男人中为首的那一个站起来指着我骂道。我的腿好像被撞伤了,身上已经被大雨淋湿,沾了很多的泥,狼狈不堪。我挣扎的爬起来,低着头忙不迭地说对不起。    另外两人也站了起来,其中染黄头发的一个不客气的推了我一把,我又摔到了地上,伤腿被重重的碰到,我疼得动弹不得。    “滚开!”就在黄毛准备再补给我一脚的时候,为首的人喝住他。    “你是夏如画!?”他诧异的说。    我惊讶得抬眼望他,辨认了好久,失声叫道:“阿福!”    阿福搀起来我说:“没认出是你阿!多少年没见了!”    我疼得轻哼了一声,阿福说:“伤到了吧?我扶你进屋!”    阿福揽着我的腰进到了屋里,却迟迟不愿放开,我觉得有点别扭,轻轻拨开了他的手。    湿透的制服衬衫把我已渐渐发育的身材暴露无遗,阿福毫无掩饰的盯着我的胸脯说:“如画,你比以前更靓了!”     我尴尬的侧着身子,默默不语,隐隐感到一种恐惧。    阿福坐到我身边说:“腿疼不疼?我帮你看看。”说着就把手伸向我的裙子。    我急忙闪开说:“不用了!你们还有事吧?不用管我,快去忙吧!一会如风就回来了,他给我看就好。”    阿福哈哈笑了一声,对他的两个小弟说:“她是我的初恋情人呢!当初她弟弟还为她跟我打了一架。”    黄毛吹了声口哨说:“福哥好眼光!”    阿福肆无忌惮的靠过来,我紧贴着墙无处可躲,他把手放在我大腿上说:“我上过的女人,哪个不好?”    我使劲推开他,喊道:“别碰我,滚出去!”    阿福狞笑道:“今天老子犯桃花,是你自己送上门,我怎么会放过?”    两个小弟识趣的走了出去,黄毛带上房门说:“福哥,动作快点阿!今晚程老大还有事!”    我惊恐的望着阿福,我知道他想做什么了,从未有过的恐惧侵透我的全身。

点击阅读文章第八集

点击阅读文章第十集

文章后续更新中,喜欢请关注哦 🌹

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

推荐阅读更多精彩内容