Прогресс-бар с закругленными углами?

Я пытаюсь достичь этого дизайна индикатора выполнения: enter image description here

текущий код, который у меня есть, производит это: enter image description here

этот код:

<item android:id="@android:id/background">
    <shape>
        <corners android:radius="8dp"/>
        <solid android:color="@color/dirtyWhite"/>
    </shape>
</item>

<item android:id="@android:id/progress">
    <clip>
        <shape>
            <corners android:radius="8dp"/>
            <solid android:color="@color/colorPrimaryDark"/>
        </shape>
    </clip>
</item>

Мой индикатор прогресса:

 <ProgressBar
            android:id="@+id/activeProgress"
            style="?android:attr/progressBarStyleHorizontal"
            android:layout_width="300dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:progress="10"
            android:progressDrawable="@drawable/rounded_corners_progress_bar"/>

Я пробовал добавлять на <shape> на <clip чтобы сделать форму прогресса немного меньше, но это не сработало. Кроме того, индикатор прогресса плоский, и я хочу быть изогнутым в соответствии с дизайном. Что? Мне нужно измениться, чтобы достичь дизайна?

2 ответов


как сделать форму прогресса немного меньше?

вам нужно дать элементу прогресса небольшое дополнение, например:

<item android:id="@android:id/progress"
    android:top="2dp"
    android:bottom="2dp"
    android:left="2dp"
    android:right="2dp">

как сделать индикатор выполнения изогнутым согласно дизайну?

заменить <clip></clip> элемент, с <scale android:scaleWidth="100%"></scale>. Это заставит форму сохранять свою форму по мере роста - и не отрезать. К сожалению, это будет иметь немного нежелательный визуальный эффект в начале - так как углы формы не имеют достаточно места для рисования. Но в большинстве случаев этого вполне достаточно.

полный код:

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:id="@android:id/background">
    <shape>
        <corners android:radius="8dp"/>
        <solid android:color="@color/dirtyWhite"/>
    </shape>
 </item>

 <item android:id="@android:id/progress"
    android:top="1dp"
    android:bottom="1dp"
    android:left="1dp"
    android:right="1dp">

    <scale android:scaleWidth="100%">
        <shape>
            <corners android:radius="8dp"/>
            <solid android:color="@color/colorPrimaryDark"/>
        </shape>
    </scale>
 </item>
</layer-list>

спасибо Георгию Коемджиеву за хороший вопрос и изображения. Для тех, кто хочет сделать подобное своему, сделайте следующее.

1) Создайте фон для ProgressBar.

progress_bar_background.XML-код:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle"
    >
    <corners android:radius="3dp" />
    <stroke android:color="@color/white" android:width="1dp" />
</shape>

2) Создайте масштаб для ProgressBar.

curved_progress_bar.XML-код:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@android:id/background">
        <shape>
            <corners android:radius="2dp" />
            <solid android:color="@color/transparent" />
        </shape>
    </item>

    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <corners android:radius="2dp" />
                <solid android:color="#ffff00" />
            </shape>
        </clip>
    </item>
</layer-list>

3) в файл layout добавить ProgressBar.

<FrameLayout
    android:layout_width="match_parent"
    android:layout_height="6dp"
    android:layout_marginStart="20dp"
    android:layout_marginTop="10dp"
    android:layout_marginEnd="20dp"
    android:background="@drawable/progress_bar_background"
    >

    <ProgressBar
        android:id="@+id/progress_bar"
        style="@style/Widget.AppCompat.ProgressBar.Horizontal"
        android:layout_width="match_parent"
        android:layout_height="4dp"
        android:layout_margin="1dp"
        android:indeterminate="false"
        android:progressDrawable="@drawable/curved_progress_bar"
        />

</FrameLayout>