mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Fixed gizmos' tooltips
This commit is contained in:
parent
c1e92a5759
commit
ffe404fc5b
8 changed files with 47 additions and 28 deletions
|
@ -1951,6 +1951,25 @@ void GLCanvas3D::render()
|
||||||
auto end_time = std::chrono::high_resolution_clock::now();
|
auto end_time = std::chrono::high_resolution_clock::now();
|
||||||
m_render_stats.last_frame = std::chrono::duration_cast<std::chrono::milliseconds>(end_time - start_time).count();
|
m_render_stats.last_frame = std::chrono::duration_cast<std::chrono::milliseconds>(end_time - start_time).count();
|
||||||
#endif // ENABLE_RENDER_STATISTICS
|
#endif // ENABLE_RENDER_STATISTICS
|
||||||
|
|
||||||
|
std::string tooltip = "";
|
||||||
|
|
||||||
|
if (tooltip.empty())
|
||||||
|
tooltip = m_layers_editing.get_tooltip(*this);
|
||||||
|
|
||||||
|
if (tooltip.empty())
|
||||||
|
tooltip = m_gizmos.get_tooltip();
|
||||||
|
|
||||||
|
if (tooltip.empty())
|
||||||
|
tooltip = m_main_toolbar.get_tooltip();
|
||||||
|
|
||||||
|
if (tooltip.empty())
|
||||||
|
tooltip = m_undoredo_toolbar.get_tooltip();
|
||||||
|
|
||||||
|
if (tooltip.empty())
|
||||||
|
tooltip = m_view_toolbar.get_tooltip();
|
||||||
|
|
||||||
|
set_tooltip(tooltip);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLE_THUMBNAIL_GENERATOR
|
#if ENABLE_THUMBNAIL_GENERATOR
|
||||||
|
@ -3587,24 +3606,6 @@ void GLCanvas3D::on_mouse(wxMouseEvent& evt)
|
||||||
else if (evt.Moving())
|
else if (evt.Moving())
|
||||||
{
|
{
|
||||||
m_mouse.position = pos.cast<double>();
|
m_mouse.position = pos.cast<double>();
|
||||||
std::string tooltip = "";
|
|
||||||
|
|
||||||
if (tooltip.empty())
|
|
||||||
tooltip = m_layers_editing.get_tooltip(*this);
|
|
||||||
|
|
||||||
if (tooltip.empty())
|
|
||||||
tooltip = m_gizmos.get_tooltip();
|
|
||||||
|
|
||||||
if (tooltip.empty())
|
|
||||||
tooltip = m_main_toolbar.get_tooltip();
|
|
||||||
|
|
||||||
if (tooltip.empty())
|
|
||||||
tooltip = m_undoredo_toolbar.get_tooltip();
|
|
||||||
|
|
||||||
if (tooltip.empty())
|
|
||||||
tooltip = m_view_toolbar.get_tooltip();
|
|
||||||
|
|
||||||
set_tooltip(tooltip);
|
|
||||||
|
|
||||||
// updates gizmos overlay
|
// updates gizmos overlay
|
||||||
if (m_selection.is_empty())
|
if (m_selection.is_empty())
|
||||||
|
@ -3692,7 +3693,6 @@ void GLCanvas3D::set_tooltip(const std::string& tooltip) const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GLCanvas3D::do_move(const std::string& snapshot_type)
|
void GLCanvas3D::do_move(const std::string& snapshot_type)
|
||||||
{
|
{
|
||||||
if (m_model == nullptr)
|
if (m_model == nullptr)
|
||||||
|
|
|
@ -265,7 +265,7 @@ void GLGizmoBase::render_grabbers_for_picking(const BoundingBoxf3& box) const
|
||||||
|
|
||||||
void GLGizmoBase::set_tooltip(const std::string& tooltip) const
|
void GLGizmoBase::set_tooltip(const std::string& tooltip) const
|
||||||
{
|
{
|
||||||
m_parent.set_tooltip(tooltip);
|
m_tooltip = tooltip;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string GLGizmoBase::format(float value, unsigned int decimals) const
|
std::string GLGizmoBase::format(float value, unsigned int decimals) const
|
||||||
|
|
|
@ -100,6 +100,7 @@ protected:
|
||||||
mutable std::vector<Grabber> m_grabbers;
|
mutable std::vector<Grabber> m_grabbers;
|
||||||
ImGuiWrapper* m_imgui;
|
ImGuiWrapper* m_imgui;
|
||||||
bool m_first_input_window_render;
|
bool m_first_input_window_render;
|
||||||
|
mutable std::string m_tooltip;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GLGizmoBase(GLCanvas3D& parent,
|
GLGizmoBase(GLCanvas3D& parent,
|
||||||
|
@ -145,10 +146,12 @@ public:
|
||||||
|
|
||||||
void update(const UpdateData& data);
|
void update(const UpdateData& data);
|
||||||
|
|
||||||
void render() const { on_render(); }
|
void render() const { m_tooltip.clear(); on_render(); }
|
||||||
void render_for_picking() const { on_render_for_picking(); }
|
void render_for_picking() const { on_render_for_picking(); }
|
||||||
void render_input_window(float x, float y, float bottom_limit);
|
void render_input_window(float x, float y, float bottom_limit);
|
||||||
|
|
||||||
|
virtual const std::string& get_tooltip() const { return m_tooltip; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual bool on_init() = 0;
|
virtual bool on_init() = 0;
|
||||||
virtual void on_load(cereal::BinaryInputArchive& ar) {}
|
virtual void on_load(cereal::BinaryInputArchive& ar) {}
|
||||||
|
|
|
@ -79,9 +79,8 @@ void GLGizmoCut::on_update(const UpdateData& data)
|
||||||
|
|
||||||
void GLGizmoCut::on_render() const
|
void GLGizmoCut::on_render() const
|
||||||
{
|
{
|
||||||
if (m_grabbers[0].dragging) {
|
if (m_hover_id == 0 || m_grabbers[0].dragging)
|
||||||
set_tooltip("Z: " + format(m_cut_z, 2));
|
set_tooltip("Z: " + format(m_cut_z, 2));
|
||||||
}
|
|
||||||
|
|
||||||
const Selection& selection = m_parent.get_selection();
|
const Selection& selection = m_parent.get_selection();
|
||||||
|
|
||||||
|
|
|
@ -135,10 +135,8 @@ void GLGizmoRotate::on_render() const
|
||||||
case Z: { axis = "Z"; break; }
|
case Z: { axis = "Z"; break; }
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!m_dragging && (m_hover_id == 0))
|
if (m_hover_id == 0 || m_grabbers[0].dragging)
|
||||||
set_tooltip(axis);
|
set_tooltip(axis + ": " + format((float)Geometry::rad2deg(m_angle), 4));
|
||||||
else if (m_dragging)
|
|
||||||
set_tooltip(axis + ": " + format((float)Geometry::rad2deg(m_angle), 4) + "\u00B0");
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_center = box.center();
|
m_center = box.center();
|
||||||
|
|
|
@ -81,6 +81,16 @@ public:
|
||||||
Vec3d get_rotation() const { return Vec3d(m_gizmos[X].get_angle(), m_gizmos[Y].get_angle(), m_gizmos[Z].get_angle()); }
|
Vec3d get_rotation() const { return Vec3d(m_gizmos[X].get_angle(), m_gizmos[Y].get_angle(), m_gizmos[Z].get_angle()); }
|
||||||
void set_rotation(const Vec3d& rotation) { m_gizmos[X].set_angle(rotation(0)); m_gizmos[Y].set_angle(rotation(1)); m_gizmos[Z].set_angle(rotation(2)); }
|
void set_rotation(const Vec3d& rotation) { m_gizmos[X].set_angle(rotation(0)); m_gizmos[Y].set_angle(rotation(1)); m_gizmos[Z].set_angle(rotation(2)); }
|
||||||
|
|
||||||
|
virtual const std::string& get_tooltip() const
|
||||||
|
{
|
||||||
|
m_tooltip = m_gizmos[X].get_tooltip();
|
||||||
|
if (m_tooltip.empty())
|
||||||
|
m_tooltip = m_gizmos[Y].get_tooltip();
|
||||||
|
if (m_tooltip.empty())
|
||||||
|
m_tooltip = m_gizmos[Z].get_tooltip();
|
||||||
|
return m_tooltip;
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual bool on_init();
|
virtual bool on_init();
|
||||||
virtual std::string on_get_name() const;
|
virtual std::string on_get_name() const;
|
||||||
|
|
|
@ -422,6 +422,15 @@ void GLGizmosManager::render_overlay() const
|
||||||
do_render_overlay();
|
do_render_overlay();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string GLGizmosManager::get_tooltip() const
|
||||||
|
{
|
||||||
|
if (!m_tooltip.empty())
|
||||||
|
return m_tooltip;
|
||||||
|
|
||||||
|
const GLGizmoBase* curr = get_current();
|
||||||
|
return (curr != nullptr) ? curr->get_tooltip() : "";
|
||||||
|
}
|
||||||
|
|
||||||
bool GLGizmosManager::on_mouse_wheel(wxMouseEvent& evt)
|
bool GLGizmosManager::on_mouse_wheel(wxMouseEvent& evt)
|
||||||
{
|
{
|
||||||
bool processed = false;
|
bool processed = false;
|
||||||
|
|
|
@ -204,7 +204,7 @@ public:
|
||||||
|
|
||||||
void render_overlay() const;
|
void render_overlay() const;
|
||||||
|
|
||||||
const std::string& get_tooltip() const { return m_tooltip; }
|
std::string get_tooltip() const;
|
||||||
|
|
||||||
bool on_mouse(wxMouseEvent& evt);
|
bool on_mouse(wxMouseEvent& evt);
|
||||||
bool on_mouse_wheel(wxMouseEvent& evt);
|
bool on_mouse_wheel(wxMouseEvent& evt);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue