Android-圆形方形进度条
我正在尝试创建一个圆形的方形进度条来绘制图像周围的进度 到目前为止,我有以下XML定义了我的圆角正方形线:Android-圆形方形进度条,android,line,android-progressbar,rounded-corners,Android,Line,Android Progressbar,Rounded Corners,我正在尝试创建一个圆形的方形进度条来绘制图像周围的进度 到目前为止,我有以下XML定义了我的圆角正方形线: <shape xmlns:android="http://schemas.android.com/apk/res/android" > <stroke android:width="6dp" android:color="@android:color/holo_green_light" /> <paddin
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<stroke
android:width="6dp"
android:color="@android:color/holo_green_light" />
<padding
android:left="5dp"
android:right="5dp"
android:bottom="5dp"
android:top="5dp" />
<corners android:radius="50dp" />
</shape>
我知道这个解决方案:但我不感兴趣,因为效果不是我想要的
我曾尝试在圆角的正方形线上创建一个普通的圆,并尝试用PorterDuff将两者合并,但到目前为止,我还无法创建进度条效果。画一个圆形的饼图来画进度
我还尝试以编程方式创建圆角正方形,以防XML膨胀被视为普通图像,并且在PorterDuff合并过程中考虑了所有像素。但结果是一样的。试试这个简单的自定义类:
class V extends View {
Path path = new Path();
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
float length;
float[] intervals = {0, 0};
public V(Context context) {
super(context);
paint.setColor(Color.GREEN);
paint.setStyle(Paint.Style.STROKE);
paint.setStrokeWidth(20);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
path.reset();
RectF rect = new RectF(0, 0, w, h);
float inset = paint.getStrokeWidth();
rect.inset(inset, inset);
path.addRoundRect(rect, 100, 100, Path.Direction.CW);
length = new PathMeasure(path, false).getLength();
intervals[0] = intervals[1] = length;
PathEffect effect = new DashPathEffect(intervals, length);
paint.setPathEffect(effect);
}
public void setProgress(int progress) {
PathEffect effect = new DashPathEffect(intervals, length - length * progress / 100);
paint.setPathEffect(effect);
invalidate();
}
@Override
protected void onDraw(Canvas canvas) {
canvas.drawPath(path, paint);
}
}
测试代码(放入活动#onCreate
):
创建自定义的
Drawable
类,调用setProgressDrawable
@pskink时将使用该类,是的,谢谢,但是如何在线条上绘制正确的进度效果?是否创建了自定义的Drawable类?绘制round rect时有什么问题?目前,我只有一个视图类,它将XML可绘制转换为位图,然后我尝试在该位图上绘制以创建所需的效果(无限后期循环一次又一次地递增进度)。问题是,到目前为止,我还没有找到正确的方法来绘制进度效果。Wonderman先生库中的解决方案对我来说似乎不适用,因为我已经拐弯了,而且似乎也不太方便实现。您可以从以下简单的解决方案开始:
LinearLayout ll = new LinearLayout(this);
ll.setOrientation(LinearLayout.VERTICAL);
SeekBar sb = new SeekBar(this);
ll.addView(sb);
final V v = new V(this);
ll.addView(v);
setContentView(ll);
SeekBar.OnSeekBarChangeListener sbcl = new SeekBar.OnSeekBarChangeListener() {
@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
v.setProgress(progress);
}
@Override public void onStartTrackingTouch(SeekBar seekBar) {}
@Override public void onStopTrackingTouch(SeekBar seekBar) {}
};
sb.setOnSeekBarChangeListener(sbcl);