IOS 开发自定义条形ProgressView的实例
2019/7/9 23:09:47
本文主要是介绍IOS 开发自定义条形ProgressView的实例,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
IOS 自定义进度条 ProgressView,好的进度条,让人赏心悦目,在等待的时候不是那么烦躁,也算是增加用户体验吧!
进度条在iOS开发中很常见的,我在项目开发中也写过好多进度条,有好多种类的,条形,圆形等,今天给大家总结一种条形的开发进度条。
简单思路:
1.自定义进度条先继承UIView 建立一个CustomBarProgressView
2.在.H文件中外漏的方法《开始的方法》《初始化的方法》
3.在.M文件中 利用定时器改变位置 实现进度条
#效果图
#部分代码
-(instancetype)initWithFrame:(CGRect)frame withStartNum:(CGFloat)startNum withEndNum:(CGFloat)endNum withSignNum:(CGFloat)signNum withTime:(CGFloat)time{ if (self = [super initWithFrame:frame]) { self.startNum = startNum; self.endNum = endNum; self.signNum = signNum; if(time == 0){ self.time = 0.1; }else{ self.time = time; } [self setUpSubViews]; } return self; } - (void)setUpSubViews { UIView *backView = [[UIView alloc] init]; backView.backgroundColor =BoomViewColor; backView.layer.cornerRadius = CornerRadius; backView.layer.masksToBounds = YES; [self addSubview:backView]; self.backView = backView; UIView *fontView = [[UIView alloc] init]; fontView.backgroundColor = UpViewColor; fontView.layer.cornerRadius = CornerRadius; fontView.layer.masksToBounds = YES; [self addSubview:fontView]; self.fontView = fontView; } -(void)progressViewStart{ if (self.timer == nil) { dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ self.timer = [NSTimer scheduledTimerWithTimeInterval:self.time target:self selector:@selector(changeProgressViewFrame:) userInfo:nil repeats:YES]; [[NSRunLoop mainRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes]; }); } } -(void)changeProgressViewFrame:(NSTimer *)timer{ //位置计算 CGFloat signProgress = (self.signNum - self.startNum) / (self.endNum - self.startNum); NSLog(@"==>>>%f",self.progress); if (self.progress >= signProgress){ [self.timer invalidate]; self.timer = nil; return; } self.progress += 0.01; [self setNeedsLayout]; } -(void)layoutSubviews{ [super layoutSubviews]; NSLog(@"==>>>%f",self.progress); self.backView.frame = self.bounds; self.fontView.frame = self.bounds; self.fontView.width = self.width * self.progress; }
PS:可以自己增加 进度条文字等修改大小 样式
别小看任何人,越不起眼的人。往往会做些让人想不到的事。。。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
这篇关于IOS 开发自定义条形ProgressView的实例的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-12Axios库资料:新手入门必读教程
- 2024-11-11Axios库项目实战:新手入门教程
- 2024-09-29Axios库教程:初学者必备指南
- 2024-08-29Axios库资料:新手入门指南与基本使用教程
- 2024-03-14system bios shadowed
- 2024-03-14gabios
- 2024-02-07iOS应用提交上架的最新流程
- 2024-02-06打包 iOS 的 IPA 文件
- 2023-12-07uniapp打包iOS应用并通过审核:代码混淆的终极解决方案 ?
- 2023-11-25uniapp IOS从打包到上架流程(详细简单) 原创