Imgui自定义中文字符集(示例代码)

https://www.136.la/au/show-106658.html

https://www.136.la/shida/show-361113.html

简介 这篇文章主要介绍了Imgui自定义中文字符集(示例代码)以及相关的经验技巧,文章约5739字,浏览量551,点赞数8,值得推荐!

虽然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 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快上一些,根据自己的需求增减字符文本就行。

以上就是本文的全部内容,希望对大家的学习有所帮助,本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 原文地址:https://www.cnblogs.com/kileyi/p/12347037.htmlll

你可能感兴趣的:(Imgui自定义中文字符集(示例代码))