Android Lの下にXXRadiusでフィレット背景画像を表示できないように設定

2972 ワード

コントロールのbackgroundを設定する例:
<Button
        android:id="@+id/btn1"
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:text="btn1"
        android:background="@drawable/btn1"/>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="#ffffffff" />
    <corners android:topLeftRadius="5dp" android:topRightRadius="5dp"  />
    <padding android:top="5dp"/> 
</shape><!-- Android L     -->
<Button
        android:id="@+id/btn2"
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:text="btn2"
        android:background="@drawable/btn2" />
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="#ffffffff" />
    <corners android:topLeftRadius="5dp" android:topRightRadius="5dp" android:bottomLeftRadius="5dp" android:bottomRightRadius="5dp" />
    <padding android:top="5dp"/> 
</shape><!-- Android L     -->
<Button
        android:id="@+id/btn3"
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:text="btn3"
        android:background="@drawable/btn3"/>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="#ffffffff" />
    <corners android:radius="5dp"/>
    <padding android:top="5dp"/> 
</shape><!--  -->
<Button
        android:id="@+id/btn4"
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:text="btn4"
        android:background="@drawable/btn4"/>
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@android:color/white" />
            <corners android:bottomLeftRadius="5dp" android:bottomRightRadius="5dp"/>
            <padding android:bottom="5dp" />
        </shape>
    </item>
</selector><!--  -->

まとめて、(1)shapeにはXXRadiusが入っていてAndroid Lでは表示できません.(2)selectorにはXXRadiusが入っており、Android Lで正常に表示されます.(3)shapeにはandroid:radiusを使用し、Android Lで正常に表示されます.(4)互換性のためにshapeをselectorに置き換えることができる.