PixiJS テキスト難読化戦略

pixijの紹介

PixiJS は、インタラクティブな 2D グラフィックとアニメーションを作成するための JavaScript ライブラリです。これは、WebGL と Canvas で動作する高速で軽量な使いやすいライブラリです。WebGL と Canvas の 2 つのレンダリング方法をサポートします。WebGL は OpenGL ベースの 3D グラフィックス API で、GPU での効率的なグラフィックス レンダリングを可能にします。Canvas は、ブラウザーで 2D グラフィックを描画できる HTML5 要素です。次の特徴があります。

  • 高性能: PixiJS は、ハードウェア アクセラレーションに WebGL を使用します。これにより、最新のブラウザーで高性能のグラフィックス レンダリングを実現できます。
  • 使いやすさ: PixiJS は、インタラクティブな 2D グラフィックスとアニメーションをすばやく作成するための使いやすい API を提供します。
  • クロスプラットフォーム: PixiJS は、デスクトップ ブラウザー、モバイル デバイス、テレビなど、複数のプラットフォームで実行できます。
  • 拡張性: PixiJS は、その機能とパフォーマンスを拡張できる豊富なプラグインと拡張機能を提供します。

pixijsの文字がぼやける

PIXI.TextThe class uses the canvas rendering method, which is a grid to draw text. ビューポートをズームインおよびズームアウトするときは、次のように解像度を設定する必要があります。

let text = new PIXI.Text('我是中国人', {
    
    fontSize:10,autoDensity: true,fill:0xff0000});
text.x = i;
text.y = j;
text.resolution=5;//就这个精度也就只能放大5倍而已,再放大就容易模糊.
app.stage.addChild(text);

この方法は、文字がぼやける問題をある程度解決することができますが、欠点も非常に明白で、解像度が高いほどメモリ消費量が多くなります。そして、それでもズーム ブラーの問題を完全に解決することはできません。

の解き方

1. ビットマップ テキスト

ビットマップ テキストのソリューションは pixijs で提供されています。ビットマップ フォントを使用すると、ピクセル パーフェクトであるため、ぼやけたテキストを回避できます。ビットマップ テキスト (BitmapText) の概要については、公式ドキュメントを参照してください。ビットマップテキストで使用されるMSDFアルゴリズムは、歪みのない文字拡大を実現できます。効果は非常に高く、メモリ消費量は canvas 方式より約 70% 低くなります。具体的な解決策は次のとおりです

TTF から MSDF を生成するツールhttps://github.com/Chlumsky/msdfgen https://github.com/donmccurdy/msdf-bmfont-web

オープン ソース ライブラリbmfont-xmlを使用して、フォント ファイルを距離フィールドをサポートする fnt ファイルおよび png ファイルに変換します。
  1. コマンド ライン スクリプトを直接インストールします (ソース コードのインストールには、国内のソースを変更する必要があります)。
cnpm install msdf-bmfont-xml -g
  1. コマンドライン スクリプトを実行する
 msdf-bmfont -o atlas.png -i d:/1.txt  -t msdf d:/正等线体.ttf

-i 新しいフォントを生成するための文字ファイルを指定します. これは変換する必要がある中国語と英語の文字を入れるだけのテキストファイルです. 指定する必要があります. 一般的に使用される 2500 文字を追加できます.
-t スケーリングの問題を解決するために、距離フィールドを含む msdf を生成します
-o ビットマップ ファイルを出力します

  1. 生成結果グラフファイル

画像.png
画像.png

  1. Pixi でのビットマップ ファイルの操作
const resourceList = [
  "assets/正等线体.fnt"
];
//必须等待加载完成,一般情况下可以用await来初始化等待;
PIXI.Assets.load(resourceList);
function draw()
{
    
    
       const bitmapFontText = new PIXI.BitmapText(
                '我名字吕时有,ABCD', {
    
    
                    fontName: '正等线体',  //字体名字就是我加载的fnt中的字体名,注意的是可能有文件名不相同
                    fontSize: 10,
                    align: 'left',
                },);
        app.stage.addChild(bitmapFontText);
}

一般的に使用される2500の漢字のリスト

QWERTYUIOPASDFGHJKLZXCVBNM::aqwertyuiopadsfghjkl;zxcvbnm,.[]\=-1234567890,。`+-!@##$%&^*(){}|!@#¥??/<>《》“”"一乙二十丁厂七卜人入八九几儿了力乃刀又三于干亏士工土才寸下大丈与万上小口巾山千乞川亿个勺久凡及夕丸么广亡门义之尸弓己已子卫也女飞刃习叉马乡丰王井开夫天无元专云扎艺木五支厅不太犬区历尤友匹车巨牙屯比互切瓦止少日中冈贝内水见午牛手毛气升长仁什片仆化仇币仍仅斤爪反介父从今凶分乏公仓月氏勿欠风丹匀乌凤勾文六方火为斗忆订计户认心尺引丑巴孔队办以允予劝双书幻玉刊示末未击打巧正扑扒功扔去甘世古节本术可丙左厉右石布龙平灭轧东卡北占业旧帅归且旦目叶甲申叮电号田由史只央兄叼叫另叨叹四生失禾丘付仗代仙们仪白仔他斥瓜乎丛令用甩印乐句匆册犯外处冬鸟务包饥主市立闪兰半汁汇头汉宁穴它讨写让礼训必议讯记永司尼民出辽奶奴加召皮边发孕圣对台矛纠母幼丝式刑动扛寺吉扣考托老执巩圾扩扫地扬场耳共芒亚芝朽朴机权过臣再协西压厌在有百存而页匠夸夺灰达列死成夹轨邪划迈毕至此贞师尘尖劣光当早吐吓虫曲团同吊吃因吸吗屿帆岁回岂刚则肉网年朱先丢舌竹迁乔伟传乒乓休伍伏优伐延件任伤价份华仰仿伙伪自血向似后行舟全会杀合兆企众爷伞创肌朵杂危旬旨负各名多争色壮冲冰庄庆亦刘齐交次衣产决充妄闭问闯羊并关米灯州汗污江池汤忙兴宇守宅字安讲军许论农讽设访寻那迅尽导异孙阵阳收阶阴防奸如妇好她妈戏羽观欢买红纤级约纪驰巡寿弄麦形进戒吞远违运扶抚坛技坏扰拒找批扯址走抄坝贡攻赤折抓扮抢孝均抛投坟抗坑坊抖护壳志扭块声把报却劫芽花芹芬苍芳严芦劳克苏杆杠杜材村杏极李杨求更束豆两丽医辰励否还歼来连步坚旱盯呈时吴助县里呆园旷围呀吨足邮男困吵串员听吩吹呜吧吼别岗帐财针钉告我乱利秃秀私每兵估体何但伸作伯伶佣低你住位伴身皂佛近彻役返余希坐谷妥含邻岔肝肚肠龟免狂犹角删条卵岛迎饭饮系言冻状亩况床库疗应冷这序辛弃冶忘闲间闷判灶灿弟汪沙汽沃泛沟没沈沉怀忧快完宋宏牢究穷灾良证启评补初社识诉诊词译君灵即层尿尾迟局改张忌际陆阿陈阻附妙妖妨努忍劲鸡驱纯纱纳纲驳纵纷纸纹纺驴纽奉玩环武青责现表规抹拢拔拣担坦押抽拐拖拍者顶拆拥抵拘势抱垃拉拦拌幸招坡披拨择抬其取苦若茂苹苗英范直茄茎茅林枝杯柜析板松枪构杰述枕丧或画卧事刺枣雨卖矿码厕奔奇奋态欧垄妻轰顷转斩轮软到非叔肯齿些虎虏肾贤尚旺具果味昆国昌畅明易昂典固忠咐呼鸣咏呢岸岩帖罗帜岭凯败贩购图钓制知垂牧物乖刮秆和季委佳侍供使例版侄侦侧凭侨佩货依的迫质欣征往爬彼径所舍金命斧爸采受乳贪念贫肤肺肢肿胀朋股肥服胁周昏鱼兔狐忽狗备饰饱饲变京享店夜庙府底剂郊废净盲放刻育闸闹郑券卷单炒炊炕炎炉沫浅法泄河沾泪油泊沿泡注泻泳泥沸波泼泽治怖性怕怜怪学宝宗定宜审宙官空帘实试郎诗肩房诚衬衫视话诞询该详建肃录隶居届刷屈弦承孟孤陕降限妹姑姐姓始驾参艰线练组细驶织终驻驼绍经贯奏春帮珍玻毒型挂封持项垮挎城挠政赴赵挡挺括拴拾挑指垫挣挤拼挖按挥挪某甚革荐巷带草茧茶荒茫荡荣故胡南药标枯柄栋相查柏柳柱柿栏树要咸威歪研砖厘厚砌砍面耐耍牵残殃轻鸦皆背战点临览竖省削尝是盼眨哄显哑冒映星昨畏趴胃贵界虹虾蚁思蚂虽品咽骂哗咱响哈咬咳哪炭峡罚贱贴骨钞钟钢钥钩卸缸拜看矩怎牲选适秒香种秋科重复竿段便俩贷顺修保促侮俭俗俘信皇泉鬼侵追俊盾待律很须叙剑逃食盆胆胜胞胖脉勉狭狮独狡狱狠贸怨急饶蚀饺饼弯将奖哀亭亮度迹庭疮疯疫疤姿亲音帝施闻阀阁差养美姜叛送类迷前首逆总炼炸炮烂剃洁洪洒浇浊洞测洗活派洽染济洋洲浑浓津恒恢恰恼恨举觉宣室宫宪突穿窃客冠语扁袄祖神祝误诱说诵垦退既屋昼费陡眉孩除险院娃姥姨姻娇怒架贺盈勇怠柔垒绑绒结绕骄绘给络骆绝绞统耕耗艳泰珠班素蚕顽盏匪捞栽捕振载赶起盐捎捏埋捉捆捐损都哲逝捡换挽热恐壶挨耻耽恭莲莫荷获晋恶真框桂档桐株桥桃格校核样根索哥速逗栗配翅辱唇夏础破原套逐烈殊顾轿较顿毙致柴桌虑监紧党晒眠晓鸭晃晌晕蚊哨哭恩唤啊唉罢峰圆贼贿钱钳钻铁铃铅缺氧特牺造乘敌秤租积秧秩称秘透笔笑笋债借值倚倾倒倘俱倡候俯倍倦健臭射躬息徒徐舰舱般航途拿爹爱颂翁脆脂胸胳脏胶脑狸狼逢留皱饿恋桨浆衰高席准座脊症病疾疼疲效离唐资凉站剖竞部旁旅畜阅羞瓶拳粉料益兼烤烘烦烧烛烟递涛浙涝酒涉消浩海涂浴浮流润浪浸涨烫涌悟悄悔悦害宽家宵宴宾窄容宰案请朗诸读扇袜袖袍被祥课谁调冤谅谈谊剥恳展剧屑弱陵陶陷陪娱娘通能难预桑绢绣验继球理捧堵描域掩捷排掉堆推掀授教掏掠培接控探据掘职基著勒黄萌萝菌菜萄菊萍菠营械梦梢梅检梳梯桶救副票戚爽聋袭盛雪辅辆虚雀堂常匙晨睁眯眼悬野啦晚啄距跃略蛇累唱患唯崖崭崇圈铜铲银甜梨犁移笨笼笛符第敏做袋悠偿偶偷您售停偏假得衔盘船斜盒鸽悉欲彩领脚脖脸脱象够猜猪猎猫猛馅馆凑减毫麻痒痕廊康庸鹿盗章竟商族旋望率着盖粘粗粒断剪兽清添淋淹渠渐混渔淘液淡深婆梁渗情惜惭悼惧惕惊惨惯寇寄宿窑密谋谎祸谜逮敢屠弹随蛋隆隐婚婶颈绩绪续骑绳维绵绸绿琴斑替款堪搭塔越趁趋超提堤博揭喜插揪搜煮援裁搁搂搅握揉斯期欺联散惹葬葛董葡敬葱落朝辜葵棒棋植森椅椒棵棍棉棚棕惠惑逼厨厦硬确雁殖裂雄暂雅辈悲紫辉敞赏掌晴暑最量喷晶喇遇喊景践跌跑遗蛙蛛蜓喝喂喘喉幅帽赌赔黑铸铺链销锁锄锅锈锋锐短智毯鹅剩稍程稀税筐等筑策筛筒答筋筝傲傅牌堡集焦傍储奥街惩御循艇舒番释禽腊脾腔鲁猾猴然馋装蛮就痛童阔善羡普粪尊道曾焰港湖渣湿温渴滑湾渡游滋溉愤慌惰愧愉慨割寒富窜窝窗遍裕裤裙谢谣谦属屡强粥疏隔隙絮嫂登缎缓编骗缘瑞魂肆摄摸填搏塌鼓摆携搬摇搞塘摊蒜勤鹊蓝墓幕蓬蓄蒙蒸献禁楚想槐榆楼概赖酬感碍碑碎碰碗碌雷零雾雹输督龄鉴睛睡睬鄙愚暖盟歇暗照跨跳跪路跟遣蛾蜂嗓置罪罩错锡锣锤锦键锯矮辞稠愁筹签简毁舅鼠催傻像躲微愈遥腰腥腹腾腿触解酱痰廉新韵意粮数煎塑慈煤煌满漠源滤滥滔溪溜滚滨粱滩慎誉塞谨福群殿辟障嫌嫁叠缝缠静碧璃墙撇嘉摧截誓境摘摔聚蔽慕暮蔑模榴榜榨歌遭酷酿酸磁愿需弊裳颗嗽蜻蜡蝇蜘赚锹锻舞稳算箩管僚鼻魄貌膜膊膀鲜疑馒裹敲豪膏遮腐瘦辣竭端旗精歉熄熔漆漂漫滴演漏慢寨赛察蜜谱嫩翠熊凳骡缩慧撕撒趣趟撑播撞撤增聪鞋蕉蔬横槽樱橡飘醋醉震霉瞒题暴瞎影踢踏踩踪蝶蝴嘱墨镇靠稻黎稿稼箱箭篇僵躺僻德艘膝膛熟摩颜毅糊遵潜潮懂额慰劈操燕薯薪薄颠橘整融醒餐嘴蹄器赠默镜赞篮邀衡膨雕磨凝辨辩糖糕燃澡激懒壁避缴戴擦鞠藏霜霞瞧蹈螺穗繁辫赢糟糠燥臂翼骤鞭覆蹦镰翻鹰警攀蹲颤瓣爆疆壤耀躁嚼嚷籍魔灌蠢霸露囊罐

ビットマップ リテラルの使用には、次の利点と欠点があります。

  1. スプライトに似た超高速レンダリング
  2. 最大サイズ制限なし
  3. グリフを再利用してメモリ使用量を最小限に抑える
  4. サードパーティのオーサリング ツールが必要
  5. 書記素を多用する言語には適していません

ビットマップ テキストの場合、pixijs にはフォント作成ツールも用意されています。

https://pixijs.download/dev/docs/PIXI.BitmapFont.html
PixiJS 5.3.0 では、BitmapText での使用に適したフォントをレンダリングするための新しい API が導入されました。を使用している開発者は、通常、次のようなテキスト要素を作成できます。

PIXI.BitmapFont.from("TitleFont", {
    
    
  fill: "#333333",
  fontSize: 40,
  fontWeight: 'bold',
});
const text = new PIXI.BitmapText("Hello World", {
    
    
  fontName: "TitleFont",
});

文字セットを定義することもできますが、これは非常に簡単です。静的文字リストは、文字列、文字範囲、または組み合わせとして定義できます。例えば:


PIXI.BitmapFont.from("TitleFont", {
    
    }, {
    
    
  chars: [
    ['a', 'z'],
    ['0', '9'],
    ['A', 'Z'],
    ' .!?'
  ]
});

2. ベクター テキストを使用する

簡単に言えば、テキストをベクター レンダリングに変換することです。オープン ソース ライブラリを使用できますhttps://github.com/mikolalysenko/vectorize-text

var vectorizeText = require("vectorize-text")

var complex = vectorizeText("Hello world! 你好", {
    
    
  triangles: true,
  width: 500,
  textBaseline: "hanging"
})

var svg = ['<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"  width="500"  height="80" >']
complex.cells.forEach(function(c) {
    
    
  for(var j=0; j<3; ++j) {
    
    
    var p0 = complex.positions[c[j]]
    var p1 = complex.positions[c[(j+1)%3]]
    svg.push('<line x1="' + p0[0] + '" y1="' + p0[1] +
      '" x2="' + p1[0] + '" y2="' + p1[1] +
      '" stroke-width="1" stroke="black" />')
  }
})
svg.push("</svg>")

console.log(svg)

フォントを JS ファイルに変換するWeb サイトhttp://gero3.github.io/facetype.js/もあり、https://github.com/mrdoob/threethreejs。 js/ブロブ/r68/src/extras/FontUtils.js

3. GPU フォントレンダリング

現在、パフォーマンスは最高ですが、JS には適切なオープン ソース ライブラリはありませんが、Rust ライブラリがあり、Rust は wasm テクノロジを介して js コードに変換できます。
https://github.com/servo/pathfinder

おすすめ

転載: blog.csdn.net/qq_33377547/article/details/130096300