3

我注意到 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>

虽然仍然不起作用

4

5 回答 5

1

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

someSwitch.setTypeface(ResourcesCompat.getFont(context, R.font.roboto));
于 2019-01-08T08:43:47.463 回答
0

尝试

parent="Base.TextAppearance.AppCompat.Body1"

替换成这个

parent="TextAppearance.AppCompat.Widget.Switch"
于 2018-04-16T06:05:33.867 回答
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>
于 2018-04-16T06:17:51.323 回答
0

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

    my_switch.setSwitchTypeface(ResourcesCompat.getFont(context, R.font.my_font))
于 2019-09-10T00:12:59.083 回答
0

我现在使用android:textAppearance而不是android:switchTextAppearance自定义字体。我的开关风格也有Widget.AppCompat.CompoundButton.Switch作为父母

于 2020-06-26T10:37:05.460 回答