iOS CAReplicatorLayer 復(fù)制圖層

簡(jiǎn)介

CAReplicatorLayer 是 CALayer 的子類(lèi)博投,是一個(gè)圖層容器伪煤,可以添加特定的圖層到其中加袋,并復(fù)制出多個(gè)圖層,例如你把一個(gè)單一的形狀抱既,通過(guò)簡(jiǎn)單的設(shè)置职烧,在屏幕上就可以顯示多個(gè)相同的形狀。
你可以使用 CAReplicatorLayer 結(jié)合動(dòng)畫(huà)制作出很多酷炫的動(dòng)畫(huà)。本章利用CAReplicatorLayer 制作幾個(gè)可以充當(dāng)加載提示的指示器蚀之,來(lái)演示下復(fù)制圖層的使用蝗敢。

加載指示器

CAReplicatorLayer

屬性解析:

instanceCount //元素圖層的數(shù)量,默認(rèn)為1
instanceDelay //元素圖層之間的延遲時(shí)間足删,默認(rèn)為0
instanceTransform //可以移動(dòng)寿谴、縮放、旋轉(zhuǎn)元素圖層

使用步驟:

  1. 創(chuàng)建元素圖層
  2. 創(chuàng)建動(dòng)畫(huà)對(duì)象失受,并添加到元素圖層上
  3. 創(chuàng)建復(fù)制圖層

演示示例

  • 示例1
圓環(huán)點(diǎn)
  1. 先使用 CALayer 制作一個(gè)元素圓點(diǎn)
CGSize size = CGSizeMake(100, 100); //大小
UIColor *color = [UIColor redColor]; //顏色
CALayer* itemLayer = [CALayer layer];
itemLayer.bounds = CGRectMake(0, 0, size.width/6, size.width/6);
itemLayer.position = CGPointMake(size.width/2, 5);
itemLayer.cornerRadius = itemLayer.bounds.size.width/2; //圓形
itemLayer.backgroundColor = color.CGColor;  //顏色
itemLayer.transform = CATransform3DMakeScale(0.1, 0.1, 0.1); //最初大小縮小為0.1
  1. 元素圖層添加動(dòng)畫(huà)
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
animation.fromValue = @1;
animation.toValue = @0.1;
animation.duration = 0.5; //動(dòng)畫(huà)時(shí)間
animation.repeatCount = HUGE_VALF;
[itemLayer addAnimation:animation forKey:@"animation"]; //添加到元素圖層上
  1. 創(chuàng)建CAReplicatorLayer 復(fù)制層
CAReplicatorLayer *replicatorLayer = [CAReplicatorLayer layer];
replicatorLayer.frame = CGRectMake(0, 0, size.width, size.height);
replicatorLayer.position = self.view.center;
replicatorLayer.backgroundColor = [UIColor clearColor].CGColor;
// 核心代碼:
NSInteger numOfSpot = 15; //復(fù)制的數(shù)量
replicatorLayer.instanceCount = numOfSpot;
CGFloat angle = (M_PI*2.0)/numOfSpot; //旋轉(zhuǎn)的角度
replicatorLayer.instanceTransform = CATransform3DMakeRotation(angle, 0, 0, 1);  //旋轉(zhuǎn)效果
replicatorLayer.instanceDelay = 1.0/numOfSpot;  //下一個(gè)元素添加的延遲時(shí)間
[replicatorLayer addSublayer:itemLayer];    // 添加元素圓點(diǎn)
[self.view.layer addSublayer:replicatorLayer];
  • 示例2
這里寫(xiě)圖片描述
// 關(guān)鍵幀動(dòng)畫(huà)
// 計(jì)算三個(gè)圓點(diǎn)位置
CGPoint p0,p1,p2;
p0 = CGPointMake(size.width/2.0, size.height);
p1 = CGPointMake(size.width/2.0*(1-cos(M_PI*30/180.0)), size.width/2.0*(1-sin(M_PI*30/180.0)));
p2 = CGPointMake(size.width/2.0*(1+cos(M_PI*30/180.0)), size.width/2.0*(1-sin(M_PI*30/180.0)));
CAKeyframeAnimation *animation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
animation.duration = 1.5;
animation.values = @[[NSValue valueWithCGPoint:p0],[NSValue valueWithCGPoint:p1],[NSValue valueWithCGPoint:p2],[NSValue valueWithCGPoint:p0]];
animation.timingFunctions = @[
                             [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
                             [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
                             [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]
                              ];  //運(yùn)動(dòng)速率
animation.repeatCount = HUGE_VALF;
// 添加關(guān)鍵幀動(dòng)畫(huà)
[itemLayer addAnimation:animation forKey:@"animation"]; 

// 核心代碼
NSInteger numOfSpot = 3; //數(shù)量
replicatorLayer.instanceCount = numOfSpot;
CGFloat angle = (M_PI*2) / numOfSpot; //計(jì)算角度
replicatorLayer.instanceTransform = CATransform3DMakeRotation(angle, 0, 0, 1);  //旋轉(zhuǎn)
[replicatorLayer addSublayer:itemLayer]; //添加元素圓點(diǎn)

Demo地址

總結(jié)

CAReplicatorLayer 是一個(gè)圖層容器讶泰,可以接受特定的圖層并復(fù)制出多個(gè)圖層。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拂到,一起剝皮案震驚了整個(gè)濱河市痪署,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌兄旬,老刑警劉巖狼犯,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異领铐,居然都是意外死亡悯森,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)绪撵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)瓢姻,“玉大人,你說(shuō)我怎么就攤上這事莲兢⌒诶矗” “怎么了续膳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵改艇,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我坟岔,道長(zhǎng)谒兄,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任社付,我火速辦了婚禮承疲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鸥咖。我一直安慰自己燕鸽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布啼辣。 她就那樣靜靜地躺著啊研,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上党远,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天削解,我揣著相機(jī)與錄音,去河邊找鬼沟娱。 笑死氛驮,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的济似。 我是一名探鬼主播矫废,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼砰蠢!你這毒婦竟也來(lái)了磷脯?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤娩脾,失蹤者是張志新(化名)和其女友劉穎赵誓,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體柿赊,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡俩功,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了碰声。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诡蜓。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖胰挑,靈堂內(nèi)的尸體忽然破棺而出蔓罚,到底是詐尸還是另有隱情,我是刑警寧澤瞻颂,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布豺谈,位于F島的核電站,受9級(jí)特大地震影響贡这,放射性物質(zhì)發(fā)生泄漏茬末。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一盖矫、第九天 我趴在偏房一處隱蔽的房頂上張望丽惭。 院中可真熱鬧,春花似錦辈双、人聲如沸责掏。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)换衬。三九已至局义,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間冗疮,已是汗流浹背萄唇。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留术幔,地道東北人另萤。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像诅挑,于是被迫代替她去往敵國(guó)和親四敞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)拔妥、插件忿危、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,058評(píng)論 4 62
  • Core Animation Core Animation,中文翻譯為核心動(dòng)畫(huà)没龙,它是一組非常強(qiáng)大的動(dòng)畫(huà)處理API铺厨,...
    45b645c5912e閱讀 3,016評(píng)論 0 21
  • 今天看到一段視頻是著名電影剪輯師廖慶松老師的公開(kāi)課,里面講到廖老師在剪輯悲情城市的時(shí)候的一段經(jīng)歷——《悲情城市》是...
    米蟲(chóng)電影閱讀 11,903評(píng)論 0 5
  • 看到今天的晨讀有點(diǎn)惋惜昨晚上吃飯前硬纤,濤先生做的一桌好菜沒(méi)有拍照留念…… 殘羹飯肴上一張照片看看有多搶手 辣子蟹…好...
    小純說(shuō)閱讀 198評(píng)論 2 3
  • 我是一個(gè)普通上班族解滓,相貌平平,收入平平筝家,但是畢竟是裸婚的已婚人士洼裤,手上多少有一些積蓄。特別羨慕最近遇到的一個(gè)理財(cái)大...
    木棉韶華閱讀 175評(píng)論 0 0