Android无裁剪的ProgressBar?

4
任何默认的ProgressBar都有一个ClipDrawable级别,例如在我的设备上,绿色的Drawable填充灰色背景,而在其他一些设备上是黄色的。
我的问题是:是否可能创建一个ProgressBar,在进度小于最大值时不显示这部分空白背景,或者我应该使用ImageView?我只需要ClipDrawable改变其宽度,这样它看起来像一个图表,而灰色背景从未出现。

只需将您的灰色背景更改为透明背景:android:color="@android:color/transparent" - Houcine
1个回答

5
创建像这样的layer-list可绘制对象。
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

<item android:id="@android:id/background">
    <shape android:shape="rectangle" >
        <solid android:color="@android:color/transparent" />
    </shape>
</item>

<item android:id="@android:id/secondaryProgress">
    <clip>
        <shape>
            <gradient
                    android:startColor="#234"
                    android:centerColor="#234"
                    android:centerY="0.75"
                    android:endColor="#a24"
                    android:angle="270"
            />
        </shape>
    </clip>
</item>

<item android:id="@android:id/progress">
    <clip>
        <shape>
            <gradient
                android:startColor="#144281"
                android:centerColor="#0b1f3c"
                android:centerY="0.75"
                android:endColor="#06101d"
                android:angle="270"
            />
        </shape>
    </clip>
</item>

主要是将带有android:id="@android:id/background的项目设置为@android:color/transparent

然后将其设置为ProgressBarandroid:progressDrawable属性

<ProgressBar
    android:id="@+id/progressBar"
    android:progressDrawable="@drawable/your_layer_list_created_on_previous_step"
    android:layout_width="fill_parent"
    android:layout_height="8dp" 
    style="?android:attr/progressBarStyleHorizontal"
    android:indeterminateOnly="false" 
    android:max="100" />

未填充的背景保持透明。现在我该如何添加自己的图片作为progressDrawable?谢谢。 - Droidman
没有得到更改..我有自己的可伸缩drawable,我想在背景保持透明的情况下将其用作ProgressBar。这就是我需要的东西。 - Droidman
然后,在具有android:id="@android:id/progress"layer-list项中,您必须删除shape及其内容,并像这样更新clip <clip android:drawable="@drawable/your_stretchable_drawable">。请参见此处的文档。 - vasart

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接