android 反向进度条,Android ProgressBar 反向进度条/进度条从右到左走

本文探讨了在Android中实现从右向左显示进度条的方法。提出了三种方案:修改ProgressBar的背景色、重写onDraw函数旋转画布,以及利用Drawable属性反向绘制进度条。最优方案是使用Drawable属性实现右对齐。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近的项目,有个需求需要使用条状图显示比例,并且右对齐,见下图:

217307_0.png

我想到了使用进度条,这样不就不需要在代码动态绘制条状了,省了很多活。

那么进度条怎样从右向左显示呢?

方案一:

将ProgressBar的前背景反着用,将前景色设置为和整个大背景同一色,将背景设置为你要的条状图颜色,这样就看不出实际的进度,看到的是进度背景,在视觉上看上去就是右对齐了。实际上还是原来那个进度条。

缺点:我这个进度条是放在ListView的item中的,点击listview,因为listview有选中的背景显示出来,这样ProgressBar的前景色就原形毕露了。

方案二:

重写ProgressBar的onDraw函数,通过旋转画布(Canvas)180度,达到自右至左的进度效果。这个方案理论上可行,网上有人旋转了90度,是可以的,参考地址:

https://www.xprogrammer.com/234.html

https://www.verydemo.com/demo_c131_i3507.html

关键代码:

@Override

protected synchronized void onDraw(Canvas canvas) {

switch (curr_mode)

{

case MODE_BOTTOM:

canvas.rotate(-90);

canvas.translate(-canvas.getHeight(), 0);

super.onDraw(canvas);

break;

case MODE_TOP:

canvas.rotate(90,canvas.getWidth(),0);

canvas.translate(10,0);

super.onDraw(canvas);

break;

}

此方案缺点:需要计算旋转中心点,比较复杂,由于对canvas旋转不熟,我最终没能旋转180度成功,哪位大神搞定了告诉我一声,共同学习

方案三:

此方案是最优方案,简单高效!利用Drawable本身的属性,反向绘制进度条。这里将backgroud注释掉,不显示backgroud,然后对前景色加上两个关键属性:android:clipOrientation=horizontal,android:gravity=right,这样就能做到从右到左画进度条。

android:clipOrientation=[horizontal | vertical]

android:gravity=[top | bottom | left | right | center_vertical |

fill_vertical | center_horizontal | fill_horizontal |

center | fill | clip_vertical | clip_horizontal] />

把对象放到容器的右边,不改变它的尺寸。当clipOrientation被设置为horizontal时,会在可绘制资源的左边进行裁剪。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值