你好,歡迎來到IOS教程網

 Ios教程網 >> IOS編程開發 >> IOS開發綜合 >> IOS 開發自定義條形ProgressView的實例

IOS 開發自定義條形ProgressView的實例

編輯:IOS開發綜合

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:可以自己增加 進度條文字等修改大小 樣式

別小看任何人,越不起眼的人。往往會做些讓人想不到的事。。。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved