I would like to apply a custom style to SwitchCompat. Change drawables and text for on and off state. How can I achieve this? I can't find any examples on how this is done. I tried the following in my styles.xml but apparently I'm not using the right parent:
<style name="Switch" parent="android:Widget.AppCompat.Widget.CompoundButton.SwitchCompat"> <item name="android:textOn">@string/common_yes</item> <item name="android:textOff">@string/common_no</item> <item name="android:thumb">@drawable/btn_switch_selector</item> <item name="android:track">@drawable/btn_switch_bg_selector</item> </style>
Edit
I managed to change the drawables in code.
switchView.setThumbResource(R.drawable.btn_switch_selector); switchView.setTrackResource(R.drawable.btn_switch_bg_selector);
but I haven't found a way yet to change the text of the switch. The following snippet doesn't seem to work. Maybe I need to set some more text-properties?
switchView.setTextOn(context.getString(R.string.common_yes)); switchView.setTextOff(context.getString(R.string.common_no));
According to the SwitchCompat source code there should be support for on/off text: https://android.googlesource.com/platform/frameworks/support/+/421d8baa4a524e1384bcf033360bccaf8d55081d/v7/appcompat/src/android/support/v7/widget/SwitchCompat.java
The {@link #setText(CharSequence) text} property controls the text displayed in the label for the switch, whereas the {@link #setTextOff(CharSequence) off} and {@link #setTextOn(CharSequence) on} text controls the text on the thumb.
Edit 2
Finally found a code solution. Apparently setShowText()
needs to be set to true
for the text to appear on the switch.
switchView.setTextOn(context.getString(R.string.common_yes)); switchView.setTextOff(context.getString(R.string.common_no)); switchView.setShowText(true); switchView.setThumbResource(R.drawable.btn_switch_selector); switchView.setTrackResource(R.drawable.btn_switch_bg_selector);
and xml solution
<android.support.v7.widget.SwitchCompat android:id="@+id/view_switch" android:layout_width="wrap_content" android:layout_height="wrap_content" android:thumb="@drawable/btn_switch_selector" app:track="@drawable/btn_switch_bg_selector" android:textOn="@string/common_yes" android:textOff="@string/common_no" app:showText="true" />
I'd still like to know if there is a way to put this in styles.xml
.
Finally I found a way to apply the same style throughout my whole app. I put the following line in my themes.xml
<item name="switchStyle">@style/Custom.Widget.SwitchCompat</item>
And the following in my styles.xml
<style name="Custom.Widget.SwitchCompat" > <item name="android:thumb">@drawable/btn_switch_selector</item> <item name="track">@drawable/btn_switch_bg_selector</item> <item name="showText">true</item> <item name="android:textOn">@string/common_yes</item> <item name="android:textOff">@string/common_no</item> </style>
The style should include the parent
<item name="switchStyle">@style/MySwitchCompat</item> <style name="MySwitchCompat" parent="Widget.AppCompat.CompoundButton.Switch"> <item name="android:textColor">@color/accent</item> <item name="android:fontFamily">sans-serif-light</item> </style>
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With