【学习ios之路:UI系列】UIProgressView

实现类似读取数据进度条效果
效果图
代码如下:
①创建UIProgressView对象
1)定义属性

{
    NSTimer *_proTimer;//计时   
}
@property (nonatomic, retain) UIProgressView *proView;
//显示进度信息
@property (nonatomic, retain) UILabel *proLabel;
@property (nonatomic, assign) float proValue;//保存进度值

  //创建控件UIProgressView
    self.proView = [[UIProgressView alloc] initWithProgressViewStyle:UIProgressViewStyleDefault];

    //设置frame
    self.proView.frame = CGRectMake(10, 260, 300, 100); 
    //设置当前进度当前值
    self.proView.progress = 0;
   // self.proValue = 0.4;
    //设置进度条的颜色
    self.proView.progressTintColor = [UIColor orangeColor];
    //导轨的颜色
    self.proView.trackTintColor = [UIColor greenColor];
    //修改进度条的高度(仿射变换)
    self.proView.transform = CGAffineTransformMakeScale(1.0f,15.0f);
    //添加到当前的试图上
    [self.view addSubview:self.proView];
    //释放
    [self.proView release];

②设置Label显示进度值,

    //创建显示进度信息的label
    self.proLabel = [[UILabel alloc] initWithFrame:CGRectMake(100, 300, 120, 30)];
    self.proLabel.backgroundColor = [UIColor clearColor];

    //显示当前进度值
    self.proLabel.text = [NSString stringWithFormat:@"loading%1.f%%",self.proView.progress*100];
    [self.view addSubview:self.proLabel];
    [self.proLabel release];

③创建计时器,平处理事件

    //通过计时器循环改进度值
    _proTimer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(changeProgress) userInfo:nil repeats:YES];

//处理事件
- (void)changeProgress {
    //设置进度每次变化值
    self.proValue += 0.05;
    self.proView.progress = self.proValue;
    //显示实时的进度值
    self.proLabel.text = [NSString stringWithFormat:@"loading%1.f%%",self.proValue * 100];
    if (self.proValue >= 1) {
        self.proValue = 0;  
        self.proLabel.text = @"进度完成";
        //停止计数器
        [_proTimer invalidate];
    }


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值