存于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"/>
设置一个实际的图像(例如a *.png)到android:drawableBottom也可以正常工作。
任何想法?
解决了!问题似乎是形状不一定有内在界限。也就是说,最终的可绘制对象不知道如何绘制自己!
要解决这个问题,只需指定形状的大小,如下所示:
<?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的尺寸相同。
如果你使用ImageView来承载线条形状作为"android:src"属性的一部分,你也会遇到同样的问题,除非你指定宽度和高度作为形状xml的一部分。一种解决方法是将线条形状作为ImageView的"android:background"属性的一部分。这样,你就可以利用ImageView的大小属性来"显示"线条形状。