设计一个进度条

31 篇文章 0 订阅
  1. 自定义一个UIView的子类
//提供一个成员属性,接收下载进度值
 @property (nonatomic, assign) CGFloat progress;
  1. 重写成员属性progress的setter
//每次改变成员属性progress的值,就会调用它的setter
 - (void)setProgress:(CGFloat)progress
 {
   _progress = progress;
   //当下载进度改变时,手动调用重绘方法
   [self setNeedsDisplay];
 }
  1. 重写(核心)
 - (void)drawRect:(CGRect)rect
 {
   //设置圆弧的半径
   CGFloat radius = rect.size.width * 0.5;
   //设置圆弧的圆心
   CGPoint center = CGPointMake(radius, radius);
   //设置圆弧的开始的角度(弧度制)
   CGFloat startAngle = - M_PI_2;
   //设置圆弧的终止角度
   CGFloat endAngle = - M_PI_2 + 2 * M_PI * self.progress;
   //使用UIBezierPath类绘制圆弧
   UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center radius:radius - 5 startAngle:startAngle endAngle:endAngle clockwise:YES];
   //将绘制的圆弧渲染到图层上(即显示出来)
   [path stroke];
 }
好的,设计一个进度条色带,同时以文字显示完成比例的方法如下: 1. 首先,我们需要一个容器来放置进度条和文字,可以使用 div 标签来创建一个容器。 2. 在容器创建一个 div 元素作为进度条,设置宽度为 0,高度为一定值,背景色为进度条的颜色。 3. 在进度条创建一个 div 元素作为色带,设置宽度为 0,高度为进度条的高度,背景色为色带的颜色。 4. 在容器创建一个 span 元素作为文字,设置文字内容为完成比例,初始值为 0%。 5. 使用 JavaScript 来控制进度条和文字的显示。当任务完成一定比例时,通过改变进度条和色带的宽度来显示进度,同时更新文字内容为完成比例。 以下是示例代码: HTML 代码: <div class="progress-container"> <div class="progress-bar"> <div class="progress-band"></div> </div> <span class="progress-text">0%</span> </div> CSS 代码: .progress-container { width: 100%; height: 20px; background-color: #f5f5f5; border-radius: 5px; margin-bottom: 20px; } .progress-bar { width: 0%; height: 100%; background-color: #4CAF50; border-radius: 5px; transition: width 0.5s ease-in-out; } .progress-band { width: 0%; height: 100%; background-color: #8BC34A; border-radius: 5px; transition: width 0.5s ease-in-out; } .progress-text { font-size: 14px; color: #333; margin-left: 10px; } JavaScript 代码: var progress = 0; var progressBar = document.querySelector('.progress-bar'); var progressBand = document.querySelector('.progress-band'); var progressText = document.querySelector('.progress-text'); function updateProgress() { progress += 10; progressBar.style.width = progress + '%'; progressBand.style.width = progress + '%'; progressText.textContent = progress + '%'; } setInterval(updateProgress, 1000); // 模拟任务完成的进度更新
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值