NSTimer怎樣實現彈性球動畫-創(chuàng)新互聯

這篇文章主要講解了“NSTimer怎樣實現彈性球動畫”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“NSTimer怎樣實現彈性球動畫”吧!

10年積累的成都做網站、網站建設經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站設計后付款的網站建設流程,更有龍山免費網站建設讓你可以放心的選擇與我們合作。

NSTimer怎樣進行彈性球動畫的實現

NSTimer并不是很好方案,為了理解這點,我們需要確切地知道NSTimer是如何工作的。iOS上的每個線程都管理了一個NSRunloop,字面上看就是通過一個循環(huán)來完成一些任務列表。但是對主線程,這些任務包含如下幾項:

處理觸摸事件

發(fā)送和接受網絡數據包

執(zhí)行使用gcd的代碼

處理計時器行為

屏幕重繪

當你設置一個NSTimer,他會被插入到當前任務列表中,然后直到指定時間過去之后才會被執(zhí)行。但是何時啟動定時器并沒有一個時間上限,而且它只會在列表中上一個任務完成之后開始執(zhí)行。這通常會導致有幾毫秒的延遲,但是如果上一個任務過了很久才完成就會導致延遲很長一段時間。

屏幕重繪的頻率是一秒鐘六十次,但是和定時器行為一樣,如果列表中上一個執(zhí)行了很長時間,它也會延遲。這些延遲都是一個隨機值,于是就不能保證定時器精準地一秒鐘執(zhí)行六十次。有時候發(fā)生在屏幕重繪之后,這就會使得更新屏幕會有個延遲,看起來就是動畫卡殼了。有時候定時器會在屏幕更新的時候執(zhí)行兩次,于是動畫看起來就跳動了。

我們可以通過一些途徑來優(yōu)化:

我們可以用CADisplayLink讓更新頻率嚴格控制在每次屏幕刷新之后。

基于真實幀的持續(xù)時間而不是假設的更新頻率來做動畫。

調整動畫計時器的runloop模式,這樣就不會被別的事件干擾。

CADisplayLink是CoreAnimation提供的另一個類似于NSTimer的類,它總是在屏幕完成一次更新之前啟動,它的接口設計的和NSTimer很類似,所以它實際上就是一個內置實現的替代,但是和timeInterval以秒為單位不同,CADisplayLink有一個整型的frameInterval屬性,指定了間隔多少幀之后才執(zhí)行。默認值是1,意味著每次屏幕更新之前都會執(zhí)行一次。但是如果動畫的代碼執(zhí)行起來超過了六十分之一秒,你可以指定frameInterval為2,就是說動畫每隔一幀執(zhí)行一次(一秒鐘30幀)或者3,也就是一秒鐘20次,等等。

感謝各位的閱讀,以上就是“NSTimer怎樣實現彈性球動畫”的內容了,經過本文的學習后,相信大家對NSTimer怎樣實現彈性球動畫這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯網站建設公司,,小編將為大家推送更多相關知識點的文章,歡迎關注!

文章名稱:NSTimer怎樣實現彈性球動畫-創(chuàng)新互聯
本文地址:http://bm7419.com/article44/dgdgee.html

成都網站建設公司_創(chuàng)新互聯,為您提供面包屑導航、網站維護、網站設計公司做網站、關鍵詞優(yōu)化網站建設

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

外貿網站制作