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

首頁 > 系統 > iOS > 正文

iOS利用CALayer實現動畫加載的效果

2020-07-26 03:08:14
字體:
來源:轉載
供稿:網友

首先來看看效果圖

實現過程如下

控制器調用就一句代碼:

[self showLoadingInView:self.view];

方便控制器如此調用,就要為控制器添加一個分類

.h文件

#import <UIKit/UIKit.h>#import "GQCircleLoadView.h"@interface UIViewController (GQCircleLoad)//顯示動畫- (void)showLoadingInView:(UIView*)view;//隱藏動畫- (void)hideLoad;@property (nonatomic,strong) GQCircleLoadView *loadingView;@end

.m文件

#import "UIViewController+GQCircleLoad.h"#import <objc/runtime.h>@implementation UIViewController (GQCircleLoad)- (GQCircleLoadView*)loadingView{ return objc_getAssociatedObject(self, @"loadingView");}- (void)setLoadingView:(GQCircleLoadView*)loadingView{ objc_setAssociatedObject(self, @"loadingView", loadingView, OBJC_ASSOCIATION_RETAIN_NONATOMIC);}- (void)showLoadingInView:(UIView*)view{ if (self.loadingView == nil) {  self.loadingView = [[GQCircleLoadView alloc]init]; } if (view) {  [view addSubview:self.loadingView];  self.loadingView.frame = view.bounds; }else{  UIWindow *appKeyWindow = [UIApplication sharedApplication].keyWindow;  [appKeyWindow addSubview:self.loadingView];  self.loadingView.frame = appKeyWindow.bounds; }}- (void)hideLoad{ [self.loadingView removeFromSuperview];}@end

接下來就是GQCircleLoadView繼承UIView,里面通過drawRect畫出圓圈,并且動畫的實現

#import "GQCircleLoadView.h"#define WINDOW_width [[UIScreen mainScreen] bounds].size.width#define WINDOW_height [[UIScreen mainScreen] bounds].size.heightstatic NSInteger circleCount = 3;static CGFloat cornerRadius = 10;static CGFloat magin = 15;@interface GQCircleLoadView()<CAAnimationDelegate>@property (nonatomic, strong) NSMutableArray *layerArr;@end@implementation GQCircleLoadView- (instancetype)initWithFrame:(CGRect)frame{ if (self = [super initWithFrame:frame]) {  self.backgroundColor = [UIColor clearColor]; } return self;}// 畫圓- (void)drawCircles{ for (NSInteger i = 0; i < circleCount; ++i) {  CGFloat x = (WINDOW_width - (cornerRadius*2) * circleCount - magin * (circleCount-1)) / 2.0 + i * (cornerRadius*2 + magin) + cornerRadius;  CGRect rect = CGRectMake(-cornerRadius, -cornerRadius , 2*cornerRadius, 2*cornerRadius);  UIBezierPath *beizPath=[UIBezierPath bezierPathWithRoundedRect:rect cornerRadius:cornerRadius];  CAShapeLayer *layer=[CAShapeLayer layer];  layer.path=beizPath.CGPath;  layer.fillColor=[UIColor grayColor].CGColor;  layer.position = CGPointMake(x, self.frame.size.height * 0.5);  [self.layer addSublayer:layer];  [self.layerArr addObject:layer]; } [self drawAnimation:self.layerArr[0]]; // 旋轉(可打開試試效果)// CABasicAnimation* rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.y"];// rotationAnimation.toValue = [NSNumber numberWithFloat: - M_PI * 2.0 ];// rotationAnimation.duration = 1;// rotationAnimation.cumulative = YES;// rotationAnimation.repeatCount = MAXFLOAT;// [self.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"];}// 動畫實現- (void)drawAnimation:(CALayer*)layer { CABasicAnimation *scaleUp = [CABasicAnimation animationWithKeyPath:@"transform.scale"]; scaleUp.fromValue = @1; scaleUp.toValue = @1.5; scaleUp.duration = 0.25; scaleUp.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseOut]; CABasicAnimation *scaleDown = [CABasicAnimation animationWithKeyPath:@"transform.scale"]; scaleDown.beginTime = scaleUp.duration; scaleDown.fromValue = @1.5; scaleDown.toValue = @1; scaleDown.duration = 0.25; scaleDown.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseOut]; CAAnimationGroup *group = [[CAAnimationGroup alloc] init]; group.animations = @[scaleUp, scaleDown]; group.repeatCount = 0; group.duration = scaleUp.duration + scaleDown.duration; group.delegate = self; [layer addAnimation:group forKey:@"groupAnimation"];}#pragma mark - CAAnimationDelegate- (void)animationDidStart:(CAAnimation *)anim{ if ([anim isKindOfClass:CAAnimationGroup.class]) {  CAAnimationGroup *animation = (CAAnimationGroup *)anim;  [self.layerArr enumerateObjectsUsingBlock:^(CAShapeLayer *obj, NSUInteger idx, BOOL * _Nonnull stop) {   CAAnimationGroup *a0 = (CAAnimationGroup *)[obj animationForKey:@"groupAnimation"];   if (a0 && a0 == animation) {    CAShapeLayer *nextlayer = self.layerArr[(idx+1)>=self.layerArr.count?0:(idx+1)];    [self performSelector:@selector(drawAnimation:) withObject:nextlayer afterDelay:0.25];    *stop = YES;   }  }]; }}- (void)drawRect:(CGRect)rect{ [super drawRect:rect]; [self drawCircles];}- (NSMutableArray *)layerArr{ if (_layerArr == nil) {  _layerArr = [[NSMutableArray alloc] init]; } return _layerArr;}@end

Demo就不上傳了,總共四個文件代碼已經全貼上了!

總結

以上就是這篇文章的全部內容了,有興趣可以試試打開上面的旋轉的動畫代碼,關閉旋轉代碼,進一步修改也可實現出QQ郵箱的下拉刷新效果,希望這篇文章的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品成久久久久三级| 欧美视频在线观看 亚洲欧| 欧美日韩亚洲一区二区| 91香蕉电影院| 欧美日韩国产精品| 国产欧美一区二区三区视频| 高清视频欧美一级| 日韩欧美一区二区在线| 国产日韩欧美夫妻视频在线观看| 欧美一区二区大胆人体摄影专业网站| 91成品人片a无限观看| 26uuu另类亚洲欧美日本老年| 日韩电影免费观看在线观看| 色综合色综合久久综合频道88| 精品成人国产在线观看男人呻吟| 国产精品午夜国产小视频| 亚洲视频在线免费看| 亚洲天堂男人天堂| 国产一区二区三区在线看| 性日韩欧美在线视频| 6080yy精品一区二区三区| 国产91在线播放九色快色| 国产精品欧美日韩| 欧美在线视频播放| 中文字幕视频一区二区在线有码| 夜色77av精品影院| 欧美资源在线观看| 日韩av大片免费看| 日韩av免费在线观看| 性欧美暴力猛交69hd| 亚洲国产婷婷香蕉久久久久久| 久久频这里精品99香蕉| 亚洲热线99精品视频| 久久99精品久久久久久青青91| 日韩电影中文字幕在线观看| 亚洲美女动态图120秒| 久久伊人精品一区二区三区| 在线看国产精品| 国产综合在线观看视频| 91亚洲永久免费精品| 日韩中文字幕免费看| 国产精品成熟老女人| 亚洲综合日韩在线| 色偷偷噜噜噜亚洲男人| 久久久久久尹人网香蕉| 亚洲999一在线观看www| 亚洲成人av在线播放| 日韩最新在线视频| 色与欲影视天天看综合网| 久久久久久久97| 久久精品国产亚洲一区二区| 欧美大片免费观看| 在线观看精品自拍私拍| 欧美极品在线播放| 日韩av在线导航| zzjj国产精品一区二区| 欧美日韩国产中字| 亚洲精品98久久久久久中文字幕| 国产精品激情av在线播放| 精品国产欧美一区二区三区成人| 中文字幕欧美专区| 欧美性xxxx在线播放| 国产精品视频久| 国产xxx69麻豆国语对白| 3344国产精品免费看| 欧美裸体xxxx极品少妇软件| 3344国产精品免费看| 一道本无吗dⅴd在线播放一区| 国产精品高潮呻吟久久av黑人| 欧美老妇交乱视频| 日韩免费在线观看视频| 亚洲欧美在线播放| 亚洲在线观看视频| 日韩电影免费在线观看中文字幕| 亚洲一区二区久久久久久久| 亚洲偷熟乱区亚洲香蕉av| 亚洲色图狂野欧美| 欧美精品久久久久久久免费观看| 国产日本欧美一区二区三区在线| 自拍偷拍亚洲在线| 亚洲999一在线观看www| 亚洲理论片在线观看| 91国产精品91| 国内外成人免费激情在线视频| 日韩欧美中文字幕在线观看| 91天堂在线视频| 国产精品永久免费视频| 亚洲国内精品在线| www高清在线视频日韩欧美| 最近中文字幕mv在线一区二区三区四区| 55夜色66夜色国产精品视频| 欧美日韩在线影院| 久久久精品网站| 91精品国产91久久久久久吃药| 欧美做受高潮电影o| 国产成+人+综合+亚洲欧美丁香花| 精品久久香蕉国产线看观看gif| 国产精品九九久久久久久久| 亚洲天堂男人天堂女人天堂| 国产一区二区三区中文| 亚洲欧美激情一区| 久久青草福利网站| 成人性生交大片免费看视频直播| 国产精品日日摸夜夜添夜夜av| 国产精品高清在线| 欧美日韩免费在线观看| 亚洲精品第一国产综合精品| 日韩电影在线观看永久视频免费网站| 91久久精品美女| 久久精品国产亚洲| 亚洲一区免费网站| 国产精品一区二区三区免费视频| 亚洲精品一二区| 国产精品第8页| 超在线视频97| 久久夜色精品国产亚洲aⅴ| 97在线视频精品| 欧洲成人午夜免费大片| 91国偷自产一区二区三区的观看方式| 亚洲国产中文字幕在线观看| 97色在线播放视频| 国产精品电影网站| 国产99久久精品一区二区 夜夜躁日日躁| 欧美精品日韩三级| 亚洲免费av片| 亚洲一二在线观看| 国产一区二区日韩| 久99久在线视频| 久久97精品久久久久久久不卡| 国内精品久久久久影院 日本资源| 亚洲国产欧美自拍| 国产精品99久久99久久久二8| 啊v视频在线一区二区三区| 一本色道久久88精品综合| 91av成人在线| 欧美日韩xxx| 欧美肥老太性生活视频| 欧美又大又硬又粗bbbbb| 精品久久久久久久久中文字幕| 久久91精品国产91久久跳| 国产在线a不卡| 欧美午夜视频一区二区| 亚洲成**性毛茸茸| 亚洲亚裔videos黑人hd| 久久视频国产精品免费视频在线| 日韩av一区在线观看| 欧美日韩亚洲精品一区二区三区| 欧美一级免费看| 91夜夜未满十八勿入爽爽影院| 日韩欧美在线视频日韩欧美在线视频| 久久久久久亚洲精品不卡| 精品久久久国产精品999| 欧美激情一区二区三区成人| 美女福利视频一区| 色综合视频网站| 国产玖玖精品视频| 高潮白浆女日韩av免费看| 国产精品视频公开费视频| 欧美日韩性视频| 成人黄色av网| 日韩免费高清在线观看| 黑人巨大精品欧美一区二区三区| 国产69久久精品成人| 久久99国产精品自在自在app|