关于Android如何更换整个应用字体的总结

本文介绍如何利用 Android 8.0 的 Fonts in XML 特性全局替换 App 字体,包括设置字体资源、创建 Font Family 和在布局中使用字体资源的方法。此外,还详细列举了在实际项目中可能遇到的问题及解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

很久没写都东西,是觉得没什么要总结的,最近有个需求是在已经成熟的项目上更新所有视图的字体,特殊情况使用指定字体。

首先,方案大概有几个:

1.项目初期就将所有TextView之类的文本视图添加基类扩展,其他地方使用都是用继承的子类,比如CustomTextView这样。这种修改字体就比较简单了,只需要修改子类,不多说。

2.在基类Activity里面写一个通用方法,使用容器视图,比如ViewGroup作为参数,循环将子视图里面的字体设置为指定字体

3.使用第三方库

上面的方案都有一些弊端,比如修改量巨大、可能导入第三方库的视图可能无法修改字体,第三方库冗余大等,下面说一个Android8.0修改字体的方法,官方链接:

https://developer.android.com/preview/features/working-with-fonts.html


鉴于很多人没法翻墙,转载一下知乎用户翻译的大概步骤

Android O推出了一项新的功能「Fonts in XML」,借助这项功能,我们能够像使用其他资源文件一样使用字体,比较方便地实现App全局字体的替换。

为了能够在API 14或者以上的设备上使用Fonts in XML特性,我们需要使用到Support Library 26。更多的内容可以参考「使用Support Library」小节。


在Android Studio中按照如下步骤将字体作为资源文件添加至工程:

1. 右键单击项目的app / res文件夹,然后选择New > Android resource directory

2. 打开下拉菜单并选择font,输入font作为File name,点击OK

注意名称字体资源文件夹的名称必须为font
<img src="https://i-blog.csdnimg.cn/blog_migrate/255b4ec6234944cac3ea0b4d54e37dd8.png" data-rawwidth="1290" data-rawheight="792" class="origin_image zh-lightbox-thumb" width="1290" data-original="https://pic3.zhimg.com/v2-aa7a80cd3f8395c9b5ecec518893c6ae_r.png">

3. 将字体文件拖放到新的res / font文件夹中。Android O支持.otf(OpenType)和.ttf(TrueType)两种格式的字体文件。

<img src="https://i-blog.csdnimg.cn/blog_migrate/1ed52a1c1fcee58df23d213074b679f7.png" data-rawwidth="298" data-rawheight="141" class="content_image" width="298">

4. 双击字体文件可以在编辑器中对字体进行预览。


<img src="https://i-blog.csdnimg.cn/blog_migrate/b2985b195ef71e40565f660c8758521f.png" data-rawwidth="2855" data-rawheight="607" class="origin_image zh-lightbox-thumb" width="2855" data-original="https://pic4.zhimg.com/v2-9993efa9fbbd6958cc811a61d308c5cb_r.png">

创建Font family

在Android Studio中创建Font family的步骤如下:

1. 右键单击项目的res / font文件夹,然后选择New > Font resource file

2. 输入文件名,然后点击OK.

3. 打开此XML文件并定义该字体的所有不同版本,以及其样式和权重属性,例如:

<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:android="http://schemas.android.com/apk/res/android">
    <font
        android:fontStyle="normal"
        android:fontWeight="400"
        android:font="@font/lobster_regular" />
    <font
        android:fontStyle="italic"
        android:fontWeight="400"
        android:font="@font/lobster_italic" />
</font-family>

在XML布局中使用字体资源

给TextView添加字体

  • 在XML布局文件中,将fontFamily设置为你想要的访问的字体文件:
<TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:fontFamily="@font/lobster"/>
  • 打开Properties 窗口,设置TextView的字体:
  1. 选择一种视图打开Properties窗口
  2. 展开textAppearance,选择fontFamily表中的一种字体类型。
&amp;lt;img src=&quot;https://i-blog.csdnimg.cn/blog_migrate/f3ca52f61b696a40b88fa4f302ef7bba.png&quot; data-rawwidth=&quot;636&quot; data-rawheight=&quot;913&quot; class=&quot;origin_image zh-lightbox-thumb&quot; width=&quot;636&quot; data-original=&quot;https://pic4.zhimg.com/v2-10dc69fabcb9a429cd774e7a4499c587_r.png&quot;&amp;gt;
&amp;lt;img src=&quot;https://i-blog.csdnimg.cn/blog_migrate/6e01672c5f8198bfa3a7c504efbb140d.png&quot; data-rawwidth=&quot;3124&quot; data-rawheight=&quot;1249&quot; class=&quot;origin_image zh-lightbox-thumb&quot; width=&quot;3124&quot; data-original=&quot;https://pic3.zhimg.com/v2-571cf5901d1b9f79ee16ac1a6f6b9392_r.png&quot;&amp;gt;

添加字体至style

打开style.xml文件,将fontFamily属性设置为你想要访问的字体文件。

<style name="customfontstyle" parent="@android:style/TextAppearance.Small">
    <item name="android:fontFamily">@font/lobster</item>
</style>

在你的App的Theme中配置此属性即可实现整个App的字体替换。

使用代码控制字体

Typeface typeface = getResources().getFont(R.font.myfont);
textView.setTypeface(typeface);

使用Support Library

当我们通过Support Library实现Fonts in XML特性时,需要使用app命名空间。Support Library目前支持API 14及以上。

在Android Support Library 26.0-beta1中,必须同时使用android和app命名空间进行声明,以确保在Android O版本及以下设备上字体能够被正确加载。
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:android="http://schemas.android.com/apk/res/android"
             xmlns:app="http://schemas.android.com/apk/res-auto">
    <font android:fontStyle="normal" android:fontWeight="400" android:font="@font/myfont-Regular"
          app:fontStyle="normal" app:fontWeight="400" app:font="@font/myfont-Regular"/>
    <font android:fontStyle="italic" android:fontWeight="400" android:font="@font/myfont-Italic"
          app:fontStyle="italic" app:fontWeight="400" app:font="@font/myfont-Italic" />
</font-family>

通过代码控制:

Typeface typeface = ResourcesCompat.getFont(context, R.font.myfont);

这里补充下:getFont方法只能在8.0编译环境里面可以调用,低版本不行。


****************************注意下面开始说坑了****************************

目前使用案例极少,而且8.0的sdk都还没更新完整,源码都还没放出来,还是bate版本。

1.首先可能项目之前使用了各种V4,V7的support包,而且版本号不一样,比如:

compile 'com.android.support:appcompat-v7:23.2.1'
compile 'com.android.support:cardview-v7:25.3’

这种不同版本的情况,要统一成下面这样:

compile 'com.android.support:appcompat-v7:26.0.0-beta2'

库相同但版本号不同的就保留一个26+版本号的库,其他注释掉,如果你导入了本地第三方库,那么第三方库的引用的support版本也需要修改

2.编译环境记得做如下修改:
compileSdkVersion 26
buildToolsVersion '26.0.1'
最低兼容版本:
minSdkVersion 16

gradle:
classpath 'com.android.tools.build:gradle:3.0.0-alpha4'
gradle版本如果不够新就无法编译

3.如果你使用其他第三方库,比如apache的库可能会出现冲突,无论怎么编译不通过,如错误:
Error:Failed to resolve: org.apache.httpcomponents:httpclient:4.3.6
可以尝试直接去官方下载对应版本的jar然后从本地导入的方式解决问题

4.自定义系统样式必须继承于:Theme.AppCompat,否则你设置了:<item name="android:fontFamily">@font/coustom_font_family</item>,应用的字体也不会改变。

5.如果你编译通过了,也修改了系统样式并指定了默认字体,但页面字体还是存在没变化的情况,千万记得把继承TextView的类改成:AppCompatTextView,注意是这个包:
import android.support.v7.widget.AppCompatTextView;

6.说到第五点,想起还有个重要的点,Activity的基类必须继承:AppCompatActivity,否则应用的字体也不会变化。

7.如果在中给Activity设置了样式,那这个样式也必须是基于Theme.AppCompat的,否则打开页面就会挂,抛出这样的错误:
java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with xxx......

8.如果你在透明样式页面动态创建了继承了ImageView的视图,并且在自定义的view里面有对onDraw方法做处理,通过setContentView设置到页面时,那么必须手动调用一次imageView.setVisibility(View.VISIBLE),否则onDraw不会执行。当然这个一般人不会遇到这个情况,可以忽略。

总的来说这个方法虽然坑多,前期资料不足都会这样,但是从长远来看,个人感觉这个才是解决字体问题最好的方案,踩了几天坑,总结一下,希望其他朋友遇到时会有帮助
欢迎来群交流:126717686






<think>好的,我需要帮助用户解决如何在代码编辑器或IDE中更改光标或字体样式的问题。首先,我需要回顾用户提供的引用内容,看看有没有相关的信息可以借鉴。 用户提到了三个引用,其中引用[1]和引用[3]是关于使用Qt框架中的QFontDialog和QTextCursor来设置字体样式的代码示例。引用[2]则提到了在VS Code中通过设置editor.fontFamily、fontSize等选项来调整字体。虽然这些引用主要是关于字体设置的,但用户的问题还涉及到光标字体的更改,这可能需要进一步分析。首先,我需要明确“光标字体”具体指的是什么。通常,光标(cursor)在编辑器中指的是插入符号的形状或颜色,而不是字体本身。但用户可能是指文本插入点周围的字体样式,或者是在某种特定模式下(比如替换模式)光标的显示样式。不过,更有可能的情况是用户想调整文本编辑器中的字体样式,包括光标所在位置的文本字体。接下来,我需要分步骤思考如何在不同的编辑器中设置字体。常见的代码编辑器如VS Code、IntelliJIDEA、Qt Creator等,每个工具的设置方式可能不同。根据引用[2],VS Code可以通过修改settings.json中的editor.fontFamily来更改字体,这适用于整个编辑器的文本。而Qt相关的引用则展示了如何通过代码动态改变选中文本的字体样式,比如加粗。用户的问题可能包括两个方面:一是更改整个编辑器的默认字体,二是更改光标所在位置或选中文本的字体样式。我需要分别回答这两种情况。对于更改整个编辑器的字体,通常是在IDE的设置中找到字体选项进行调整。例如在VS Code中,用户可以通过文件->首选项->设置,搜索font,然后修改相应的选项。在QtCreator中,可以在工具->选项->文本编辑器->字体和颜色中调整。对于更改光标所在位置的字体样式,这通常涉及代码中的文本处理功能,比如使用QTextCursor来设置选中文本的格式,如引用[1]和[3]中的示例。这种情况下,可能需要编写代码来实现,比如通过快捷键触发字体样式的改变。另外,用户提到“光标字体”,可能需要确认是否指光标的形状或颜色。如果是光标本身的样式,不同编辑器的设置方式不同。例如,在VSCode中,可以通过editor.cursorStyle和editor.cursorWidth来调整光标的外观,但字体可能不直接相关。需要确保回答覆盖常见的编辑器和IDE,并给出具体步骤。同时,要区分整体字体设置和局部字体样式的调整,以及光标本身的样式设置。如果某些编辑器不支持直接更改光标字体,可能需要说明这一点,并提供替代方案。最后,生成相关问题,帮助用户深入理解主题,比如如何动态改变字体、不同IDE的设置差异等。</think>### 如何在代码编辑器/IDE中设置字体样式及光标相关配置 #### 一、设置编辑器整体字体 1. **VS Code** - 打开设置:`文件 > 首选项 > 设置` - 搜索`editor.fontFamily`,输入字体名称(如`Fira Code`) - 调整字体大小:`editor.fontSize`(如`15`) - 修改行高:`editor.lineHeight`(如`1.8`)[^2] 2. **Qt Creator** - 进入`工具 > 选项 > 文本编辑器 > 字体和颜色` - 选择字体类型和大小 3. **IntelliJ IDEA** - 打开`File > Settings > Editor > Font` - 修改`Primary font`和字号 --- #### 二、动态修改选中文本的字体样式(编程实现) 若需通过代码控制局部文本样式(如加粗),可参考Qt框架的实现: ```cpp void MainWindow::on_actionBold_triggered(bool checked) { QTextCursor cursor = textEdit->textCursor(); QTextCharFormat format; format.setFontWeight(checked ? QFont::Bold : QFont::Normal); cursor.mergeCharFormat(format); // 应用格式到选中文本 textEdit->mergeCurrentCharFormat(format); // 同步到后续输入 } ``` 此代码通过`QTextCursor`选中文本并设置字体粗细[^1][^3]。 --- #### 三、调整光标样式(非字体) 若需修改光标本身(如形状、颜色、闪烁频率): 1. **VS Code** - `editor.cursorStyle`: 可选`block`(方块)、`line`(竖线) - `editor.cursorBlinking`: 控制是否闪烁 2. **Sublime Text** - 在配置文件中添加: ```json { "caret_style": "solid", // 或"phase"、"blink" "caret_color": "#FF0000" } ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值