例えば以下のような drawable を用意して Checkbox の android:button に指定したのが次のスクリーンショットの下2つです。
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:bottom="7dp"
android:left="7dp"
android:right="7dp"
android:top="7dp">
<selector>
<item android:state_checked="true">
<shape android:shape="oval">
<size
android:width="18dp"
android:height="18dp" />
<stroke
android:width="6dp"
android:color="#6666ff" />
</shape>
</item>
<item>
<shape android:shape="oval">
<size
android:width="18dp"
android:height="18dp" />
<stroke
android:width="2dp"
android:color="#cccccc" />
</shape>
</item>
</selector>
</item>
</layer-list>
<CheckBox
...
android:button="@drawable/checkbox"
... />
data:image/s3,"s3://crabby-images/2dd6e/2dd6e544c410c0dc7ec848158721d0934d8b5166" alt=""
全く同じコードで Activity の theme を Material Design Components for Android 1.0.0 に変えたのが次のスクリーンショットです。
data:image/s3,"s3://crabby-images/3293b/3293b90e33b5de5a388f52f82ec7b64054c049d0" alt=""
同じようになってますね。
全く同じコードで Activity の theme を Material Design Components for Android 1.1.0 に変えたのが次のスクリーンショットです。
data:image/s3,"s3://crabby-images/1b1d3/1b1d38322a3d5ef086401da85a98ba0c7a51ef85" alt=""
なんということでしょう!android:button で指定した drawable resource が Material Design の theme color で tint されるようになりました。tint で使われる色は colorControlActivated と colorOnSurface です。
この挙動を止めるには app:useMaterialThemeColors="false" を指定します。
<CheckBox
...
android:button="@drawable/checkbox"
app:useMaterialThemeColors="false"
... />
data:image/s3,"s3://crabby-images/7ced5/7ced5af067ba7cc7ec40ff6109b663b7c497693d" alt=""
tint されなくなりました!
0 件のコメント:
コメントを投稿