java - 如何改进进度条匹配以跟随图像(颜色、角度、形状等)

标签 java android android-layout android-intent android-activity

我创建了一个圆形进度条,并使其尽可能遵循下图中的设计。

但我很难让它与下图中的设计相匹配(颜色、角度、形状等):

我不知道如何匹配:

  • 上面的颜色?
  • 还是形状?

我想要遵循的设计:

/image/ZVzZm.png

我当前的设计如下所示:

/image/nzyiL.png

到目前为止我的代码如下:

activity_main.xml

 <ProgressBar
        style="?android:attr/progressBarStyleHorizontal"
        android:id="@+id/progressBar"
        android:layout_width="240dp"
        android:layout_height="240dp"
        android:indeterminate="false"
        android:max="100"
        android:progress="75"
        android:progressDrawable="@drawable/style_circular_fill"
        android:secondaryProgress="10"
        android:layout_alignParentBottom="false"
        android:layout_alignParentStart="false"
        android:focusableInTouchMode="false"
        android:layout_alignParentTop="true"
        android:layout_marginTop="70dp"
        xmlns:android="http://schemas.android.com/apk/res/android" />

style_circular_fill.xml

<item android:id="@android:id/secondaryProgress">
    <rotate
        android:fromDegrees="270"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="270" >
        <shape
            android:innerRadiusRatio="2.5"
            android:shape="ring"
            android:thicknessRatio="20.0"
            android:useLevel="true" >
            <gradient
                android:centerColor="#A9E2F3"
                android:endColor="#A9E2F3"
                android:startColor="#A9E2F3"
                android:type="sweep" />
        </shape>
    </rotate>
</item>
<item android:id="@android:id/progress">
    <rotate
        android:fromDegrees="270"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="270" >
        <shape
            android:innerRadiusRatio="2.5"
            android:shape="ring"
            android:thicknessRatio="20.0"
            android:useLevel="true" >
            <gradient
                android:centerColor="#26ce61"
                android:endColor="#26ce61"
                android:startColor="#26ce61"
                android:type="sweep" />
        </shape>
    </rotate>
</item>

最佳答案

您可以尝试CircleProgress图书馆。他们提供的示例之一看起来与您的要求非常相似。

我没有使用过它,所以无法确认它的易用性。

为了保持平衡,请查看 this list进度条库。可能有一个库可以达到想要的效果。

关于java - 如何改进进度条匹配以跟随图像(颜色、角度、形状等),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30170186/

相关文章:

java - 将 Retrofit 原始响应作为 json 对象返回而不转换为任何特定类型的对象?

java - Android Studio 导致应用程序接收致命信号 6 (SIGABRT),代码 -6 (SI_TKILL)

android 布局 0dp 显示可疑尺寸错误

java - 从HashMap中获取包含字符串片段的key

java - OpenGL 中的字体度量

java - 来自单独 bundle 的 JPA 实体,使用主 bundle 中的一个连接

java - 暂停计时器然后继续

android - android:gradle:依赖版本相同

android - 具有线性布局的 AppBarLayout

android - 找不到以下类 : android. support.constraint.RelativeLayout