使用CAAnimation打造一個(gè)有意思的loading動(dòng)畫

項(xiàng)目中遇到一個(gè)比較有意思的loading動(dòng)畫需求,最終效果如下:

screenShot.gif
分析

相信很多人跟我一樣第一眼被這張圖欺騙了,以為是有一個(gè)實(shí)心圓在做縮放旋轉(zhuǎn)的動(dòng)畫,其實(shí)仔細(xì)單獨(dú)觀察每個(gè)圓形,不難看出,這個(gè)loading只是由8個(gè)圓形規(guī)律的做放大縮小的動(dòng)畫,同時(shí)加上了透明度的變化達(dá)到了圖中的效果,由此我們有了思路:8個(gè)圓形,scale animate + opacity animate.

代碼實(shí)現(xiàn)

我嘗試使用最基礎(chǔ)的CAAnimation中api來(lái)完成想要的效果,由之前的思路,我們首先將縮放動(dòng)畫與透明漸變動(dòng)畫實(shí)現(xiàn)出來(lái):

  1. 縮放.我們可以看出每個(gè)圓形的縮放比例是經(jīng)歷了 1,0.4,1這三個(gè)階段,當(dāng)然你也可以理解為0.4,1,0.4,至于為什么是0.4,僅僅是覺(jué)的比較好看Orz,并且我們定義動(dòng)畫完成一個(gè)循環(huán)需要的時(shí)間是1s.
  2. 透明漸變. 每個(gè)圓形的opacity屬性經(jīng)歷了1,0.3,1這三個(gè)階段,同上選中0.3,1,0.3也取決于你的喜好,同樣的一個(gè)循環(huán)時(shí)間為1s.
//scale
- (CAKeyframeAnimation *)scaleAnimation {
    CAKeyframeAnimation *scaleAnimate = [CAKeyframeAnimation animationWithKeyPath:@"transform.scale"];
    scaleAnimate.keyTimes = @[@0, @0.5, @1];
    scaleAnimate.values = @[@1, @0.4, @1];
    scaleAnimate.duration = kDuration;
    return scaleAnimate;
}

//opactity
- (CAKeyframeAnimation *)opactityAnimation {
    CAKeyframeAnimation *opacityAnimaton = [CAKeyframeAnimation animationWithKeyPath:@"opacity"];
    opacityAnimaton.keyTimes = @[@0, @0.5, @1];
    opacityAnimaton.values = @[@1, @0.3, @1];
    opacityAnimaton.duration = kDuration;
    return opacityAnimaton;
}

接下來(lái)我們使用CAAnimationGroup來(lái)包裝這兩個(gè)動(dòng)畫:

CAAnimationGroup *animation = [[CAAnimationGroup alloc] init];
    animation.animations = @[[self scaleAnimation], [self opactityAnimation]];
    animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
    animation.duration = 1.f;
    animation.repeatCount = HUGE;
    animation.removedOnCompletion = NO;

最后的步驟,按照?qǐng)A形排列繪制8個(gè)原點(diǎn),我們可以使用CAShapeLayerUIBszierPath結(jié)合來(lái)繪制圓形圖案,代碼都非常簡(jiǎn)單,不做更多解讀了,至于8個(gè)圖形的擺放位置這里可能需要一點(diǎn)高中數(shù)學(xué)知識(shí)了:

    for (int i = 0; i < 8; i++) {
        CALayer *circle = [self circleLayerWithAngle:M_PI_4 * i size:circleSize origin:CGPointMake(x, y) containerSize:size color:tintColor];
        
        animation.beginTime = beginTime + i * 0.12;
        [circle addAnimation:animation forKey:@"animation"];
        [layer addSublayer:circle];
    }  

- (CALayer *)circleLayerWithAngle:(CGFloat)angle size:(CGFloat)size origin:(CGPoint)origin containerSize:(CGSize)containerSize  color:(UIColor *)color{
    CGFloat raduis = containerSize.width * 0.5;
    
    CAShapeLayer *layer = [CAShapeLayer layer];
    UIBezierPath *path = [[UIBezierPath alloc] init];
    
    [path addArcWithCenter:CGPointMake(size * 0.5, size * 0.5) radius:size * 0.5 startAngle:0 endAngle:M_PI * 2 clockwise:NO];
    [path closePath];
    layer.fillColor = color.CGColor;
    layer.path = path.CGPath;
    
    CGRect frame = CGRectMake(origin.x + raduis * (cos(angle) + 1),
                              origin.y + raduis * (sin(angle) + 1),
                              size, size);
    layer.frame = frame;
    return layer;
}

通常,對(duì)于這種小的動(dòng)畫我習(xí)慣封裝成一個(gè)單獨(dú)的animation類,方便在其他地方調(diào)用,你可以在這里下載到這個(gè)demo.
如有你對(duì)本文有什么好的建議,歡迎提出咯

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市坛增,隨后出現(xiàn)的幾起案子炭玫,更是在濱河造成了極大的恐慌躏仇,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件扒磁,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)点寥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)祥楣,“玉大人开财,你說(shuō)我怎么就攤上這事∥笸剩” “怎么了责鳍?”我有些...
    開(kāi)封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)兽间。 經(jīng)常有香客問(wèn)我历葛,道長(zhǎng),這世上最難降的妖魔是什么嘀略? 我笑而不...
    開(kāi)封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任恤溶,我火速辦了婚禮,結(jié)果婚禮上帜羊,老公的妹妹穿的比我還像新娘咒程。我一直安慰自己,他們只是感情好讼育,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布帐姻。 她就那樣靜靜地躺著稠集,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饥瓷。 梳的紋絲不亂的頭發(fā)上剥纷,一...
    開(kāi)封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音呢铆,去河邊找鬼晦鞋。 笑死,一個(gè)胖子當(dāng)著我的面吹牛棺克,可吹牛的內(nèi)容都是我干的悠垛。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼逆航,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼鼎文!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起因俐,我...
    開(kāi)封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤拇惋,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后抹剩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體撑帖,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年澳眷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胡嘿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡钳踊,死狀恐怖衷敌,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拓瞪,我是刑警寧澤缴罗,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站祭埂,受9級(jí)特大地震影響面氓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蛆橡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一舌界、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泰演,春花似錦呻拌、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)酿箭。三九已至,卻和暖如春趾娃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缔御。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工抬闷, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人耕突。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓笤成,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親眷茁。 傳聞我的和親對(duì)象是個(gè)殘疾皇子炕泳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 1、屬性選擇器:id選擇器 # 通過(guò)id 來(lái)選擇類名選擇器 . 通過(guò)類名來(lái)選擇屬性選擇器 ...
    Yuann閱讀 1,621評(píng)論 0 7
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果上祈,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜培遵,今天將帶大家一窺ios動(dòng)畫全貌。在這里你可以看...
    每天刷兩次牙閱讀 8,469評(píng)論 6 30
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果登刺,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜籽腕,今天將帶大家一窺iOS動(dòng)畫全貌。在這里你可以看...
    F麥子閱讀 5,101評(píng)論 5 13
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)纸俭、插件皇耗、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,059評(píng)論 4 62
  • 1,感謝清晨的陽(yáng)光揍很,明媚燦爛郎楼。 謝謝!謝謝!謝謝! 2嫁审,感謝大姨愿意乘坐今天的高鐵過(guò)來(lái)定页,這樣送了媽媽之后就可以接到...
    by_10閱讀 190評(píng)論 0 0