如何将自定义样式应用于SwitchCompat

时间:2014-12-19 08:14:45

标签: android android-theme android-appcompat switchcompat

我想将自定义样式应用于SwitchCompat。更改可打开和关闭状态的drawable和文本。我怎样才能做到这一点?我无法找到有关如何完成此操作的任何示例。我在styles.xml中尝试了以下内容,但显然我没有使用正确的父:

<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>

修改

我设法改变了代码中的drawable。

switchView.setThumbResource(R.drawable.btn_switch_selector);
switchView.setTrackResource(R.drawable.btn_switch_bg_selector);

但我还没有找到改变开关文字的方法。以下代码段似乎无法正常工作。也许我需要设置更多的文本属性?

switchView.setTextOn(context.getString(R.string.common_yes));
switchView.setTextOff(context.getString(R.string.common_no));

根据SwitchCompat源代码,应该支持开/关文本: https://android.googlesource.com/platform/frameworks/support/+/421d8baa4a524e1384bcf033360bccaf8d55081d/v7/appcompat/src/android/support/v7/widget/SwitchCompat.java

{@link #setText(CharSequence)text} property控制交换机标签中显示的文本,而 {@link #setTextOff(CharSequence)off}和{@link #setTextOn(CharSequence)on} text 控制拇指上的文字。

修改2

终于找到了一个代码解决方案。显然,setShowText()需要设置为true才能使文本显示在交换机上。

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);

和xml解决方案

<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" />

我仍然想知道是否有办法将其放入styles.xml

2 个答案:

答案 0 :(得分:11)

最后,我找到了一种在整个应用程序中应用相同样式的方法。 我在我的themes.xml

中添加了以下行
<item name="switchStyle">@style/Custom.Widget.SwitchCompat</item>

以下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>

答案 1 :(得分:2)

样式应包括父

ind = np.setdiff1d(np.arange(len(a)), ignInd)