日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

iOS實現逐幀動畫做loading視圖

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

本文實例為大家分享了iOS實現逐幀動畫做loading視圖的具體代碼,供大家參考,具體內容如下

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

.h文件

#import <UIKit/UIKit.h> //加載狀態typedef enum { FZImageSequenceLoadingStatusStop = 1, // 停止 FZImageSequenceLoadingStatusLoading, // 加載中 FZImageSequenceLoadingStatusError //發生錯誤} FZImageSequenceLoadingStatus; @interface FZImageSequenceLoadingView : UIView { UIImageView *_imageView; UILabel *_lblMsg; NSTimer *timer; int currentImageIndex;} @property(strong) NSArray *imageArray; //動畫序列的圖片數組 @property(strong, nonatomic) UIImage *errorImage; @property(nonatomic, strong) NSString *errorMsg; @property(nonatomic, strong) NSString *loadingMsg; //提示文字 @property(nonatomic) CGRect imageFrame; //圖片的Frame @property(nonatomic) CGRect msgFrame; //文字內容的Frame @property(nonatomic) float timerInterval; //切換圖片的周期 /** 切換狀態 */- (void)switchToStatus:(FZImageSequenceLoadingStatus)status; /** 通過圖片名字和數量設置圖片數組,如給定名字'name'、“.png”和數量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的頂部居中,大小為圖片數組中的第一張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; //如果有錯誤狀態的圖 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; // 主線程執行: 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)), @'圖片名字和數量錯誤'); 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中使用如下:

初始化視圖:

//設置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的代理方法中切換狀態:

#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]; }}

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: IOS
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
成人亚洲一区| 国产精区一区二区| 精品久久在线| 国产精品tv| 国产精品115| 国际精品欧美精品| 91嫩草亚洲精品| www在线观看黄色| 日韩电影免费网站| 久久国产主播| 好看的亚洲午夜视频在线| 亚洲婷婷在线| 在线亚洲免费| 亚州av日韩av| 国产毛片精品| 国产精品日韩精品中文字幕| 欧美国产极品| 国产精品蜜芽在线观看| 成人av三级| 亚洲福利久久| 日韩视频二区| 日韩激情中文字幕| 国产精品一区毛片| 国产成人精品一区二区三区在线| 最新亚洲一区| 久久都是精品| 亚洲精品伊人| 久久久久九九精品影院| 国产精品tv| 久久男女视频| 99视频+国产日韩欧美| 综合欧美精品| 久久99久久人婷婷精品综合| 欧美精品高清| 日韩专区一卡二卡| 国产精品中文| 成人久久一区| 少妇精品久久久一区二区| 精品国产成人| 亚洲欧美日韩国产| 国产精品2023| 精品一区免费| 欧美一级二级视频| 香蕉视频亚洲一级| 亚洲人成网77777色在线播放| 久久国产亚洲| 亚洲深夜福利| 国产精品日韩精品中文字幕| 久久久精品网| 亚洲资源网站| 在线亚洲人成| 日韩黄色在线观看| 国产成年精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 激情五月综合| 日本在线视频一区二区| 久久久久免费| 四虎精品永久免费| 亚洲h色精品| 欧美一区在线观看视频| 成人看片网站| 18国产精品| 亚洲电影有码| 日本不卡一二三区黄网| 电影天堂国产精品| 国产精品资源| 亚洲丝袜啪啪| 欧美aa在线观看| 日本三级亚洲精品| 精品1区2区3区4区| 国产成人黄色| 欧美影院精品| 好吊日精品视频| 日韩.com| 欧美日韩亚洲三区| 性欧美69xoxoxoxo| 精品久久在线| 91精品日本| 亚洲制服少妇| 中文字幕在线高清| 欧美日韩18| 蜜臀国产一区二区三区在线播放| 一本一道久久a久久| 精品国产中文字幕第一页| 蜜桃一区二区三区在线| 首页国产精品| 国产欧美丝祙| 蜜臀精品一区二区三区在线观看| 日韩综合一区二区| 荡女精品导航| 中文一区一区三区免费在线观 | 一区二区三区四区日本视频| 免费成人性网站| 91精品91| 999久久久国产精品| 国产一区二区三区国产精品| 日本视频在线一区| 91久久久久| 久久精品主播| 成人亚洲一区| 欧美精品1区| 91在线成人| 亚洲资源网站| 在线免费观看亚洲| 黄色亚洲大片免费在线观看| 亚洲先锋成人| 欧美精品高清| 精品丝袜在线| 日韩国产欧美一区二区| 国产在线不卡一区二区三区| 免费看久久久| 欧美激情aⅴ一区二区三区| 日本免费新一区视频| 热久久国产精品| 亚洲欧美日韩在线观看a三区| 日韩精品1区2区3区| 夜夜嗨一区二区| 黄色成人精品网站| 三级精品视频| 激情欧美日韩一区| 久久久久久久久丰满| 久久久噜噜噜| 欧美手机在线| 日韩视频一区| 国产精品婷婷| 蜜臀av在线播放一区二区三区| 麻豆视频一区二区| 亚洲精品人人| 日本综合视频| 欧美精品三级在线| 日本欧美一区二区| 国产情侣久久| 麻豆91小视频| 久久精品国内一区二区三区| 麻豆成人综合网| 91日韩免费| 国产综合欧美| 午夜在线一区二区| 男女男精品网站| 日韩欧美久久| 国产精品22p| 黄色在线网站噜噜噜| 一本大道色婷婷在线| 激情婷婷亚洲| 亚洲一区二区三区四区电影| 97精品资源在线观看| 国产精品天天看天天狠| 国产精品99一区二区三区| 香蕉成人av| 黄色日韩精品| 日韩欧美中文字幕在线视频| 国产精品1区在线| 中文在线中文资源| 好看的av在线不卡观看| 天堂精品久久久久| 久久精品国产精品亚洲毛片| 日本免费一区二区三区四区| 国产亚洲福利| 91麻豆精品| a日韩av网址| 婷婷综合在线| 中文字幕亚洲精品乱码| 国产欧美大片| 波多视频一区| 亚洲欧美日韩精品一区二区 | 99久久夜色精品国产亚洲狼| 99精品一区| 亚洲我射av| 久久香蕉网站| 国产一区二区高清| 日本aⅴ精品一区二区三区 | 欧美日本久久| 免费一区二区三区在线视频| 91精品国产成人观看| 午夜av一区| 国产精品一区二区av日韩在线| 亚洲精品日本| 欧美成人aaa| 亚洲无线一线二线三线区别av| 精品国产不卡| 香蕉人人精品| 日韩一区二区三免费高清在线观看| 久久久久久久久99精品大| 成人羞羞在线观看网站| 亚洲午夜久久| 日韩综合精品| 天堂久久一区| 成人午夜精品| 欧美另类中文字幕| 欧美一区二区三区高清视频| 97久久亚洲| 四虎4545www国产精品 | 欧美日韩一区二区三区不卡视频| 伊人成人网在线看| 日韩不卡一二三区| 91精品国产91久久久久久黑人| 香蕉视频亚洲一级| 日韩精品免费视频人成| 天堂资源在线亚洲| 国产精品nxnn|