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

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

iOS實現逐幀動畫做loading視圖

瀏覽:116日期: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久久,三上悠亚国产精品一区二区三区
久久精品72免费观看| 国产高清视频一区二区| 动漫av一区| 免费在线欧美黄色| 亚洲3区在线| 香蕉久久久久久| 亚洲美女久久| 综合亚洲视频| 日韩一区二区三免费高清在线观看 | 日韩精品永久网址| 丰满少妇一区| 日韩理论片av| 欧美1级日本1级| 影视先锋久久| 在线亚洲国产精品网站| 中文视频一区| 国产欧美自拍一区| 精品国产麻豆| 久久九九99| 噜噜噜躁狠狠躁狠狠精品视频 | 国产在线看片免费视频在线观看| 精品国产成人| 日本欧美不卡| 欧美女激情福利| 亚洲三级在线| 国产精品巨作av| 欧美日韩视频网站| 尹人成人综合网| 青青草精品视频| 国产成人精品一区二区三区视频| 亚洲国产影院| 亚洲精品欧美| 久久婷婷国产| 午夜影院欧美| 日韩av网站免费在线| 精品三级在线观看视频| 久久黄色影院| 亚洲我射av| 国产毛片精品| 欧美日韩免费观看视频| 乱人伦精品视频在线观看| 国产精品一页| 在线日韩欧美| 欧美精品三级在线| 日本精品影院| 视频一区日韩精品| 国产中文欧美日韩在线| 伊人久久成人| 久久av综合| 国产一区日韩一区| 久久国际精品| 日本精品不卡| 日韩精品一区二区三区免费视频| 麻豆mv在线观看| 亚洲精品系列| 蜜桃精品在线| 欧美有码在线| 激情综合网址| 国产亚洲久久| 九九综合九九| 久久av超碰| 久久高清一区| 高清av不卡| 日韩精品三区四区| 久久黄色影院| 国产精品一卡| 亚洲精品中文字幕乱码| 国产精品片aa在线观看| 9国产精品视频| 国产在视频一区二区三区吞精| 亚洲一区二区三区高清不卡| 国产精品男女| 老牛国产精品一区的观看方式| 成人污污视频| 欧美三区不卡| 国产亚洲精品v| 天堂中文av在线资源库| 日韩avvvv在线播放| 91九色精品国产一区二区| 国内揄拍国内精品久久| 日韩精品一区二区三区中文字幕| 久久精品青草| 麻豆国产精品| 日韩中文字幕在线一区| 国产一区日韩一区| 国产一区国产二区国产三区| 日本成人在线不卡视频| 久久国产电影| 国产一区二区精品久| 日韩精品亚洲专区| 亚洲午夜精品久久久久久app| 久久97久久97精品免视看秋霞| 中文字幕日韩亚洲| 欧美一级专区| 婷婷六月综合| 丝袜美腿一区| 国产一区二区三区亚洲| 国产日韩视频在线| 青草久久视频| 亚洲1区在线观看| 香蕉成人久久| 亚洲欧美日韩精品一区二区 | 亚洲一区二区三区免费在线观看 | 精品成av人一区二区三区| 天堂俺去俺来也www久久婷婷| 亚洲精品极品少妇16p| 日本精品不卡| 日本久久综合| 久久影视三级福利片| 日本91福利区| 亚洲毛片视频| 免费视频最近日韩| 亚洲一区日韩在线| 欧美日韩精品一本二本三本| 久久精品动漫| 999久久久91| 91精品国产自产在线观看永久∴| 久久久久久一区二区| 精品免费av| 欧美国产中文高清| 国产精品久久久久毛片大屁完整版 | 人人精品亚洲| 日韩欧美二区| 91亚洲一区| 久久久久国产精品一区三寸| 日本精品不卡| 婷婷丁香综合| 免播放器亚洲| 少妇精品在线| 国产欧美日韩精品一区二区免费 | 捆绑调教美女网站视频一区 | 69精品国产久热在线观看| 久久不射网站| 亚洲香蕉视频| 久久国际精品| 精品黄色一级片| 国产中文字幕一区二区三区| 国产精品毛片久久| 中文在线а√在线8| 亚洲性色av| 一区在线免费观看| 日av在线不卡| 欧美中文高清| 成人国产精品久久| 91精品国产调教在线观看| 亚洲精品网址| 天堂久久av| 麻豆精品视频在线观看免费| 成人在线超碰| 精品一区毛片| 亚洲18在线| 精品国产亚洲日本| 久久精品国产www456c0m| 国产99精品| 亚洲欧美日韩国产一区二区| 日韩高清欧美激情| 激情不卡一区二区三区视频在线| 久久精品国产www456c0m| 蜜桃传媒麻豆第一区在线观看| 91综合久久爱com| 精品视频在线一区二区在线| 久久精品1区| 蜜桃久久av| 国产伦精品一区二区三区千人斩| 国产一区二区三区四区五区传媒 | 精品一区在线| 亚洲日本三级| 国产精品久久久久久久免费观看| 91精品国产乱码久久久久久久| 中文亚洲欧美| 欧美一区影院| 欧美日韩视频免费观看| 日韩制服丝袜av| 欧美激情视频一区二区三区免费 | 欧美成人国产| 亚洲精品中文字幕99999| 麻豆精品在线视频| 欧美日韩在线观看视频小说| 中文字幕日本一区| 日韩av专区| 亚洲一级在线| 乱一区二区av| aa国产精品| 日韩超碰人人爽人人做人人添| 国产一区二区三区四区二区| 丝袜亚洲另类欧美| 国产不卡av一区二区| 免费日韩视频| 91亚洲国产高清| 日本欧美在线看| 日韩和的一区二在线| 欧美在线黄色| 九一国产精品| 欧美国产不卡| 久久亚洲风情| 欧美一区久久久| 国产麻豆精品| 亚洲一区二区三区中文字幕在线观看| 精品成人18| 91精品国产自产精品男人的天堂|