【问题标题】:How to customize border width of ProgressBar如何自定义 ProgressBar 的边框宽度
【发布时间】:2018-08-15 09:35:05
【问题描述】:

我有一个默认进度条

对我来说,这是非常大的边界。如何制作这样的进度条(带细边框)?

我有一个简单的布局

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">


    <ProgressBar
        android:id="@+id/hello_progress_bar"
        android:layout_width="210dp"
        android:layout_height="210dp"

        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</android.support.constraint.ConstraintLayout>

【问题讨论】:

  • Jsut 将 android:layout_width 和 android:layout_height 放到 wrap_content 中,这对于 UI 来说是完美的
  • 我发布的答案真的对你有帮助,请检查

标签: android android-progressbar


【解决方案1】:
  1. 为您的进度创建一个可绘制形状的文件

    <?xml version="1.0" encoding="utf-8"?>
    <rotate xmlns:android="http://schemas.android.com/apk/res/android"
        android:fromDegrees="0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="360">
    
        <shape
            android:innerRadiusRatio="3"
            android:shape="ring"
            android:thicknessRatio="8"
            android:useLevel="false">
    
            <solid
                 android:color="#F3A523"/>
    
         </shape>
    
    </rotate>
    
  2. 在您的 ProgressBar 中使用它

     <ProgressBar
        android:id="@+id/progress_bar"
        android:layout_width="24dp"
        android:layout_height="24dp"
        android:indeterminate="true"
        android:progressDrawable="@drawable/progress_bar"
        android:indeterminateDrawable="@drawable/progress_bar"
      />
    

这样你可以通过drawable的thicknessRatio属性控制边框的宽度

【讨论】:

  • 我有默认的进度条(像this一样旋转)。我如何才能延长实质性进展并应用您的解决方案?
  • 首先,如果你想要 100% 的材质进度条 - 你不能改变它的宽度,因为那样它不会通过严格的材质要求。我的解决方案是材料进度条。我们改变的只是边框的宽度
  • 很伤心...我怎样才能无限旋转这个形状?
  • @EvgenyNaumov 我已经更新了我的答案,看看。简而言之 - 将 indeterminate 设置为 true 并为中间状态设置可绘制
  • 这对控制进度条的粗细很有效,但是会像普通进度条那样做一个完整的圆圈,没有进度的影响
【解决方案2】:

1> 为 Ring Progressbar 创建一个 Drawable progressbar.xml 并放入 进入drawabal文件夹。

 <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:id="@android:id/progress">
            <rotate android:toDegrees="360">
                <shape
                    android:shape="ring"
                    android:thickness="4dp"
                    android:innerRadiusRatio="3"
                    android:thicknessRatio="20.0">
                    <solid android:color="#FF4081" />
                </shape>
            </rotate>
        </item>
    </layer-list>

2> 将上面的 Drawable 设置到你的进度条中

 <?xml version="1.0" encoding="utf-8"?>
    <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">


        <ProgressBar
            android:id="@+id/hello_progress_bar"
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:layout_marginBottom="8dp"
            android:layout_marginEnd="8dp"
            android:layout_marginStart="8dp"
            android:layout_marginTop="8dp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            android:progressDrawable="@drawable/progressbar"
            android:indeterminateDrawable="@drawable/progressbar"
             />

    </android.support.constraint.ConstraintLayout>

在可绘制文件中设置以下属性

android:innerRadiusRatio="3"
android:thicknessRatio="20.0

希望对你有帮助

【讨论】:

    【解决方案3】:

    布局文件

     <ProgressBar
            android:id="@+id/progress"
            style="?android:attr/progressBarStyleHorizontal"
            android:layout_width="270dp"
            android:layout_height="270dp"
            android:layout_gravity="center"
            android:indeterminate="false"
            android:max="200"
            android:progress="100"
            android:progressDrawable="@drawable/progress" />
    

    可绘制/progress.xml

    <?xml version="1.0" encoding="utf-8"?>
    <shape xmlns:android="http://schemas.android.com/apk/res/android"
           android:innerRadiusRatio="2.3"
           android:shape="ring"
           android:thickness="10dp"
           android:useLevel="true">
    
          <solid android:color="#05b61c" />
    </shape>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-02-08
      • 2021-11-20
      • 1970-01-01
      • 1970-01-01
      • 2019-01-13
      • 1970-01-01
      • 2018-02-15
      • 1970-01-01
      相关资源
      最近更新 更多