Added extra frame renders to let labels grow to their final size

This commit is contained in:
Enrico Turri 2020-01-28 15:57:02 +01:00
parent d5b258c267
commit 9032dadff3
2 changed files with 25 additions and 13 deletions

View file

@ -1250,13 +1250,13 @@ bool GLCanvas3D::Labels::is_shown() const
return wxGetApp().app_config->get("show_labels") == "1";
}
void GLCanvas3D::Labels::render(const GLCanvas3D& canvas) const
void GLCanvas3D::Labels::render() const
{
if (!m_enabled || !is_shown())
return;
const Camera& camera = canvas.get_camera();
const Model* model = canvas.get_model();
const Camera& camera = m_canvas.get_camera();
const Model* model = m_canvas.get_model();
if (model == nullptr)
return;
@ -1271,12 +1271,13 @@ void GLCanvas3D::Labels::render(const GLCanvas3D& canvas) const
BoundingBoxf3 world_box;
double eye_center_z;
std::string id_str;
std::string instance_str;
bool selected;
};
// collect world bounding boxes from volumes
std::vector<Owner> owners;
const GLVolumeCollection& volumes = canvas.get_volumes();
const GLVolumeCollection& volumes = m_canvas.get_volumes();
for (const GLVolume* volume : volumes.volumes)
{
int obj_idx = volume->object_idx();
@ -1299,6 +1300,7 @@ void GLCanvas3D::Labels::render(const GLCanvas3D& canvas) const
owner.world_box = volume->transformed_bounding_box();
owner.selected = volume->selected;
owner.id_str = "object" + std::to_string(obj_idx) + "_inst##" + std::to_string(inst_idx);
owner.instance_str = _(L("Instance ")) + std::to_string(inst_idx + 1);
owners.push_back(owner);
}
}
@ -1350,13 +1352,20 @@ void GLCanvas3D::Labels::render(const GLCanvas3D& canvas) const
ImGui::BringWindowToDisplayFront(ImGui::GetCurrentWindow());
float win_w = ImGui::GetWindowWidth();
std::string object_str = model->objects[owner.obj_idx]->name;
ImGui::SetCursorPosX(0.5f * (win_w - imgui.calc_text_size(object_str).x));
float object_str_len = imgui.calc_text_size(object_str).x;
ImGui::SetCursorPosX(0.5f * (win_w - object_str_len));
ImGui::AlignTextToFramePadding();
imgui.text(object_str);
std::string instance_str = _(L("Instance ")) + std::to_string(owner.inst_idx + 1);
ImGui::SetCursorPosX(0.5f * (win_w - imgui.calc_text_size(instance_str).x));
float instance_str_len = imgui.calc_text_size(owner.instance_str).x;
ImGui::SetCursorPosX(0.5f * (win_w - instance_str_len));
ImGui::AlignTextToFramePadding();
imgui.text(instance_str);
imgui.text(owner.instance_str);
// force re-render while the windows gets to its final size (it takes several frames)
float content_w = 1 + ImGui::GetWindowContentRegionWidth();
if ((content_w <= object_str_len) || (content_w <= instance_str_len))
m_canvas.request_extra_frame();
imgui.end();
ImGui::PopStyleColor();
ImGui::PopStyleVar(2);
@ -1431,6 +1440,7 @@ GLCanvas3D::GLCanvas3D(wxGLCanvas* canvas, Bed3D& bed, Camera& camera, GLToolbar
, m_show_picking_texture(false)
#endif // ENABLE_RENDER_PICKING_PASS
, m_render_sla_auxiliaries(true)
, m_labels(*this)
{
if (m_canvas != nullptr) {
m_timer.SetOwner(m_canvas);
@ -4870,13 +4880,13 @@ void GLCanvas3D::_render_overlays() const
_render_undoredo_toolbar();
_render_view_toolbar();
#if ENABLE_SHOW_SCENE_LABELS
m_labels.render(*this);
#endif // ENABLE_SHOW_SCENE_LABELS
if ((m_layers_editing.last_object_id >= 0) && (m_layers_editing.object_max_z() > 0.0f))
m_layers_editing.render_overlay(*this);
#if ENABLE_SHOW_SCENE_LABELS
m_labels.render();
#endif // ENABLE_SHOW_SCENE_LABELS
glsafe(::glPopMatrix());
}

View file

@ -377,12 +377,14 @@ private:
class Labels
{
bool m_enabled{ false };
GLCanvas3D& m_canvas;
public:
explicit Labels(GLCanvas3D& canvas) : m_canvas(canvas) {}
void enable(bool enable) { m_enabled = enable; }
void show(bool show);
bool is_shown() const;
void render(const GLCanvas3D& canvas) const;
void render() const;
};
#endif // ENABLE_SHOW_SCENE_LABELS