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

  次阅读 作者:智能小宝 来源:互联网 2015-10-03 10:59 我要评论(0)

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

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

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

方案一:

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

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

方案二:

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

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

http://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时,会在可绘制资源的左边进行裁剪。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...