iOS動(dòng)畫(huà)進(jìn)階-實(shí)現(xiàn)類(lèi)似美顏相機(jī)的相機(jī)啟動(dòng)動(dòng)畫(huà)

最近在寫(xiě)一個(gè)相冊(cè)的demo狠裹,偶爾看到了美拍的相機(jī)過(guò)載動(dòng)畫(huà)覺(jué)得很有意思,就想在我的相冊(cè)demo中加入一個(gè)這種特效官辽,下面把我的想法和實(shí)現(xiàn)過(guò)程給大家分享一下

先上效果圖:(demo地址

效果圖

步驟分析

這個(gè)動(dòng)效看起來(lái)很有特色但是實(shí)現(xiàn)起來(lái)是非常簡(jiǎn)單的汛聚,只需要用到CALayerCAShapeLayer做為展示層,然后通過(guò)CABasicAnimation實(shí)現(xiàn)動(dòng)畫(huà)就行了~

  • 用兩個(gè)CALayer來(lái)呈現(xiàn)啟動(dòng)的image
  • 通過(guò)UIBezierPathCAShapeLayer來(lái)畫(huà)出具有曲線的CAShapeLayer
  • 然后將曲線的CAShapeLayer做為CALayer的mask
  • 最后通過(guò)CABasicAnimation做一個(gè)簡(jiǎn)單的位移動(dòng)畫(huà)

先繪制上半部分的layer

/**
     繪制上半部分的layer
     */
    private func configTopShapeLayer() {
        //繪制貝斯?fàn)柷€
        let topBezier:UIBezierPath = UIBezierPath()
        topBezier.moveToPoint(CGPointMake(-1, -1))
        topBezier.addLineToPoint(CGPointMake(bounds.width+1, -1))
        topBezier.addCurveToPoint(CGPointMake(bounds.width/2.0+1, bounds.height/2.0+1), controlPoint1: CGPointMake(bounds.width+1, 0+1), controlPoint2: CGPointMake(343.5+1, 242.5+1))
        topBezier.addCurveToPoint(CGPointMake(-1, bounds.height+2), controlPoint1: CGPointMake(31.5+2, 424.5+2), controlPoint2: CGPointMake(0+2, bounds.height+2))
        topBezier.addLineToPoint(CGPointMake(-1, -1))
        topBezier.closePath()
        //創(chuàng)建一個(gè)CAShapeLayer畅买,將繪制的貝斯?fàn)柷€的path給CAShapeLayer
        let topShape = CAShapeLayer()
        topShape.path = topBezier.CGPath
        //給topLayer設(shè)置contents為啟動(dòng)圖
        topLayer.contents = launchImage?.CGImage
        topLayer.frame = bounds
        layer.addSublayer(topLayer)
        //將繪制后的CAShapeLayer做為topLayer的mask
        topLayer.mask = topShape
    }

繪制后的結(jié)果是這樣的:

繪制后的結(jié)果

然后以同樣的原理繪制下半部分的layer

/**
     繪制下半部分的layer
     */
    private func configBottomShapeLayer() {
        //繪制貝斯?fàn)柷€
        let bottomBezier:UIBezierPath = UIBezierPath()
        bottomBezier.moveToPoint(CGPointMake(bounds.width, 0))
        bottomBezier.addCurveToPoint(CGPointMake(bounds.width/2.0, bounds.height/2.0), controlPoint1: CGPointMake(bounds.width, 0), controlPoint2: CGPointMake(343.5, 242.5))
        bottomBezier.addCurveToPoint(CGPointMake(0, bounds.height), controlPoint1: CGPointMake(31.5, 424.5), controlPoint2: CGPointMake(0, bounds.height))
        bottomBezier.addLineToPoint(CGPointMake(bounds.width, bounds.height))
        bottomBezier.addLineToPoint(CGPointMake(bounds.width, 0))
        bottomBezier.closePath()
        //創(chuàng)建一個(gè)CAShapeLayer并闲,將繪制的貝斯?fàn)柷€的path給CAShapeLayer
        let bottomShape = CAShapeLayer()
        bottomShape.path = bottomBezier.CGPath
        //給bottomLayer設(shè)置contents為啟動(dòng)圖
        bottomLayer.contents = launchImage?.CGImage
        bottomLayer.frame = bounds
        layer.addSublayer(bottomLayer)
        //將繪制后的CAShapeLayer做為bottomLayer的mask
        bottomLayer.mask = bottomShape
    }

這里注意的是畫(huà)的貝斯?fàn)柷€上半部分的要整體向下平移1到2個(gè)像素,為了防止貝斯?fàn)柷€畫(huà)曲線導(dǎo)致的鋸齒效果谷羞,下面是下半部分完成后的效果圖:

這里寫(xiě)圖片描述

最后給兩個(gè)layer一個(gè)位移動(dòng)畫(huà)

/**
     展開(kāi)的動(dòng)畫(huà)
     */
    func starAnimation() {
        //創(chuàng)建一個(gè)CABasicAnimation作用于CALayer的anchorPoint
        let topAnimation = CABasicAnimation.init(keyPath: "anchorPoint")
        //設(shè)置移動(dòng)路徑
        topAnimation.toValue = NSValue.init(CGPoint: CGPointMake(1, 1))
        //動(dòng)畫(huà)時(shí)間
        topAnimation.duration = 0.6
        //設(shè)置代理帝火,方便完成動(dòng)畫(huà)后移除當(dāng)前view
        topAnimation.delegate = self
        //設(shè)置動(dòng)畫(huà)速度為勻速
        topAnimation.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionLinear)
        //設(shè)置動(dòng)畫(huà)結(jié)束后不移除點(diǎn),保持移動(dòng)后的位置
        topAnimation.removedOnCompletion = false
        topAnimation.fillMode = kCAFillModeForwards
        topLayer.addAnimation(topAnimation, forKey: "topAnimation")
        
        //創(chuàng)建一個(gè)CABasicAnimation作用于CALayer的anchorPoint
        let bottomAnimation = CABasicAnimation.init(keyPath: "anchorPoint")
        //設(shè)置移動(dòng)路徑
        bottomAnimation.toValue = NSValue.init(CGPoint: CGPointMake(0, 0))
        //動(dòng)畫(huà)時(shí)間
        bottomAnimation.duration = 0.6
        //設(shè)置動(dòng)畫(huà)速度為勻速
        bottomAnimation.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionLinear)
        //設(shè)置動(dòng)畫(huà)結(jié)束后不移除點(diǎn)湃缎,保持移動(dòng)后的位置
        bottomAnimation.removedOnCompletion = false
        bottomAnimation.fillMode = kCAFillModeForwards
        bottomLayer.addAnimation(bottomAnimation, forKey: "topAnimation")
    }
    
        /**
     動(dòng)畫(huà)完成后移除當(dāng)前view
     */
    internal override func animationDidStop(anim: CAAnimation, finished flag: Bool)           
    {
        if flag {
            removeFromSuperview()
        }
    }

這里為了方便觀察犀填,我將動(dòng)畫(huà)時(shí)間變長(zhǎng)了,下面是完成后的效果圖:

這里寫(xiě)圖片描述

到這里這個(gè)動(dòng)效就完成的差不多了嗓违,希望大家能學(xué)到東西九巡,如果大家有更好的實(shí)現(xiàn)辦法也可以給我提意見(jiàn),我學(xué)習(xí)學(xué)習(xí)蹂季,謝謝大家觀看冕广,另外附加demo地址,喜歡的可以關(guān)注一下

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末偿洁,一起剝皮案震驚了整個(gè)濱河市撒汉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌涕滋,老刑警劉巖睬辐,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡溉委,警方通過(guò)查閱死者的電腦和手機(jī)鹃唯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)瓣喊,“玉大人坡慌,你說(shuō)我怎么就攤上這事≡迦” “怎么了洪橘?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)棵帽。 經(jīng)常有香客問(wèn)我熄求,道長(zhǎng),這世上最難降的妖魔是什么逗概? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任弟晚,我火速辦了婚禮,結(jié)果婚禮上逾苫,老公的妹妹穿的比我還像新娘卿城。我一直安慰自己,他們只是感情好铅搓,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布瑟押。 她就那樣靜靜地躺著,像睡著了一般星掰。 火紅的嫁衣襯著肌膚如雪多望。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,031評(píng)論 1 285
  • 那天氢烘,我揣著相機(jī)與錄音怀偷,去河邊找鬼。 笑死播玖,一個(gè)胖子當(dāng)著我的面吹牛枢纠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播黎棠,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼镰绎!你這毒婦竟也來(lái)了脓斩?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤畴栖,失蹤者是張志新(化名)和其女友劉穎随静,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡燎猛,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年恋捆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片重绷。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沸停,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出昭卓,到底是詐尸還是另有隱情愤钾,我是刑警寧澤,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布候醒,位于F島的核電站能颁,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏倒淫。R本人自食惡果不足惜伙菊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望敌土。 院中可真熱鬧镜硕,春花似錦、人聲如沸纯赎。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)犬金。三九已至念恍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間晚顷,已是汗流浹背峰伙。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留该默,地道東北人瞳氓。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像栓袖,于是被迫代替她去往敵國(guó)和親匣摘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

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

  • Core Animation Core Animation裹刮,中文翻譯為核心動(dòng)畫(huà)音榜,它是一組非常強(qiáng)大的動(dòng)畫(huà)處理API,...
    45b645c5912e閱讀 3,015評(píng)論 0 21
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫(huà)效果捧弃,實(shí)現(xiàn)這些動(dòng)畫(huà)的過(guò)程并不復(fù)雜赠叼,今天將帶大家一窺ios動(dòng)畫(huà)全貌擦囊。在這里你可以看...
    每天刷兩次牙閱讀 8,465評(píng)論 6 30
  • 前言:關(guān)于貝塞爾曲線與CAShapeLayer的學(xué)習(xí) 學(xué)習(xí)Demo演示: 貝塞爾曲線簡(jiǎn)單了解 使用UIBezier...
    麥穗0615閱讀 17,857評(píng)論 18 149
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫(huà)效果,實(shí)現(xiàn)這些動(dòng)畫(huà)的過(guò)程并不復(fù)雜嘴办,今天將帶大家一窺iOS動(dòng)畫(huà)全貌瞬场。在這里你可以看...
    F麥子閱讀 5,094評(píng)論 5 13
  • 目錄: 主要繪圖框架介紹 CALayer 繪圖 貝塞爾曲線-UIBezierPath CALayer子類(lèi) 補(bǔ)充:i...
    Ryan___閱讀 1,658評(píng)論 1 9