如何修改SwitchCompat的字体系列?

时间:2018-04-16 06:00:11

标签: android xml switchcompat

我注意到SwitchCompat的字体似乎没有改变我在 fontFamily 字段中设置的内容。我还尝试将样式与自定义fontFamily(适用于TextViews )甚至 switchTextAppearance 字段一起使用。它确实适用于预览(我知道预览不是很准确),但在我尝试在我的测试设备上运行时却没有。

这是我的SwitchCompat:

<android.support.v7.widget.SwitchCompat
            style="@style/MyStyle.Body"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:fontFamily="@font/my_font_family"
            android:text="Enable"
            app:switchTextAppearance="@style/MyStyle.Body"/>

这是我的风格:

<style name="MyStyle.Body" parent="Base.TextAppearance.AppCompat.Body1">
    <item name="android:textSize">14sp</item>
    <item name="android:fontFamily">@font/my_font_family</item>
    <item name="android:textColor">@color/color_primary_text</item>
</style>

如你所见,我只想改变它的字体

修改

我已经改变了我的风格

<style name="MyStyle.Switch" parent="Widget.AppCompat.CompoundButton.Switch">
    <item name="android:textSize">14sp</item>
    <item name="android:textColor">@color/color_primary_text</item>
    <item name="android:fontFamily">@font/my_font_family</item>
    <item name="fontFamily">@font/my_font_family</item>
</style>

但仍然无法正常工作

5 个答案:

答案 0 :(得分:0)

尝试

parent="Base.TextAppearance.AppCompat.Body1"

替换为此

parent="TextAppearance.AppCompat.Widget.Switch"

答案 1 :(得分:0)

尝试以下

public class CustomSwitchCompact extends SwitchCompat {

    public CustomSwitchCompact(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        init();
    }

    public CustomSwitchCompact(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    public CustomSwitchCompact(Context context) {
        super(context);
        init();
    }

    private void init() {
        if (!isInEditMode()) {
            Typeface myFonts = Typeface.createFromAsset(getContext().getAssets(),
                    "fonts/Roboto_Bold.ttf");
            setTypeface(myFonts);
        }
    }
}

XML文件

<com.test.CustomSwitchCompact
        android:id="@+id/switch_compat"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:checked="false"
        android:padding="20dp"
        android:text="SwitchCompat"
        android:textOff="OFF"
        android:textOn="ON"
        app:showText="true" />

使用自定义字体实现SwitchCompact的另一种方法

  <android.support.v7.widget.SwitchCompat
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/adamSwitch"
        android:textColor="@color/top_color"
        android:textAppearance="@color/top_color"
        android:gravity="center"
        app:showText="true"
        android:fontFamily="@font/my_font_family"
        app:theme="@style/Custom.Widget.SwitchCompat"
        app:switchPadding="5dp"
        />

在style.xml中

<style name="Custom.Widget.SwitchCompat" parent="Widget.AppCompat.CompoundButton.Switch" >
            <item name="android:textColorPrimary">@color/blue</item>  
            <item name="android:textSize">14sp</item>
            <item name="android:fontFamily">@font/my_font_family</item>
             <item name="android:textColor">@color/color_primary_text</item>
      </style>

答案 2 :(得分:0)

XML设置不起作用,因此我使用以下代码:

someSwitch.setTypeface(ResourcesCompat.getFont(context, R.font.roboto));

答案 3 :(得分:0)

对我唯一有用的是setSwitchTypeface不是 setTypeface

    my_switch.setSwitchTypeface(ResourcesCompat.getFont(context, R.font.my_font))

答案 4 :(得分:0)

我用android:textAppearance代替了android:switchTextAppearance,自定义字体现在可以使用了。我的切换样式也以Widget.AppCompat.CompoundButton.Switch作为父项