自定義條形ProgressView


進(jìn)度條在iOS開發(fā)中很常見的,我在項(xiàng)目開發(fā)中也寫過好多進(jìn)度條,有好多種類的,條形,圓形等,今天給大家總結(jié)一種條形的開發(fā)進(jìn)度條。系統(tǒng)的進(jìn)度條UIProgressView


簡單思路:
 1.自定義進(jìn)度條先繼承UIView 建立一個(gè)CustomBarProgressView
 2.在.H文件中外漏的方法《開始的方法》《初始化的方法》
 3.在.M文件中 利用定時(shí)器改變位置 實(shí)現(xiàn)進(jìn)度條

#######效果圖

1.gif

#######部分代碼


-(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{
    
    //位置計(jì)算
    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:可以自己增加 進(jìn)度條文字等修改大小 樣式

別小看任何人,越不起眼的人。往往會做些讓人想不到的事。。。
2016年09月26日 未完待續(xù)。。。需要Demo留下郵箱。。后續(xù)傳GitHub

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容