【发布时间】:2011-04-14 21:03:14
【问题描述】:
我有一个进度条,应该看起来像所附图片:
我已经走了很长一段路。我非常接近唯一不起作用的部分是progressDrawable的圆角。这是我的样子。 (注意,红圈,白色轮廓内的填充没有圆角):
所以,当进度条用形状、渐变或颜色着色时,我找到了几种方法来完成这项工作。但是,我无法将图像作为progressDrawable。
这是我扩展 ProgressBar 的类
public class RoundedProgressBar extends ProgressBar{
private Paint paint;
public RoundedProgressBar(Context context) {
super(context);
setup();
}
public RoundedProgressBar(Context context, AttributeSet attrs) {
super(context, attrs);
setup();
}
public RoundedProgressBar(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
setup(); ;
}
protected void setup()
{
paint = new Paint();
}
@Override
protected synchronized void onDraw(Canvas canvas) {
// First draw the regular progress bar, then custom draw our text
super.onDraw(canvas);
paint.setColor(Color.WHITE);
paint.setStyle(Paint.Style.STROKE);
RectF r = new RectF(0,0,getWidth()-1,getHeight()-1);
canvas.drawRoundRect(r,getHeight()/2,getHeight()/2, paint);
}
}
这是我的选择器:
<layer-list
xmlns:android="http://schemas.android.com/apk/res/android"
>
<item
android:id="@android:id/background"
android:drawable="@drawable/slider_track" />
<item
android:id="@android:id/secondaryProgress"
android:drawable="@drawable/slider_track" />
<item
android:id="@android:id/progress"
android:drawable="@drawable/slider_track_progress" />
</layer-list>
以下是选择器中使用的图像:
slider_track->
slider_track_progress->
这是我在我的活动布局中嵌入进度条的地方
<com.android.component.RoundedProgressBar
android:id="@+id/player_hp_bar"
android:layout_width="fill_parent"
android:layout_height="36dip"
android:layout_marginLeft="30dip"
android:layout_marginRight="30dip"
android:max="100"
style="?android:attr/progressBarStyleHorizontal"
android:progressDrawable="@drawable/slider_layer_list"
android:progress="20"
android:maxHeight="12dip"
android:minHeight="12dip"
/>
有人知道怎么做吗?
【问题讨论】:
-
我想通了,并在这里发了一个帖子:blog post
-
我在这里发布了一个类似问题的更新答案:stackoverflow.com/questions/2078809/…
标签: android layout progress-bar rounded-corners skinning