Harmonyos之字体设置功能

概述

字体大小适配是我们app在适配过程中比较常用的一个适配项, 这里我们学习下在鸿蒙项目适配中是如何实现 ,自定义字体显示文本、自定义字体恢复为系统字体、字体大小跟随系统设置、字体大小不跟随系统设置等功能。

PreferenceUtils(工具类)

const TAG = 'PreferenceUtils';
const TEXT_FONT_SIZE = 'textFontSize';
const TEXT_FONT_WEIGHT = 'textFontWeight';
const TEXT_FONT = 'textFont';

export class PreferenceUtils {
   
   
  preference?: preferences.Preferences;

  // 创建PreferenceUtils实例
  getTextFontPreference(context: Context) {
   
   
    try {
   
   
      this.preference = preferences.getPreferencesSync(context, {
   
    name: 'TextFontPreference' });
      hilog.info(0x0000, TAG, 'create preference success');
    } catch (err) {
   
   
      let error = err as BusinessError;
      hilog.error(0x0000, TAG, `create preference faile. code: ${
   
   error.code}, message:${
   
   err.message}`);
    }
  }

 // 保存修改的字体大小
  saveModifyFontSize(fontValue: number) {
   
   
    try {
   
   
      this.preference?.putSync(TEXT_FONT_SIZE, fontValue);
      this.preference?.flush((err: BusinessError) => {
   
   
        if (err) {
   
   
          hilog.error(0x0000, TAG, `Failed to flush. code:${
   
   err.code}, message:${
   
   err.message}`);
          return;
        }
      })
    } catch (err) {
   
   
      let error = err as BusinessError;
      hilog.error(0x0000, TAG,
        `putSync or flush fontSize preference data faile. code: ${
   
   error.code}, message:${
   
   err.message}`);
    }
  }

  // 获取当前缓存的字体大小
  getFontSize(): number {
   
   
    let textFontSize: number = 0;
    try {
   
   
      textFontSize = this.preference?.getSync(TEXT_FONT_SIZE, 0) as number;
    } catch (err) {
   
   
      let error = err as BusinessError;
      hilog.error(0x0000, TAG, `getSync fontSize preference data faile. code
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值