Android 如何将自定义样式应用于SwitchCompat
我想对SwitchCompat应用自定义样式。更改“打开”和“关闭”状态的可绘图项和文本。我怎样才能做到这一点?我找不到任何这样做的例子。我在styles.xml中尝试了以下操作,但显然我没有使用正确的父级:Android 如何将自定义样式应用于SwitchCompat,android,android-theme,android-appcompat,switchcompat,Android,Android Theme,Android Appcompat,Switchcompat,我想对SwitchCompat应用自定义样式。更改“打开”和“关闭”状态的可绘图项和文本。我怎样才能做到这一点?我找不到任何这样做的例子。我在styles.xml中尝试了以下操作,但显然我没有使用正确的父级: <style name="Switch" parent="android:Widget.AppCompat.Widget.CompoundButton.SwitchCompat"> <item name="android:textOn">@string/co
<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>
但是我还没有找到一种方法来更改开关的文本。下面的代码片段似乎不起作用。也许我需要设置更多的文本属性
switchView.setTextOn(context.getString(R.string.common_yes));
switchView.setTextOff(context.getString(R.string.common_no));
根据SwitchCompat源代码,应支持开/关文本:
{@link#setText(CharSequence)text}
属性控制开关标签中显示的文本,而
{@link#setTextOff(CharSequence)off}和{@link#setTextOn(CharSequence)on}文本
控制拇指上的文本
编辑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
最后,我找到了一种方法,可以在整个应用程序中应用相同的样式。
我在我的themes.xml
<item name="switchStyle">@style/Custom.Widget.SwitchCompat</item>
<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>
样式应包括父级
<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>
@style/MySwitchCompat
@颜色/口音
无衬线灯
询问如何实现这一目标的问题或示例可被视为“需要场外资源”。请重新表述您的问题,向我们展示您的尝试(它完全尝试过)。别忘了访问部分,看看这里欢迎什么样的问题。我将等待您的编辑/删除。谢谢。你确定你继承了其他属性吗。那么...怎么样
<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>