mirror of
https://github.com/ocornut/imgui.git
synced 2025-01-18 17:24:09 +01:00
ImDrawList::AddText() allows changing font
This commit is contained in:
parent
cc79b85c28
commit
40f7b67ef1
11
imgui.cpp
11
imgui.cpp
@ -6144,7 +6144,11 @@ void ImDrawList::AddText(ImFont* font, float font_size, const ImVec2& pos, ImU32
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (text_end == NULL)
|
if (text_end == NULL)
|
||||||
text_end = text_begin + strlen(text_begin); // FIXME-OPT
|
text_end = text_begin + strlen(text_begin);
|
||||||
|
|
||||||
|
const bool push_texture_id = font->TexID != texture_id_stack.back();
|
||||||
|
if (push_texture_id)
|
||||||
|
PushTextureID(font->TexID);
|
||||||
|
|
||||||
// reserve vertices for worse case
|
// reserve vertices for worse case
|
||||||
const unsigned int char_count = (unsigned int)(text_end - text_begin);
|
const unsigned int char_count = (unsigned int)(text_end - text_begin);
|
||||||
@ -6159,6 +6163,9 @@ void ImDrawList::AddText(ImFont* font, float font_size, const ImVec2& pos, ImU32
|
|||||||
const size_t vtx_count = vtx_buffer.size() - vtx_begin;
|
const size_t vtx_count = vtx_buffer.size() - vtx_begin;
|
||||||
commands.back().vtx_count -= (unsigned int)(vtx_count_max - vtx_count);
|
commands.back().vtx_count -= (unsigned int)(vtx_count_max - vtx_count);
|
||||||
vtx_write -= (vtx_count_max - vtx_count);
|
vtx_write -= (vtx_count_max - vtx_count);
|
||||||
|
|
||||||
|
if (push_texture_id)
|
||||||
|
PopTextureID();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImDrawList::AddImage(ImTextureID user_texture_id, const ImVec2& a, const ImVec2& b, const ImVec2& uv0, const ImVec2& uv1, ImU32 col)
|
void ImDrawList::AddImage(ImTextureID user_texture_id, const ImVec2& a, const ImVec2& b, const ImVec2& uv0, const ImVec2& uv1, ImU32 col)
|
||||||
@ -6461,7 +6468,7 @@ bool ImFont::LoadFromMemoryTTF(const void* data, size_t data_size, float size
|
|||||||
|
|
||||||
// Draw white pixel and make UV points to it
|
// Draw white pixel and make UV points to it
|
||||||
TexPixels[0] = TexPixels[1] = TexPixels[TexWidth+0] = TexPixels[TexWidth+1] = 0xFF;
|
TexPixels[0] = TexPixels[1] = TexPixels[TexWidth+0] = TexPixels[TexWidth+1] = 0xFF;
|
||||||
TexUvWhitePixel = ImVec2(TexExtraDataPos.x + 0.5f / TexWidth, TexExtraDataPos.y + 0.5f / TexHeight);
|
TexUvWhitePixel = ImVec2((TexExtraDataPos.x + 0.5f) / TexWidth, (TexExtraDataPos.y + 0.5f) / TexHeight);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user