亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS 仿微博客戶端紅包加載界面 XLDotLoading效果

2020-07-26 02:57:10
字體:
來源:轉載
供稿:網友

一、顯示效果

二、原理簡介

1、思路

要實現這個效果需要先知道這兩個硬幣是怎樣運動的,然后通過放大、縮小的效果實現的這種有距離感的效果。思路如下:

一、這兩個硬幣是在一定范圍內做相對運動的,可以先使一個硬幣在一個固定范圍內做左右的往復運動,另一個硬幣和它做“相對運動”即可。

二、讓硬幣從左至右移動時先變小再回復正常;從右至左移動時先變大再回復正常;這樣就實現了這用有距離感的“相對運動”。

2、代碼

第一步 要實現一個硬幣在一定范圍內實現左右往復運動,需要先固定一個范圍,當運動到左邊緣時讓其向右運動,當運動到有邊緣時讓其向左運動。

這里用到了MVC的思想,先創建一個模型XLDot,給這個模型添加一個Direction屬性,然后通過改變模型direction屬性從而改變運動方向。

typedef NS_ENUM(NSInteger,DotDitection) {   DotDitectionLeft = -1,   DotDitectionRight = 1, }; @interface XLDot : UIView //移動方向 就兩種 左、右 @property (nonatomic,assign) DotDitection direction; //字體顏色 @property (nonatomic,strong) UIColor *textColor; @end 

先初始化一個豆,放在容器的左邊,方向設為向右

//初始化存放豆豆的的容器 _dotContainer = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 200)]; _dotContainer.center = self.center; [self addSubview:_dotContainer]; XLDot *dot = [[XLDot alloc] initWithFrame:CGRectMake(0, 0, [self dotWidth],[self dotWidth])]; dot.backgroundColor = [UIColor redColor]; dot.direction = DotDitectionRight; [_dotContainer addSubview:dot]; 

 通過CADisplayLink實現刷新工作,代碼如下

_link = [CADisplayLink displayLinkWithTarget:self selector:@selector(reloadView)]; [_link addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes]; 

刷新代碼如下,通過移動到左右邊緣,改變direction屬性

//刷新UI -(void)reloadView {   XLDot *dot1 = _dots.firstObject;   //改變移動方向、約束移動范圍   //移動到右邊距時   if (dot1.center.x >= _dotContainer.bounds.size.width - [self dotWidth]/2.0f) {     CGPoint center = dot1.center;     center.x = _dotContainer.bounds.size.width - [self dotWidth]/2.0f;     dot1.center = center;     dot1.direction = DotDitectionLeft;     [_dotContainer bringSubviewToFront:dot1];   }   //移動到左邊距時   if (dot1.center.x <= [self dotWidth]/2.0f) {     dot1.center = CGPointMake([self dotWidth]/2.0f, dot1.center.y);     dot1.direction = DotDitectionRight;     [_dotContainer sendSubviewToBack:dot1];   }   //更新第一個豆的位置   CGPoint center1 = dot1.center;   center1.x += dot1.direction * [self speed];   dot1.center = center1; } 

顯示效果:

第二步 實現向左移動先放大再回復正常、向右運動先變小再回復正常。

代碼如下:

//顯示放大、縮小動畫 -(void)showAnimationsOfDot:(XLDot*)dot {   CGFloat apart = dot.center.x - _dotContainer.bounds.size.width/2.0f;   //最大距離   CGFloat maxAppart = (_dotContainer.bounds.size.width - [self dotWidth])/2.0f;   //移動距離和最大距離的比例   CGFloat appartScale = apart/maxAppart;   //獲取比例對應余弦曲線的Y值   CGFloat transfomscale = cos(appartScale * M_PI/2.0);   //向右移動則 中間變大 兩邊變小   if (dot.direction == DotDitectionLeft) {     dot.transform = CGAffineTransformMakeScale(1 + transfomscale/4.0f, 1 + transfomscale/4.0f);     //向左移動則 中間變小 兩邊變大   }else if (dot.direction == DotDitectionRight){     dot.transform = CGAffineTransformMakeScale(1 - transfomscale/4.0f,1 - transfomscale/4.0f);   } } 

原理是利用余弦函數曲線-π/2到π/2先變大再變小的特性

效果如下:

第三步 放置另一個豆豆,和第一個豆豆做“相對運動”,包括放大變小、運動方向;

保證相對距離的代碼:

CGFloat apart = dot1.center.x - _dotContainer.bounds.size.width/2.0f; CGPoint center2 = dot2.center; center2.x = _dotContainer.bounds.size.width/2.0f - apart; dot2.center = center2; 

效果如下:

稍加潤色后:

三、代碼

GitHub地址

以上所述是小編給大家介紹的iOS 仿微博客戶端紅包加載界面 XLDotLoading效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
不用播放器成人网| 亚洲欧美福利视频| 亚洲精品自产拍| 国产精品久久久av久久久| 国产欧美亚洲视频| 欧美巨猛xxxx猛交黑人97人| 国产综合在线观看视频| 亚洲欧美国产视频| 亚洲精品xxx| 欧美极品少妇xxxxⅹ喷水| 色香阁99久久精品久久久| 激情久久av一区av二区av三区| 久久久亚洲国产| 欧美大片网站在线观看| 综合欧美国产视频二区| 伊人伊成久久人综合网站| 成人97在线观看视频| 亚洲一区二区三区xxx视频| 国外日韩电影在线观看| 欧美成人免费全部观看天天性色| 成人黄色片网站| 91精品国产九九九久久久亚洲| 91中文字幕在线观看| 欧美激情高清视频| 国产精品成av人在线视午夜片| 日本高清久久天堂| 亚洲欧美激情一区| 久久久91精品国产一区不卡| 亚洲视频日韩精品| 亚洲淫片在线视频| 精品激情国产视频| 亚洲性xxxx| 久久精品国产亚洲精品2020| 成人精品久久一区二区三区| 国产v综合ⅴ日韩v欧美大片| 国产精品极品在线| 国产一区香蕉久久| 91久久精品久久国产性色也91| 亚洲视频在线观看免费| 国产精品久久不能| 8090理伦午夜在线电影| 66m—66摸成人免费视频| 亚洲精品www久久久久久广东| 日韩在线免费高清视频| 久久久伊人欧美| 成人精品在线视频| 国产一区二区三区在线观看视频| 久久久91精品| 国产亚洲精品久久久久久| 欧美xxxx18性欧美| 尤物99国产成人精品视频| 国产精品99久久99久久久二8| 精品国产欧美一区二区三区成人| 91影院在线免费观看视频| 国产精品对白刺激| 夜夜嗨av色综合久久久综合网| 色与欲影视天天看综合网| 日韩av免费看网站| 91精品中国老女人| 日韩精品视频免费专区在线播放| 日韩中文字幕视频| 欧美wwwxxxx| 精品亚洲一区二区三区在线播放| 视频在线观看99| 国产精品xxxxx| 久久中国妇女中文字幕| 国产午夜精品全部视频在线播放| 亚洲人成网站999久久久综合| 亚洲综合在线播放| 疯狂蹂躏欧美一区二区精品| 亚洲欧美变态国产另类| 一区二区三区精品99久久| 成人免费观看网址| 亚洲最大中文字幕| 在线亚洲国产精品网| 欧美极品美女视频网站在线观看免费| 欧美劲爆第一页| 91精品久久久久久综合乱菊| 97精品国产91久久久久久| 欧美xxxx做受欧美| 最近2019中文字幕在线高清| 欧美午夜影院在线视频| 日韩在线中文视频| 欧美又大粗又爽又黄大片视频| 国产亚洲美女久久| 久久69精品久久久久久国产越南| 精品久久久视频| 在线视频免费一区二区| 成人黄色午夜影院| 欧美成人免费观看| 国产成人小视频在线观看| 欧美电影免费观看大全| 欧美一级片免费在线| 久久精品视频99| 亚洲精品久久久久久下一站| 久久艳片www.17c.com| 欧美日韩ab片| 久久亚洲精品毛片| 欧美极度另类性三渗透| 国产精品福利在线观看网址| 日韩人在线观看| 国产精品网站视频| 日韩在线小视频| 欧美人与性动交a欧美精品| 国产精品国产亚洲伊人久久| 日韩中文综合网| 亚洲国产日韩欧美综合久久| 欧美极品少妇xxxxⅹ喷水| 亚洲成人精品在线| 色噜噜狠狠色综合网图区| 国产精品美乳在线观看| 欧美伦理91i| 国产日韩欧美在线| 国产欧美日韩丝袜精品一区| 欧美日韩精品在线视频| 伊人一区二区三区久久精品| 中文字幕亚洲欧美日韩在线不卡| 精品一区二区三区四区| 成人日韩av在线| 久久69精品久久久久久国产越南| 中文字幕在线国产精品| 88国产精品欧美一区二区三区| 福利视频第一区| 97免费在线视频| 亚洲最大的成人网| 成人免费福利在线| 中文字幕亚洲综合久久筱田步美| 欧美日韩国产区| 精品欧美aⅴ在线网站| 深夜福利一区二区| 国产欧美一区二区| 色综合久久久久久中文网| 欧美激情精品久久久久久黑人| 成人www视频在线观看| 欧美午夜精品在线| 亚洲香蕉成视频在线观看| 久久在线免费观看视频| 国产在线精品播放| 亚洲一区久久久| 亚洲欧洲日产国产网站| 久99九色视频在线观看| 国产香蕉精品视频一区二区三区| 精品国产成人在线| 91精品久久久久久久久久另类| 日韩av影视在线| 欧美视频在线观看 亚洲欧| 久久99国产精品自在自在app| 川上优av一区二区线观看| 久久精品国产视频| 日韩在线免费av| 国产欧美精品va在线观看| 国产精品久久在线观看| 91精品视频在线播放| 另类视频在线观看| 国产成人97精品免费看片| 国产精品中文字幕在线观看| 成人国产精品色哟哟| 欧美激情在线狂野欧美精品| 成人女保姆的销魂服务| 91成人在线观看国产| 亚洲午夜精品久久久久久性色| 国产极品精品在线观看| 欧美成人黑人xx视频免费观看| 中文字幕亚洲情99在线|