Code refactoring

This commit is contained in:
YuSanka 2019-04-17 11:22:30 +02:00
parent 3b9803ba6e
commit 3e9c0c396e
3 changed files with 84 additions and 86 deletions

View File

@ -59,20 +59,41 @@ public:
{ {
m_scale_factor = (float)get_dpi_for_window(this) / (float)DPI_DEFAULT; m_scale_factor = (float)get_dpi_for_window(this) / (float)DPI_DEFAULT;
// ->- m_prev_scale_factor = m_scale_factor;
m_prev_scale_factor = -1;
// -<-
recalc_font(); recalc_font();
this->Bind(EVT_DPI_CHANGED, [this](const DpiChangedEvent &evt) { this->Bind(EVT_DPI_CHANGED, [this](const DpiChangedEvent &evt) {
// ->-
if (m_prev_scale_factor < 0)
reset_prev_scale_factor();
// -<-
m_scale_factor = (float)evt.dpi / (float)DPI_DEFAULT; m_scale_factor = (float)evt.dpi / (float)DPI_DEFAULT;
on_dpi_changed(evt.rect);
if (!m_can_rescale)
return;
if (is_new_scale_factor())
rescale(evt.rect);
});
this->Bind(wxEVT_MOVE_START, [this](wxMoveEvent& event)
{
event.Skip();
// Suppress application rescaling, when a MainFrame moving is not ended
m_can_rescale = false;
});
this->Bind(wxEVT_MOVE_END, [this](wxMoveEvent& event)
{
event.Skip();
m_can_rescale = is_new_scale_factor();
// If scale factor is different after moving of MainFrame ...
if (m_can_rescale)
// ... rescale application
rescale(event.GetRect());
else
// set value to _true_ in purpose of possibility of a display dpi changing from System Settings
m_can_rescale = true;
}); });
} }
@ -80,23 +101,21 @@ public:
float scale_factor() const { return m_scale_factor; } float scale_factor() const { return m_scale_factor; }
float prev_scale_factor() const { return m_prev_scale_factor; } float prev_scale_factor() const { return m_prev_scale_factor; }
void reset_prev_scale_factor() { m_prev_scale_factor = m_scale_factor; }
int em_unit() const { return m_em_unit; } int em_unit() const { return m_em_unit; }
int font_size() const { return m_font_size; } int font_size() const { return m_font_size; }
protected: protected:
virtual void on_dpi_changed(const wxRect &suggested_rect) = 0; virtual void on_dpi_changed(const wxRect &suggested_rect) = 0;
// ->-
// virtual void scale(wxWindow *window, const float& scale) = 0;
// -<-
private: private:
float m_scale_factor; float m_scale_factor;
float m_prev_scale_factor;
int m_em_unit; int m_em_unit;
int m_font_size; int m_font_size;
float m_prev_scale_factor;
bool m_can_rescale{ true };
void recalc_font() void recalc_font()
{ {
wxClientDC dc(this); wxClientDC dc(this);
@ -104,6 +123,40 @@ private:
m_font_size = metrics.height; m_font_size = metrics.height;
m_em_unit = metrics.averageWidth; m_em_unit = metrics.averageWidth;
} }
// check if new scale is differ from previous
bool is_new_scale_factor() const { return fabs(m_scale_factor - m_prev_scale_factor) > 0.001; }
// recursive function for scaling fonts for all controls in Window
void scale_controls_fonts(wxWindow *window, const float scale_f)
{
auto children = window->GetChildren();
for (auto child : children) {
scale_controls_fonts(child, scale_f);
child->SetFont(child->GetFont().Scaled(scale_f));
}
window->Layout();
}
void rescale(const wxRect &suggested_rect)
{
this->Freeze();
// rescale fonts of all controls
scale_controls_fonts(this, m_scale_factor / m_prev_scale_factor);
// rescale missed controls sizes and images
on_dpi_changed(suggested_rect);
this->Layout();
this->Thaw();
// reset previous scale factor from current scale factor value
m_prev_scale_factor = m_scale_factor;
}
}; };
typedef DPIAware<wxFrame> DPIFrame; typedef DPIAware<wxFrame> DPIFrame;

View File

@ -129,30 +129,6 @@ DPIFrame(NULL, wxID_ANY, SLIC3R_BUILD, wxDefaultPosition, wxDefaultSize, wxDEFAU
event.Skip(); event.Skip();
}); });
Bind(wxEVT_MOVE_START, [this](wxMoveEvent& event)
{
event.Skip();
// Suppress application rescaling, when a MainFrame moving is not ended
m_can_rescale_application = false;
// Cash scale factor value before a MainFrame moving
m_scale_factor_cache = scale_factor();
});
Bind(wxEVT_MOVE_END, [this](wxMoveEvent& event)
{
event.Skip();
// If scale factor is different after moving of MainFrame ...
m_can_rescale_application = fabs(m_scale_factor_cache - scale_factor()) > 0.0001;
// ... rescale application
on_dpi_changed(event.GetRect());
// set value to _true_ in purpose of possibility of a display dpi changing from System Settings
m_can_rescale_application = true;
});
wxGetApp().persist_window_geometry(this); wxGetApp().persist_window_geometry(this);
update_ui_from_settings(); // FIXME (?) update_ui_from_settings(); // FIXME (?)
@ -280,41 +256,20 @@ bool MainFrame::can_delete_all() const
return (m_plater != nullptr) ? !m_plater->model().objects.empty() : false; return (m_plater != nullptr) ? !m_plater->model().objects.empty() : false;
} }
// scale font for existing controls
static void scale_controls_fonts(wxWindow *window, const float scale_f)
{
auto children = window->GetChildren();
for (auto child : children)
{
scale_controls_fonts(child, scale_f);
child->SetFont(child->GetFont().Scaled(scale_f));
}
window->Layout();
}
void MainFrame::on_dpi_changed(const wxRect &suggested_rect) void MainFrame::on_dpi_changed(const wxRect &suggested_rect)
{ {
if (!m_can_rescale_application)
return;
printf("WM_DPICHANGED: %.2f\n", scale_factor());
const float old_sc_factor = prev_scale_factor(); const float old_sc_factor = prev_scale_factor();
const float new_sc_factor = scale_factor(); const float new_sc_factor = scale_factor();
if (fabs(old_sc_factor - new_sc_factor) > 0.001) printf("old_sc_factor: %.2f \n", old_sc_factor);
{ printf("new_sc_factor: %.2f\n\n", new_sc_factor);
printf("\told_sc_factor: %.2f\n", old_sc_factor);
printf("\tnew_sc_factor: %.2f\n", new_sc_factor);
Freeze(); const float relative_scale_factor = new_sc_factor / old_sc_factor;
scale_controls_fonts(this, new_sc_factor / old_sc_factor); wxGetApp().scale_default_fonts(relative_scale_factor);
wxGetApp().scale_default_fonts(new_sc_factor / old_sc_factor);
const auto new_em_unit = wxGetApp().em_unit()*new_sc_factor / old_sc_factor; // _strange_ workaround for correct em_unit calculation
const int new_em_unit = new_sc_factor * 10;//int(relative_scale_factor*wxGetApp().em_unit());
wxGetApp().set_em_unit(std::max<size_t>(10, new_em_unit)); wxGetApp().set_em_unit(std::max<size_t>(10, new_em_unit));
/* Load default preset bitmaps before a tabpanel initialization, /* Load default preset bitmaps before a tabpanel initialization,
@ -328,14 +283,6 @@ void MainFrame::on_dpi_changed(const wxRect &suggested_rect)
// update Tabs // update Tabs
for (auto tab : wxGetApp().tabs_list) for (auto tab : wxGetApp().tabs_list)
tab->rescale(); tab->rescale();
Layout();
Thaw();
Refresh();
reset_prev_scale_factor();
}
} }
void MainFrame::init_menubar() void MainFrame::init_menubar()

View File

@ -44,8 +44,6 @@ struct PresetTab {
class MainFrame : public DPIFrame class MainFrame : public DPIFrame
{ {
bool m_loaded {false}; bool m_loaded {false};
bool m_can_rescale_application {true};
float m_scale_factor_cache;
wxString m_qs_last_input_file = wxEmptyString; wxString m_qs_last_input_file = wxEmptyString;
wxString m_qs_last_output_file = wxEmptyString; wxString m_qs_last_output_file = wxEmptyString;