ProgressBar大家可能项目中都会用到,但是大部分都是根据UI给的符合项目主题的自定义形式的;
下面就是我们项目中一个显示学习进度的横向ProgressBar;
可以看到四个角都是圆角的,本人首先想到的是自定义,但是会发现四个角总是不能够实现,要不左侧会被切成直角,要不进度内侧会被切成直角,也是从网上查找分析,最终实现如下:
结合网上大神的示意,在此作个笔记,方便之后遇到直接拿来用,节省时间.
但是根据自定义的shape 或者是 layer-list却总是很难做到,几乎都是被clip成了直角的样子如上;
为什么是直角的?原因就是被clip给切了,所以我们不能够用clip,而要使用scale这个标签。而上面链接给出的解答是定义一个.9的图片就能满足要求,由于我们这里是纯色的一个进度,所以没有必要通过再制作一个.9的图片,而只需要通过同样的方法引用我们定义的一个shape就可以了;
好了,先上图(自动忽略边框,实际是没有)
xml
<ProgressBar