成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

iOS實(shí)現(xiàn)逐幀動畫做loading視圖

瀏覽:87日期:2022-09-16 16:09:45

本文實(shí)例為大家分享了iOS實(shí)現(xiàn)逐幀動畫做loading視圖的具體代碼,供大家參考,具體內(nèi)容如下

我封裝了一個可復(fù)用的loading視圖組件,用于按照一定周期逐幀播放加載動畫。代碼如下:

.h文件

#import <UIKit/UIKit.h> //加載狀態(tài)typedef enum { FZImageSequenceLoadingStatusStop = 1, // 停止 FZImageSequenceLoadingStatusLoading, // 加載中 FZImageSequenceLoadingStatusError //發(fā)生錯誤} FZImageSequenceLoadingStatus; @interface FZImageSequenceLoadingView : UIView { UIImageView *_imageView; UILabel *_lblMsg; NSTimer *timer; int currentImageIndex;} @property(strong) NSArray *imageArray; //動畫序列的圖片數(shù)組 @property(strong, nonatomic) UIImage *errorImage; @property(nonatomic, strong) NSString *errorMsg; @property(nonatomic, strong) NSString *loadingMsg; //提示文字 @property(nonatomic) CGRect imageFrame; //圖片的Frame @property(nonatomic) CGRect msgFrame; //文字內(nèi)容的Frame @property(nonatomic) float timerInterval; //切換圖片的周期 /** 切換狀態(tài) */- (void)switchToStatus:(FZImageSequenceLoadingStatus)status; /** 通過圖片名字和數(shù)量設(shè)置圖片數(shù)組,如給定名字'name'、“.png”和數(shù)量4,則會去加載“name_1.png”到'name_4.png'的圖片 */- (void)setImageArrayByName:(NSString *)name andExtName:(NSString *)extName andCount:(int)count; @end

.m文件

#import 'FZImageSequenceLoadingView.h' @implementation FZImageSequenceLoadingView @synthesize errorImage;@synthesize errorMsg;@synthesize imageArray;@synthesize loadingMsg;@synthesize timerInterval; - (id)initWithFrame:(CGRect)frame{ self = [super initWithFrame:frame]; if (self) {timerInterval = 1;currentImageIndex = -1; } return self;} /* // Only override drawRect: if you perform custom drawing. // An empty implementation adversely affects performance during animation. - (void)drawRect:(CGRect)rect { // Drawing code } */ - (void)setupSubviews {// self.backgroundColor = [UIColor redColor]; if (self.imageArray && self.imageArray.count > 0) {if (!_imageView) { _imageView = [[UIImageView alloc] init]; [self addSubview:_imageView];}//讓圖片view為本view的頂部居中,大小為圖片數(shù)組中的第一張UIImage *firstImg = [self.imageArray objectAtIndex:0];_imageView.size = firstImg.size;_imageView.top = 0;_imageView.left = (self.size.width - _imageView.size.width) / 2; } if (self.loadingMsg) {CGSize labelSize = [self.loadingMsg sizeWithFont:[UIFont systemFontOfSize:11]];if (!_lblMsg) { _lblMsg = [[UILabel alloc] initWithFrame:CGRectZero]; _lblMsg.textAlignment = NSTextAlignmentCenter; [self addSubview:_lblMsg];}_lblMsg.font = [UIFont systemFontOfSize:11];_lblMsg.size = labelSize;_lblMsg.textColor = [UIColor darkGrayColor];_lblMsg.backgroundColor = [UIColor clearColor];_lblMsg.bottom = self.height;_lblMsg.left = (self.width - _lblMsg.width) / 2; }} - (void)switchToStatus:(FZImageSequenceLoadingStatus)status { if (!_lblMsg || !_imageView) {[self setupSubviews]; } switch (status) {case FZImageSequenceLoadingStatusError: [self switchToError]; break;case FZImageSequenceLoadingStatusLoading: [self switchToLoading]; break;case FZImageSequenceLoadingStatusStop: [self switchToStop]; break; }} - (void)switchToStop { [timer invalidate]; timer = nil; if (self.imageArray && self.imageArray.count > 0) {_imageView.image = [self.imageArray objectAtIndex:0]; }} - (void)switchToError { [timer invalidate]; timer = nil; //如果有錯誤狀態(tài)的圖 if (self.errorImage) {_imageView.image = self.errorImage;//如果沒有就用第一張動畫圖 } else if (self.imageArray && self.imageArray.count > 0) {_imageView.image = [self.imageArray objectAtIndex:0]; }if (self.errorMsg) {_lblMsg.text = self.errorMsg; }} - (void)switchToLoading { if (self.loadingMsg) {_lblMsg.text = self.loadingMsg; } if (!timer) {timer = [NSTimer scheduledTimerWithTimeInterval:self.timerInterval target:self selector:@selector(showNextImage) userInfo:nil repeats:YES]; }} - (void)showNextImage { if (!imageArray || imageArray.count < 1) {return; } currentImageIndex = (currentImageIndex + 1) % self.imageArray.count; // 主線程執(zhí)行: dispatch_async(dispatch_get_main_queue(), ^{_imageView.image = [imageArray objectAtIndex:currentImageIndex]; });} - (void)setImageArrayByName:(NSString *)name andExtName:(NSString *)extName andCount:(int)count { NSAssert((name && extName && (count > 0)), @'圖片名字和數(shù)量錯誤'); NSMutableArray *imgs = [NSMutableArray arrayWithCapacity:count]; for (int i = 1; i <= count; i++) {NSString *imgName = [NSString stringWithFormat:@'%@_%i%@', name, i, extName];UIImage *image = [UIImage imageNamed:imgName];NSLog(@'%@', image);if (!image) { continue;}[imgs addObject:image]; } self.imageArray = imgs;} @end

使用示例,在uiwebview中使用如下:

初始化視圖:

//設(shè)置loading視圖- (void)setupLoadingView { if (!_loadingView) {_loadingView = [[FZImageSequenceLoadingView alloc] initWithFrame:CGRectMake(0, 0, 170, 70)];_loadingView.center = self.view.center;[_loadingView setImageArrayByName:@'loading' andExtName:@'.png' andCount:10];_loadingView.loadingMsg = @'努力加載中,請稍候';_loadingView.errorMsg = @'加載失敗';_loadingView.timerInterval = 0.1;_loadingView.hidden = YES;[self.view addSubview:_loadingView]; }}

在uiwebview的代理方法中切換狀態(tài):

#pragma mark - webview delegate- (void)webViewDidStartLoad:(UIWebView *)webView { if (_loadingView.hidden) {_loadingView.hidden = NO;[_loadingView switchToStatus:FZImageSequenceLoadingStatusLoading]; }} - (void)webViewDidFinishLoad:(UIWebView *)webView { if (!_loadingView.hidden) {[_loadingView switchToStatus:FZImageSequenceLoadingStatusStop];_loadingView.hidden = YES; } }- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error { NSLog(@'load page error:%@', [error description]); if (!_loadingView.hidden) {[_loadingView switchToStatus:FZImageSequenceLoadingStatusError]; }}

目前該組件功能還不夠完善,但是能滿足目前我自己的需求,后續(xù)再繼續(xù)豐富。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: IOS
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲专区一二三| 欧美日韩mp4| 欧美亚洲国产一卡| 亚洲综合视频在线| 精品999日本| 国产亚洲精久久久久久| 成人激情免费电影网址| 7777精品伊人久久久大香线蕉| 喷白浆一区二区| 色吧成人激情小说| 天堂一区二区在线| 久久久久久色| 亚洲国产精品一区二区尤物区| 亚洲三级影院| 亚洲精品中文字幕乱码三区| 亚洲福利国产| 亚洲人成网站在线| 亚洲性视频h| 成人免费在线视频| 亚洲激情婷婷| 亚洲欧美偷拍三级| 国产三级精品在线不卡| 亚洲一区二区三区中文字幕| 亚洲少妇诱惑| 亚洲一区二区美女| 国产精品一国产精品k频道56| 亚洲一区二区精品视频| 久久动漫亚洲| 免费三级欧美电影| 欧美高清视频不卡网| 精品一区二区三区欧美| 欧美二区乱c少妇| 国产精品一色哟哟哟| 日韩欧美色电影| 国产成人a级片| 日韩女优毛片在线| 波多野结衣精品在线| 久久美女高清视频| 亚洲精选一区| 香蕉影视欧美成人| 欧亚洲嫩模精品一区三区| 久久9热精品视频| 6080午夜不卡| 99re热视频精品| 中文字幕亚洲电影| 国产伦精品一区二区三区照片91| 亚洲午夜羞羞片| 亚洲主播在线| 秋霞午夜av一区二区三区 | 欧美一三区三区四区免费在线看 | 一本色道久久综合亚洲精品高清| 亚洲成人av一区二区三区| 91久久精品午夜一区二区| 国产麻豆一精品一av一免费| 国产亚洲一区二区三区| 一级成人国产| 国模套图日韩精品一区二区 | 国产精品伦理在线| 夜夜爽99久久国产综合精品女不卡| 天天综合天天做天天综合| 91精品国产一区二区人妖| 99久久免费国产| 亚洲毛片av在线| 欧美专区在线观看一区| 波多野结衣一区二区三区| 亚洲天堂精品视频| 在线视频欧美区| 成人激情文学综合网| 一区二区中文视频| 在线亚洲高清视频| 91蜜桃在线观看| 天天操天天干天天综合网| 日韩女优电影在线观看| 狠狠爱综合网| 日本欧美久久久久免费播放网| 欧美一级片在线| 影音欧美亚洲| 精品伊人久久久久7777人| 国产日产欧美一区| 久久精品99| 成人午夜碰碰视频| 亚洲欧美在线观看| 欧美日韩高清一区二区不卡| 欧美视频二区| 欧美日韩一区二区视频在线 | 成人综合日日夜夜| 亚洲三级在线观看| 欧美日韩精品一区二区三区| 欧美日韩视频| 理论电影国产精品| 中文字幕一区二区三区不卡| 欧美日韩高清一区| 99精品国产一区二区青青牛奶| 国产精品一区二区在线看| 综合久久综合久久| 欧美一级日韩不卡播放免费| 国产精品久久久亚洲一区| 成人av午夜电影| 亚洲二区视频在线| 久久久不卡网国产精品二区| 久久综合九色综合久99| 欧美黄污视频| 国产真实乱偷精品视频免| 亚洲欧洲综合另类在线 | 性做久久久久久免费观看欧美| 精品国产91久久久久久久妲己 | 久久久99精品免费观看| 六月婷婷一区| 99久久国产综合精品麻豆| 日韩电影一区二区三区四区| 中文一区一区三区高中清不卡| 欧美日韩mp4| 国产亚洲精品自拍| 91麻豆免费观看| 精品一区二区三区欧美| 一区二区在线免费| 久久九九国产精品| 欧美精品三级在线观看| 国产精品一卡| 国内自拍视频一区二区三区| 粉嫩蜜臀av国产精品网站| 日本午夜精品视频在线观看| 中文字幕一区二区5566日韩| 欧美一级片在线观看| 91福利国产精品| 国产偷国产偷亚洲高清97cao| 91热门视频在线观看| 国产精品一区二区三区网站| 午夜精品免费在线观看| 国产精品欧美极品| 精品国产污网站| 欧美日韩国产精品自在自线| 久久久久久久波多野高潮日日| 亚洲经典在线看| 欧美精选一区| 不卡视频一二三| 激情伊人五月天久久综合| 香蕉久久夜色精品国产使用方法| 国产欧美一区二区精品久导航| 91精品国产欧美日韩| 91福利国产精品| 久久午夜影视| 国产乱人伦精品一区二区| 亚洲一级高清| 欧美日韩免费| 欧美女激情福利| 91美女蜜桃在线| 97久久精品人人做人人爽| 国产成人综合精品三级| 黑人巨大精品欧美黑白配亚洲| 天天色天天爱天天射综合| 亚洲在线一区二区三区| 亚洲视频一区二区在线观看| 国产日韩欧美激情| 久久久久久免费毛片精品| 欧美va在线播放| 精品久久久久久久久久久久久久久久久 | 成人黄色av电影| 国产麻豆精品视频| 国产一区福利在线| 久草热8精品视频在线观看| 免费在线成人网| 麻豆精品蜜桃视频网站| 人人狠狠综合久久亚洲| 午夜精品成人在线| 亚洲自拍偷拍网站| 亚洲精品va在线观看| 亚洲裸体xxx| 亚洲精品国产一区二区三区四区在线| 国产精品免费久久久久| 国产女人18水真多18精品一级做 | 国产女主播在线一区二区| 久久精品亚洲国产奇米99| 久久一日本道色综合| 精品国产91久久久久久久妲己 | 久久先锋资源网| 久久免费视频色| 久久久久久久久蜜桃| 久久先锋影音av鲁色资源网| 久久久精品免费免费| 国产女人aaa级久久久级 | 久久久噜噜噜久久狠狠50岁| 美日韩在线观看| 色哟哟国产精品| 在线观看成人小视频| 欧美熟乱第一页| 欧美老女人第四色| 7777精品伊人久久久大香线蕉完整版 | 亚洲五月婷婷| 99成人在线| 老鸭窝91久久精品色噜噜导演| 色综合久久久久久久久| 欧美日韩精品一区二区三区四区| 欧美日韩国产123区| 日韩欧美久久久| 国产亚洲精品7777| 亚洲欧美乱综合| 亚洲国产欧美日韩另类综合| 日本欧洲一区二区| 激情伊人五月天久久综合|