Возможно ли сделать закругленные углы в пользовательском Progressbar progressDrawable?

У меня есть индикатор выполнения, который должен выглядеть как прикрепленное изображение:

И я проделал длинный путь. Я очень близко, единственная часть, которая не работает, это закругленные углы для 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"
/>

Кто-нибудь знает, как заставить это работать?

2 ответа

Не уверен, что вы действительно можете закруглить края с помощью API, но вы могли бы очень легко добавить новый слой между белым контуром и вашим реальным объектом прогресса? Слой может быть точным вырезом белого контура, и поэтому индикатор выполнения не будет отображаться за пределами контура.

Попробуйте это, вы можете сделать то, что вы хотите, изменив цвет, ширину и высоту большого пальца и панель поиска в XML.

Вы можете увидеть изображение здесь

Этот sulotion был единственным способом, которым я мог сделать это. Надеюсь это поможет

это моя панель поиска:

         <SeekBar
            android:id="@+id/simpleProgressBar"
            android:layout_width="fill_parent"
            android:layout_height="12dp"
            android:max="100"
            android:progress="0"
            android:background="@null"
            android:shape="oval"
            android:splitTrack="false"
            android:progressDrawable="@drawable/progress_background"
            android:secondaryProgress="0"
            android:thumbOffset="10dp"
            android:thumb="@drawable/oval_seekbar_thumb" />

это (progress_background.xml):

<item android:id="@android:id/background">
    <shape android:shape="rectangle">
        <corners android:radius="5dp" />

        <gradient
            android:angle="270"
            android:endColor="@color/grey_line"
            android:startColor="@color/grey_line" />
    </shape>
</item>
<item android:id="@android:id/secondaryProgress">
    <clip>
        <shape android:shape="oval">
            <corners android:radius="5dp" />
            <gradient
                android:angle="270"
                android:endColor="@color/blue"
                android:startColor="@color/blue" />
        </shape>
    </clip>
</item>
<item android:id="@android:id/progress">
    <clip>
        <shape android:shape="rectangle">
            <corners android:radius="90dp" />

            <gradient
                android:angle="90"
                android:endColor="@color/colorPrimaryDark"
                android:startColor="@color/colorPrimary" />
        </shape>
    </clip>
</item>

и это большой палец (oval_seekbar_thumb.xml):

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="oval">
            <solid android:color="#ffffff" />
            <stroke android:color="@color/colorPrimaryDark" android:width="3dp"/>
            <size android:height="12dp" android:width="12dp"/>
        </shape>
    </item>
</selector>

Высота большого пальца должна быть такой же, как высота панели поиска, чтобы выглядеть правильно.

Другие вопросы по тегам