NGUI中如何减少CacheFontForText耗时

在NGUI中,UILabel里的CacheFontForText耗时一直是个大问题
这里写图片描述

CacheFontForText是在UILabel在渲染时,在对应的字体的FontTexture找不到需要渲染的字符时,就会重新生成FontTexture,FontTexture尺寸越大,重新生成这张FontTexture就越耗时。

网上已经有一些解决方案了,大多数是一开始就将FontTexture撑大,减少CacheFontForText的频率,但这种解决方案有个缺点,一旦在这张比较大的FontTexture里找不到对应的字符时,需要重建的时间反而更大,也就是说,从频繁的小卡变成了偶尔一次的大卡,特别是在频繁打开UI或者聊天内容刷新比较频繁时。

这里,我们另辟蹊径,在不撑大FontTexture的前提下,减少触发概率。

解决方案其实已经有了,NGUI已经提供了静态字体,那我们就将静态字体利用彻底点


1、准备字体

从网上下载一个字体文件,这个解决方案里,必须保证静态字体和动态字体无差别,也就是最终渲染的时候,看不出来任何痕迹。
这里写图片描述

这里我从系统字体里拷了一个华文细黑做为素材

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值