与android:drawableBottom属性结合使用时不显示的可绘制形状。

时间:2011-07-28 13:12:52

标签: android layout drawable shape

保存在res / drawable / gradient_box.xml的XML文件:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <gradient
        android:startColor="#FFFF0000"
        android:endColor="#80FF00FF"
        android:angle="45"/>
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp" />
    <corners android:radius="8dp" />
</shape>

(上面的形状定义取自当时的Android开发者指南。它没有错误。)。

让我们尝试将它与TextView一起使用:

<TextView 
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:text="Text with some crazy rectangle shape below it."
    android:drawableBottom="@drawable/gradient_box"/>   

TextView显示就像drawableBottom属性不存在一样!但是,将形状设置为背景可以正常工作:

<TextView 
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:text="Text with crazy background"
    android:background="@drawable/gradient_box"/>

将实际图像(例如* .png)设置为android:drawableBottom也可以正常工作。

有什么想法吗?

2 个答案:

答案 0 :(得分:32)

解决了!问题似乎是形状不一定具有内在界限。也就是说,得到的drawable不知道如何绘制自己!

要解决此问题,只需指定形状的大小,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <gradient
        android:startColor="#FFFF0000"
        android:endColor="#80FF00FF"
        android:angle="45"/>
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp" />
    <corners android:radius="8dp" />
    <size android:width="xxdp"
          android:height="xxdp"/>
</shape>

当形状被指定为TextView的背景可绘制时,其尺寸已知与TextView尺寸相同。当告诉形状向文本视图的右侧或上方移动时,无法自动确定形状尺寸。

答案 1 :(得分:2)

如果您使用ImageView将线条形状作为“android:src”属性的一部分来托管,除非您将宽度和高度指定为形状xml的一部分,否则您也会遇到同样的问题。一种解决方法是将线形托管为ImageView的“android:background”属性的一部分。这样,您可以利用ImageView的大小属性将线条形状“显示”通过。