iOS動(dòng)畫(huà)之-CADisplayLink屏幕刷新動(dòng)畫(huà)

屏幕刷新動(dòng)畫(huà)-CADisplayLink

CADisplayLink是一定時(shí)器對(duì)象阴孟,相對(duì)NSTimer的不同之處在于,CADisplayLink是根據(jù)屏幕的刷新頻率來(lái)實(shí)現(xiàn)的一個(gè)定時(shí)器。iOS設(shè)備是每秒刷新60次蛤虐,意味著CADisplayLink開(kāi)啟后,每秒也將執(zhí)行60次。CADisplayLinkselector調(diào)用時(shí)機(jī)是在屏幕刷新結(jié)束后局雄。

CADisplayLink與NSTimer區(qū)別

  • CADisplayLink是屏幕刷新結(jié)束后調(diào)用的,相對(duì)于NSTimer來(lái)說(shuō)精度更高存炮,因?yàn)樵?code>RunLoop出現(xiàn)阻塞的情況下NSTimer的精度有所下降炬搭。主要跟RunLoop的周期有關(guān)。
  • CADisplayLink是基于屏幕刷新的穆桂,更適合做UI不停繪制的工作宫盔。

CADisplayLink常用屬性

//上一幀的時(shí)間
@property(readonly, nonatomic) CFTimeInterval timestamp;
//屏幕時(shí)兩幀之間的時(shí)間間隔
@property(readonly, nonatomic) CFTimeInterval duration;
//下一幀的時(shí)間
@property(readonly, nonatomic) CFTimeInterval targetTimestamp;
//是否暫停
@property(getter=isPaused, nonatomic) BOOL paused;
//已過(guò)時(shí)
@property(nonatomic) NSInteger frameInterval;
//每秒多少幀
@property(nonatomic) NSInteger preferredFramesPerSecond;

創(chuàng)建CADisplayLink

通過(guò)調(diào)用CADisplayLink的displayLinkWithTarget可以創(chuàng)建一個(gè)CADisplayLink對(duì)象,然后再通過(guò)調(diào)用addToRunLoop將定時(shí)器添加到runloop中啟動(dòng)定時(shí)器享完,可以設(shè)置preferredFramesPerSecond來(lái)指定每秒執(zhí)行多少次灼芭。

self.displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(updateTimer)];
    //每秒執(zhí)行一次
    self.displayLink.preferredFramesPerSecond = 1;
    [self.displayLink addToRunLoop:[NSRunLoop currentRunLoop] forMode:NSRunLoopCommonModes];

CADisplayLink示例

下面通過(guò)使用CADisplayLinkCAShapeLayer來(lái)實(shí)現(xiàn)一個(gè)圓形進(jìn)度條的動(dòng)畫(huà)。

  1. 首先用CAShapeLayerUIBezierPath來(lái)創(chuàng)建一個(gè)灰色的圓形作為背景驼侠,如下所示:
    CGPoint point = CGPointMake(self.animationView.frame.size.width/2, self.animationView.frame.size.height/2);
    UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:point radius:80 startAngle:0 endAngle:360 clockwise:YES];
    CAShapeLayer *layer = [CAShapeLayer layer];
    layer.lineWidth = 5;
    layer.strokeColor = [UIColor grayColor].CGColor;
    layer.fillColor = nil;
    layer.path = path.CGPath;
    [self.animationView.layer addSublayer:layer];
  1. 同理再創(chuàng)建一個(gè)用于顯示動(dòng)畫(huà)的紅色圓形姿鸿,如下所示:
    
    CAShapeLayer *layer = [CAShapeLayer layer];
    layer.lineWidth = 5;
    layer.strokeColor = [UIColor redColor].CGColor;
    layer.fillColor = nil;
    [self.animationView.layer addSublayer:layer];
    self.progressLayer = layer;
  1. 調(diào)用CADisplayLink的回調(diào)不停的添加弧度谆吴,如下所示:
-(void)updateTimer{
    if(self.startAngle >= 360){
        self.displayLink.paused = YES;
    }
    CGPoint point = CGPointMake(self.animationView.frame.size.width/2, self.animationView.frame.size.height/2);
    [self.progressPath addArcWithCenter:point radius:80  startAngle:(M_PI /180.0) *_startAngle endAngle:(M_PI /180.0) *(_startAngle + 3.6) clockwise:YES];
    self.progressLayer.path = self.progressPath.CGPath;
    self.startAngle += 3.6;
}

具體的代碼可以在demo中的 MLDisplayLinkViewController進(jìn)行查看
個(gè)人博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市苛预,隨后出現(xiàn)的幾起案子句狼,更是在濱河造成了極大的恐慌,老刑警劉巖热某,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腻菇,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡昔馋,警方通過(guò)查閱死者的電腦和手機(jī)筹吐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)秘遏,“玉大人丘薛,你說(shuō)我怎么就攤上這事“钗#” “怎么了洋侨?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)倦蚪。 經(jīng)常有香客問(wèn)我希坚,道長(zhǎng),這世上最難降的妖魔是什么陵且? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任裁僧,我火速辦了婚禮,結(jié)果婚禮上慕购,老公的妹妹穿的比我還像新娘聊疲。我一直安慰自己,他們只是感情好脓钾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布售睹。 她就那樣靜靜地躺著,像睡著了一般可训。 火紅的嫁衣襯著肌膚如雪昌妹。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天握截,我揣著相機(jī)與錄音飞崖,去河邊找鬼。 笑死谨胞,一個(gè)胖子當(dāng)著我的面吹牛固歪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼牢裳,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼逢防!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蒲讯,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤忘朝,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后判帮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體局嘁,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年晦墙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了悦昵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡晌畅,死狀恐怖但指,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情踩麦,我是刑警寧澤枚赡,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站谓谦,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏贪婉。R本人自食惡果不足惜反粥,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望疲迂。 院中可真熱鬧才顿,春花似錦、人聲如沸尤蒿。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)腰池。三九已至尾组,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間示弓,已是汗流浹背讳侨。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奏属,地道東北人跨跨。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像囱皿,于是被迫代替她去往敵國(guó)和親勇婴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子忱嘹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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