Only save original string in GlyphLayout if needed

This commit is contained in:
Benau 2021-09-06 14:51:45 +08:00
parent 5d5292787e
commit 8c3bacf769
4 changed files with 10 additions and 2 deletions

View File

@ -24,6 +24,7 @@ enum ShapeFlag
{ {
SF_DISABLE_CACHE = 1, /* Disable caching glyph layouts. */ SF_DISABLE_CACHE = 1, /* Disable caching glyph layouts. */
SF_DISABLE_URL_HIGHLIGHT = 2, /* Disable URL highlight. */ SF_DISABLE_URL_HIGHLIGHT = 2, /* Disable URL highlight. */
SF_ENABLE_CLUSTER_TEST = 4, /* If on getCluster will work on these layouts, which the original string will be stored, it will be turned on too if any URL is found. */
}; };
enum GlyphLayoutFlag enum GlyphLayoutFlag

View File

@ -469,6 +469,8 @@ s32 CGUIStaticText::getCluster(int x, int y, std::shared_ptr<std::u32string>* ou
return -1; return -1;
std::shared_ptr<std::u32string> s = m_glyph_layouts[idx].orig_string; std::shared_ptr<std::u32string> s = m_glyph_layouts[idx].orig_string;
if (!s)
return -1;
unsigned cluster = m_glyph_layouts[idx].cluster.front(); unsigned cluster = m_glyph_layouts[idx].cluster.front();
if (cluster > s->size()) if (cluster > s->size())
return -1; return -1;

View File

@ -332,6 +332,8 @@ void FontManager::shape(const std::u32string& text,
} }
return 0; return 0;
}; };
bool save_orig_string = (shape_flag & gui::SF_ENABLE_CLUSTER_TEST) != 0;
if ((shape_flag & gui::SF_DISABLE_URL_HIGHLIGHT) == 0) if ((shape_flag & gui::SF_DISABLE_URL_HIGHLIGHT) == 0)
{ {
size_t pos = text.find(U"http://", 0); size_t pos = text.find(U"http://", 0);
@ -376,6 +378,8 @@ void FontManager::shape(const std::u32string& text,
pos = text.find(U"https://", pos + 1); pos = text.find(U"https://", pos + 1);
} }
} }
if (!http_pos.empty())
save_orig_string = true;
int start = 0; int start = 0;
std::shared_ptr<std::u32string> orig_string = std::shared_ptr<std::u32string> orig_string =
@ -595,6 +599,7 @@ void FontManager::shape(const std::u32string& text,
gl.flags |= gui::GLF_RTL_CHAR; gl.flags |= gui::GLF_RTL_CHAR;
if (FT_HAS_COLOR(glyphs[idx].ftface)) if (FT_HAS_COLOR(glyphs[idx].ftface))
gl.flags |= gui::GLF_COLORED; gl.flags |= gui::GLF_COLORED;
if (save_orig_string)
gl.orig_string = orig_string; gl.orig_string = orig_string;
cur_line.push_back(gl); cur_line.push_back(gl);
} }

View File

@ -347,7 +347,7 @@ void NetworkingLobby::addMoreServerInfo(core::stringw info)
const float box_height = m_text_bubble->getDimension().Height; const float box_height = m_text_bubble->getDimension().Height;
std::vector<GlyphLayout> cur_info; std::vector<GlyphLayout> cur_info;
font_manager->initGlyphLayouts(info, cur_info, gui::SF_DISABLE_CACHE | font_manager->initGlyphLayouts(info, cur_info, gui::SF_DISABLE_CACHE |
gui::SF_DISABLE_URL_HIGHLIGHT); gui::SF_DISABLE_URL_HIGHLIGHT | gui::SF_ENABLE_CLUSTER_TEST);
gui::IGUIFont* font = GUIEngine::getFont(); gui::IGUIFont* font = GUIEngine::getFont();
gui::breakGlyphLayouts(cur_info, box_width, gui::breakGlyphLayouts(cur_info, box_width,
font->getInverseShaping(), font->getScale()); font->getInverseShaping(), font->getScale());