Flutter Web 中文字体显示异常问题
flutter web 在中文使用粗体的时候发现了两个问题
- 一个字的笔画颜色不相同
- 带有 ‘口’的字 这个口由于太粗出现了实体闭合的情况
解决方案
替换字体
对于这个问题解决的办法只有替换中文字体库,因为只有粗体才有问题,所以只需要添加粗体字体即可。我使用的阿里普惠字体。
遇到的问题
flutter 支持otf和ttf格式的字体,这两个的大小都在7-8M左右(中文字体都很大), 当加入字体后,如果服务器性能一般,会严重影响网页的加载速度,直接加载肯定不合适。
提速方案
- 使用
font-spider对 ttf 字体进行压缩,适配项目中出现的粗体字。把这个字体文件固定到 assets 中进行加载 - 为了适配其他网络字体,把 otf 文件(体积较小的)上传到cdn平台,提高下载速度,项目启动完成后进行异步下载,下载完成后使用
FontLoader进行加载完整字体包。 - 为了防止字体下载失败,可以加入重试机制
import 'package:flutter/services.dart';
import 'package:http/http.dart' as http;class FontUtil {FontUtil._();static bool _isLoadSuccess = false;static int retryCount = 0;static void loadFontRes() async {if (_isLoadSuccess == true || retryCount > 3) {return;}try {final response = await http.get(Uri.parse("https://oss.static.cn/AlibabaPuHuiTi-3-85-Bold.otf"));if (response.statusCode != 200) {_onLoadFontError();return;}final bytes = response.bodyBytes.buffer.asByteData();final loader = FontLoader(AppFontFamily.AlibabaPuHuiTiAll)..addFont(Future.value(bytes));await loader.load();_isLoadSuccess = true;print("loadFontSuccess");} catch (e) {_onLoadFontError();}}static void _onLoadFontError() {Future.delayed(Duration(minutes: 1), () {retryCount++;print("load error, retry time $retryCount");FontUtil.loadFontRes();});}static String get aliFont => _isLoadSuccess ? AppFontFamily.AlibabaPuHuiTiAll : AppFontFamily.AlibabaPuHuiTi;
}
相关文章:
Flutter Web 中文字体显示异常问题
flutter web 在中文使用粗体的时候发现了两个问题 一个字的笔画颜色不相同带有 ‘口’的字 这个口由于太粗出现了实体闭合的情况 解决方案 替换字体 对于这个问题解决的办法只有替换中文字体库,因为只有粗体才有问题,所以只需要添加粗体字体即可。我…...
【Nginx】设置https和http同时使用同一个端口访问
以下是一个同时使用 HTTP 和 HTTPS 并通过 8070 端口的配置示例: server {listen 8070;server_name your_domain.com;location / {root /var/www/html;index index.html;} }server {listen 8070 ssl;server_name your_domain.com;# SSL 证书和私钥的路径ssl_certif…...
clickhouse query_log 常用查询语句
1、查询一段时间耗时超过3秒的语句。 SELECT* FROMsystem.query_log WHEREquery_duration_ms > 30000AND event_time > 2024-12-31 15:50:00 AND event_time < 2024-12-31 17:50:00 ORDER BYevent_time desc;2、查询一段时间报错的语句 SELECT* FROMsystem.query_lo…...
【Linux】RPMSG通讯协议介绍
RPMSG协议通讯协议介绍 RPMSG,全称Remote processor Messaging。是一种核间通讯协议。在Linux Kernel中,已经内置了RPMSG。 Linux RPMSG基于共享内存,利用RPMSG可以高效的实现核间通信。比如Linux与FreeRTOS、Linux与Android,都可…...
Idea(中文版) 项目结构/基本设置/设计背景
目录 1. Idea 项目结构 1.1 新建项目 1.2 新建项目的模块 1.3 新建项目模块的包 1.4 新建项目模块包的类 2. 基本设置 2.1 设置主题 2.2 设置字体 2.3 设置注释 2.4 自动导包 2.5 忽略大小写 2.6 设置背景图片 3. 项目与模块操作 3.1 修改类名 3.2 关闭项目 1. I…...
深入理解 Android 中的 ActivityInfo
深入理解 Android 中的 ActivityInfo 在 Android 开发中,ActivityInfo 是一个非常重要的类,它包含了关于 Activity 的元信息。这些信息通常是从 AndroidManifest.xml 文件中提取的,开发者可以通过 ActivityInfo 类来获取和操作这些信息。本文…...
Linux初识——基本指令
我们在linux下输入各种指令,其实就相当于在windows中的相关操作,比如双击,新建文件夹等。 以下是相关基本指令基本用法 一.ls(显示当前目录下的所有文件和目录) 那如何显示当前目录(我们所在的位置&…...
c/c++ 里的进程间通信 , 管道 pipe 编程举例
(1)以下是一个网上的使用 pipe 编程的范例: #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <sys/types.h> #include <sys/wait.h>int main() {int pipefd…...
【C++笔记】红黑树(RBTree)深度剖析和AVL树的对比分析
【C笔记】红黑树(RBTree)深度剖析和AVL树的对比分析 🔥个人主页:大白的编程日记 🔥专栏:C笔记 文章目录 【C笔记】红黑树(RBTree)深度剖析和AVL树的对比分析前言一.红黑树的定义1.1 红黑树的概念1.2红黑树的规则1.3 红黑树对比A…...
Pytorch初学
创建虚拟环境 python控制台,jupyter notebook,python文件运行的差异,后续结合使用三者。 jupter主要可以对代码进行分割单独运行,主要做一些探索性工作。 数据集的常见存储模式 1、以标签命名图像。 2、单独存储图像的地址。 加载数据集…...
Golang学习笔记_20——error
Golang学习笔记_17——方法 Golang学习笔记_18——接口 Golang学习笔记_19——Stringer 文章目录 error1. 接口2. 创建3. 自定义错误4. 处理错误5. 实现Error接口 源码 error 在Go语言中,error 是一个内建的接口类型,用于表示和处理错误情况。它是Go语言…...
基于Vite+TS初始项目 | 不断更新
1 创建项目 1.1 初始化项目 # 创建项目 pnpm create vite# 使用vue-ts模板创建项目 pnpm create vite xyz-vue-app-ts --template vue-ts1.2 添加ts类型检查命令 添加 "type-check" 类型检查命令 {"name": "xyz-vue-app-ts-test","scri…...
R语言装环境Gcc报错以及scater包的安装
error: ‘timespec_get’ has not been declared in ‘::’ 80 | using ::timespec_get; 在conda 的虚拟环境中升级gcc的版本 conda install -c conda-forge gcc11 gxx11终极方法,在R的最新版本和环境下装啥都能成功!! 比如beyondcell的方法…...
关于量子神经网络的思考
其实在写这篇文章之前想了很多,主要是想法太超前,有可能颠覆未来机器智能行业甚至是影响世界。 1、计算机的历史 计算机的历史可以追溯到20世纪中叶,最早的电子计算机如ENIAC和EDVAC采用了冯诺依曼架构(John von Neumann Archit…...
注册中心如何选型?Eureka、Zookeeper、Nacos怎么选
这是小卷对分布式系统架构学习的第9篇文章,第8篇时只回答了注册中心的工作原理的内容,面试官的第二个问题还没回答,今天再来讲讲各个注册中心的原理,以及区别,最后如何进行选型 上一篇文章:如何设计一个注册…...
使用 Conda创建新的环境遇到的问题
下载速度很慢 1、更新 conda update -n base -c defaults conda2、清理缓存 conda clean --all解决方法 方法 1:关闭严格的渠道优先级 检查是否开启了严格渠道优先级: conda config --show channel_priority 如果返回 strict,说明启用了严…...
Flutter项目开发模版,开箱即用(Plus版本)
前言 当前案例 Flutter SDK版本:3.22.2 本文,是由这两篇文章 结合产出,所以非常建议大家,先看完这两篇: Flutter项目开发模版: 主要内容:MVVM设计模式及内存泄漏处理,涉及Model、…...
Spring Boot + Jasypt 实现application.yml 属性加密的快速示例
Jasypt(Java Simplified Encryption)是一个专为Java应用程序设计的开源加密库,旨在简化加密和解密流程,保护敏感数据如密码、API密钥等。 jasypt-spring-boot-starter允许开发者在Spring Boot应用中轻松地实现加密和解密功能。 本篇介绍使用 jasypt-spring-boot-starter 以…...
arcgisPro加载CGCS2000天地图后,如何转成米单位
1、导入加载的天地图影像服务,一开始是经纬度显示的。 2、右键地图,选择需要调整的投影坐标,这里选择坐标如下: 3、点击确定后,就可以调整成米单位的了。 4、切换后结果如下: 如有需要,可调整成…...
多模态论文笔记——GLIDE(DALL·E 2模型核心部件)
大家好,这里是好评笔记,公主号:Goodnote,专栏文章私信限时Free。本文详细介绍了OpenAI的DALLE 2模型中重要的组成部分,用于图像生成的GLIDE模型及其论文。 文章目录 论文背景扩散模型(Diffusion Models&…...
WaveTools终极指南:3步解锁鸣潮120帧流畅游戏体验
WaveTools终极指南:3步解锁鸣潮120帧流畅游戏体验 【免费下载链接】WaveTools 🧰鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 如果你正在玩《鸣潮》并且希望获得更流畅的游戏体验,那么WaveTools正是你需要的开…...
Phi-4-mini-reasoning 3.8B 时序预测应用初探:结合LSTM进行销售数据分析
Phi-4-mini-reasoning 3.8B与LSTM结合的销售预测实战 1. 场景痛点与解决方案 在零售行业,销售预测一直是个令人头疼的问题。传统方法要么单纯依赖历史销售数据,忽略了促销文案、市场活动等文本信息;要么需要人工提取文本特征,效…...
RedmiBook Pro15 2023锐龙版Linux调优指南:从内核编译到amd-pstate睿频实战
1. 开箱即用的Linux调优指南 RedmiBook Pro15 2023锐龙版搭载了AMD Ryzen 7 7840HS这颗性能强劲的APU,但在Linux环境下想要充分发挥其潜力,需要一些特殊的调优技巧。我最近刚入手这台笔记本,在Ubuntu 22.04上折腾了一周,总结出这套…...
网络协议分析AI应用:使用PyTorch进行加密流量分类与异常检测
网络协议分析AI应用:使用PyTorch进行加密流量分类与异常检测 1. 网络安全的新挑战与AI解决方案 现代网络环境中,加密流量占比已超过80%,传统基于规则和签名的检测方法面临严峻挑战。想象一下,网络安全工程师每天需要分析数百万个…...
C 语言中const与指针:三种常见写法辨析
摘要: const int *p 与 int const *p 含义相同,表示「通过指针不能修改所指对象」;int * const p 表示「指针本身不可再指向别处」。本文用经典与拓展示例说明差异,并给出工程实践建议。关键词: C 语言、const、指针、…...
从Level 6的解题过程,聊聊Linux通配符‘?’那些容易被忽略的细节和安全隐患
从CTF解题看Linux通配符的隐藏陷阱与安全实践 在Linux系统中,通配符是每个管理员和开发者日常操作中不可或缺的工具。?和*这两个看似简单的符号,背后却隐藏着许多不为人知的细节和潜在风险。最近在分析一个CTF题目(Level 6)时&a…...
墨语灵犀处理403 Forbidden错误:智能排查与解决方案生成
墨语灵犀处理403 Forbidden错误:智能排查与解决方案生成 遇到网站打不开,显示“403 Forbidden”,是不是感觉有点懵?这个错误在运维和开发中太常见了,它就像一道“禁止入内”的门,告诉你服务器收到了请求&a…...
Git多账号管理实战:SSH与HTTPS双协议配置指南
1. 为什么需要管理多个Git账号 作为一个开发者,你可能遇到过这样的场景:白天在公司用工作账号提交代码,晚上回家又想用个人账号维护自己的开源项目。这时候如果只有一个全局Git配置,就会遇到账号冲突的问题。我刚开始工作时就踩过…...
hive strict 严格模式
Hive的严格模式(Strict Mode)是一道经典的面试题。它的核心是一个安全防护机制,通过限制执行高风险的查询,来防止单个“烂SQL”拖垮整个集群。 🔒 严格模式禁止的三大类查询 在 hive.mapred.modestrict 模式下&#…...
GLM-4.1V-9B-Base实战案例:短视频封面图内容审核与敏感要素识别
GLM-4.1V-9B-Base实战案例:短视频封面图内容审核与敏感要素识别 1. 短视频封面审核的行业痛点 在短视频内容爆炸式增长的今天,封面图作为吸引用户点击的第一道门面,其内容质量直接影响平台生态和用户体验。然而,人工审核海量封面…...
