标签:范围 自定义 open 超过 缓存 read chinese 就是 file
虽然Imgui不支持富文本,也不能同一时刻显示2种或更多的字号,只能简单作为调式GUI用用,但是这并不妨碍它流行,有些东西还是需要简单方便才能赢得大众喜爱。
说回正题。
Imgui的例子默认是英文字体,要显示中文需要先添加中文字体,如
io.Fonts->AddFontFromFileTTF("Asset/Font/SourceHanSansCN-Normal.otf", 14.0f, nullptr, io.Fonts->GetGlyphRangesChineseSimplifiedCommon());
再调用C++11类似如下的代码
ImGui::Text(u8"显示中文试试骚");
然后你就会遇到骚字显示不出来的情况
F12进入这个函数发现这个函数只提供2500个中文字符集,想显示完整你需要调用如下
io.Fonts->AddFontFromFileTTF("Asset/Font/SourceHanSansCN-Normal.otf", 14.0f, nullptr, io.Fonts->GetGlyphRangesChineseFull());
就是把
GetGlyphRangesChineseSimplifiedCommon
换成了
GetGlyphRangesChineseFull
字符不全的问题是解决了,但是带来了新问题,运行一下你会发现慢了不少,因为这个不少已经超过我的忍受范围,所以稍微简单研究了下自定义字符集。
========================================
首先你需要一份常用中文字符表文件,这东西无论百度还是gayhub都能找到,以我所知有3500,7000,9000等汉字表,越多的编译时间越长,根据自己需要选择。
因为Imgui这个字符纹理是静态一次性缓存上的,这点真的很烂,随便看看SFML2都有动态字符集缓存的代码实现。
然后加入下面的测试代码,别吐槽风格,测试用写的,根本没过大脑
ImGuiIO& io = ImGui::GetIO(); (void)io; FILE* inFile = fopen("Asset/Font/chinese3500.txt", "rb"); //FILE* inFile = fopen("Asset/Font/chinese7000.txt", "rb"); //FILE* inFile = fopen("Asset/Font/chinese9000.txt", "rb"); unsigned char *charBuf; fseek(inFile, 0, SEEK_END); int fileLen = ftell(inFile); charBuf = new unsigned char[fileLen]; fseek(inFile, 0, SEEK_SET); fread(charBuf, fileLen, 1, inFile); fclose(inFile); static ImVector<ImWchar> myRange; ImFontGlyphRangesBuilder myGlyph; //ImWchar base_ranges[] = // not zero-terminated //{ // 0x0020, 0x00FF, // Basic Latin + Latin Supplement // 0x2000, 0x206F, // General Punctuation // 0x3000, 0x30FF, // CJK Symbols and Punctuations, Hiragana, Katakana // 0x31F0, 0x31FF, // Katakana Phonetic Extensions // 0xFF00, 0xFFEF // Half-width characters //}; //myGlyph.AddRanges(base_ranges); //myGlyph.AddText(u8"显示中文测试骚"); myGlyph.AddText((const char*)charBuf); myGlyph.BuildRanges(&myRange); delete[] charBuf; ImFont* font1 = io.Fonts->AddFontFromFileTTF("Asset/Font/SourceHanSansCN-Normal.otf", 14.0f, nullptr, myRange.Data); ImFont* font2 = io.Fonts->AddFontFromFileTTF("Asset/Font/Alibaba-PuHuiTi-Bold.ttf", 18.0f, nullptr, myRange.Data);
这样再测试,发现能比GetGlyphRangesChineseFull快上一些,根据自己的需求增减字符文本就行。
标签:范围 自定义 open 超过 缓存 read chinese 就是 file
原文地址:https://www.cnblogs.com/kileyi/p/12347037.html