Cocos Creator2.4版本文字模糊终极解决方案

前言:相信你也会发现,Cocos Creator的文字组件在高清分辨率屏幕下,会表现得非常模糊,相比原生界面的文字,差别很大。开始的时候,我没有注意到这个问题,因为我没有想到,文字组件作为最基本的组件,这么大一个引擎,竟然会有这个问题。后来随着项目的“壮大”,才发现这个问题。然后搜了很多解决方法,最多的一个方法就是字体大小* 2,行高* 2,节点大小* 2,Scale/2的方法。但是对于已经存在的项目,且使用文本较多的时候,逐个去修改文字的属性,简直就是一场噩梦!哪怕写成一个组件,逐个去挂载也是极为繁琐的事情,并且节点大小的改变,有些布局排版也会受到影响。后来搜索到了Cocos Enhance Kit

引用Cocos Enhance Kit https://forum.cocos.org/t/topic/137649

这里面的文字高清功能可以完美解决文字模糊的问题,但是由于该kit的功能较多,并且要编译原生引擎,由于里面大多功能我没有用到,并且可能由于我的环境问题,总是没有编译成功。所以决定单独抽取其文字高清的功能,经过几个晚上的研究,粗略地了解了一下原理:就是从引擎渲染文字的层面对文字进行放大缩放,这样不需要在编辑器改变节点的宽高Scale等属性。

因为涉及到修改引擎,所以你可能还需要了解这些知识:
https://docs.cocos.com/creator/2.4/manual/zh/advanced-topics/engine-customization.html

只需要修改引擎两个关于文字渲染的文件即可。
第一步:

1714041866507

然后进入到引擎的目录

1714042207979

你也可以直接拷贝engine目录到其他地方,然后修改,再在项目设置里面设置自定义js引擎的路径,这里仅仅是修改了js引擎,不用修改cocos2dx原生引擎,即可工作。
1714042570167

下载好需要改变的这两个文件,因为我的机器上面只装有2.45版本和2.49版本,所以只改了这两个版本的文件,如果你使用其他的版本,可以照着修改。

ttf修改文件.zip (14.3 KB)

里面分别包含了2.45和2.49两个版本对应的两个文件,请根据你的Cocos Creator选择对应的版本,如果你的版本不是这两个版本,可以参考源码对应修改,可以用vsCode打开,Ctrl+F搜索关键字“修改”,里面需要改动的几个地方会有注释。对照着改即可。

下载好文件之后,把ttf1.js文件和ttf2.js分别放到引擎目录的Creator\2.4.5\resources\engine\cocos2d\core\renderer\utils\label
和:
Creator\2.4.5\resources\engine\cocos2d\core\renderer\webgl\assemblers\label\2d
1714043264680
1714043603545

替换之后记得改回ttf.js名字啊,别傻乎乎地就留着ttf1.js的名字。
1714044517976

如图所述,使用了一个全局变量来控制文字高清开启和关闭,也可以在cc.Label中增加一个属性来为单独的文字组件提供开启和关闭。具体参考Cocos Enhance Kit的代码,因为文字高清基本是全局开的,所以我就没搞这个功能了,全局开即可。

然后在项目初始化入口之前设置一下全局变量即可。
cc.enableLabelRetina = true;
cc.labelRetinaScale = 2;

至此就完成了修改引擎的工作,当你修改完之后,你重新运行,你会发现没有什么变化,这是因为,js引擎没有编译。所以改完之后你需要编译一下,你可以理解为把那么多的js文件编译成一个js文件或者进行min压缩等操作,以便于发行或在浏览器中运行。

编译你可以参考上面关于自定义引擎相关的连接

编译步骤:
1.首先你得安装了nodejs和npm,一般你下载nodejs安装配套都有npm的。默认安装应该都会自动添加到环境变量的,你随便在一个文件打开cmd命令,输入node -v 和npm -v 如果都输出有对应的版本号,证明nodejs环境安装好了,如果没有,则检查一下node的环境变量

2.去到引擎文件执行编译工具安装和编译等命令
1714045632454

如图,分别上面三步命令,
1: npm install -g gulp
2:npm install
3:gulp build-dev

第三步完成之后你会在你的engine目录下存在一个bin文件,可能之前就有,但是编译之前也不用删,它会覆盖的。进入文件你可以看到编译出来的相关js文件了。

1714045878751

然后重启你的Cocos Creator,需要重启才生效,并且你项目设置了
cc.enableLabelRetina = true;
cc.labelRetinaScale = 2;

那么就可以看到效果了。准备亮瞎你的钛合金眼吧!体验一下一劳永逸的感觉,这一刻你会发现世界多么美好。
感谢Cocos Enhance Kit!

另外,bmFont也是可以改为高清的,因为我项目没有用到,所以没去研究,可以参考上面Cocos Enhance Kit!,下载相关引擎代码,去参考engine\cocos2d\core\renderer\utils\label\bmfont.js这个文件即可。

其他版本的也可以照着原理改,3.几版本的因为没有安装和研究过,不知道内置引擎是否已经自动添加高清的支持。

这里看着好像步骤很多,其实就是换两个文件,重新编译。写得详细点,毕竟每个开发者都喜欢保姆级的教程。

14赞

确实够详细!

1赞

求问 这么好,为啥 官方不整合进官方版本里?

It’s so good. Thanks for sharing!

本质还是缩放吧。

不持支char模式的高清么

应该是的,只不过在引擎渲染层面处理了

2.几的都是老版本了,新版本不知道有没有实现,没了解过

是说 按本文所描述的 大概也就是替换文件然后编译一下引擎的问题 让官方来整合一下 那不是分分钟钟的事情吗 为啥不给官方提个建议 ,2.4.14上一个啊

因为他们只能在新的版本中去修改。试想一下,如果官方在2.4.14修改了这个功能,那么它就不能叫2.4.14版本了,只能用新的版本名字,比如2.4.14增强版,修正版之类的,才能和之前的区分。如果改了也还叫2.4.14,那么用户前后下载下来的版本功能就不一样了,用户就会疑惑为什么我下载的2.4.14没有文字高清,你的有。官方要保证同一版本功能代码一致性,这涉及到代码管理和版本控制的问题。所以只能在新的版本中加,或者以插件的形式加,或者你们自己弄,这也是为什么论坛中会有大神出所谓的魔改版的原因。如果单独给你2.4.14修改个功能,取名为2.4.14增强版,现在他们好像已经搞到了3.几版本了,不会再回2.几版本又去发行一个版本了,发展到3.几都不知道改动了多少代码了呢,又回之前去搞一个版本,代码管理就混乱了,还不如让你们自己搞。这也就很好解释:平时某版本出了bug,他们都会说:等下一个版本。

哥们 现在最高版本也就是2.4.13啊,所以我说2.4.14上一个啊 是下一个版本啊, 你想成啥啦? 既然这么好 官方来做这个 岂不是又简单又稳定 还能让所有人受益,那么官方为啥不做呢? 官方不做 肯定也有理由吧 我也想知道官方为啥不做呢?

据了解,最新版本的3.8已经支持文字高清了。本身这个解决方案就是针对老版本那些历史遗留问题的,只能自己弄。

我都没看到任何更新说明提到这个?

我上次特意查了一下的,是看到支持了的,忘记在哪里看到的了。你搜索框上输入文字高清,应该可以看到论坛很多人都说支持了的,因为我本身没需求,所以就没安装有3.几的版本。

看了下引擎 确实做了这方面的处理,文本处理确实大改了一波