From b7c640d0613e9720fda7aa08b68a16c271bb77f3 Mon Sep 17 00:00:00 2001 From: wangqr Date: Fri, 17 May 2019 03:01:31 -0400 Subject: [PATCH] Fix High DPI issue on GTK * Use icon size in the config --- src/subs_edit_box.cpp | 3 +-- src/utils.cpp | 10 ++++++++-- src/visual_tool_drag.cpp | 8 +++++++- src/visual_tool_vector_clip.cpp | 8 +++++++- 4 files changed, 23 insertions(+), 6 deletions(-) diff --git a/src/subs_edit_box.cpp b/src/subs_edit_box.cpp index 9dff8d413..9e896a272 100644 --- a/src/subs_edit_box.cpp +++ b/src/subs_edit_box.cpp @@ -276,8 +276,7 @@ TimeEdit *SubsEditBox::MakeTimeCtrl(wxString const& tooltip, TimeField field) { void SubsEditBox::MakeButton(const char *cmd_name) { cmd::Command *command = cmd::get(cmd_name); - // FIXME: Hard coded icon size. Use icon size in config instead. Or maybe use toolbar to construct this - wxBitmapButton *btn = new wxBitmapButton(this, -1, command->Icon(int(16 * GetContentScaleFactor()))); + wxBitmapButton *btn = new wxBitmapButton(this, -1, command->Icon(OPT_GET("App/Toolbar Icon Size")->GetInt())); ToolTipManager::Bind(btn, command->StrHelp(), "Subtitle Edit Box", cmd_name); middle_right_sizer->Add(btn, wxSizerFlags().Expand()); diff --git a/src/utils.cpp b/src/utils.cpp index 69c53bd1c..6b23dc763 100644 --- a/src/utils.cpp +++ b/src/utils.cpp @@ -214,9 +214,15 @@ void AddFullScreenButton(wxWindow *) { } void SetFloatOnParent(wxWindow *) { } // OS X implementation in retina_helper.mm -RetinaHelper::RetinaHelper(wxWindow *) { } +RetinaHelper::RetinaHelper(wxWindow* w) { window = w; } RetinaHelper::~RetinaHelper() { } -int RetinaHelper::GetScaleFactor() const { return 1; } +int RetinaHelper::GetScaleFactor() const { +#ifdef __WXGTK__ + return int(window->GetContentScaleFactor()); +#else + return 1; +#endif +} // OS X implementation in scintilla_ime.mm namespace osx { namespace ime { diff --git a/src/visual_tool_drag.cpp b/src/visual_tool_drag.cpp index 9d8aa6594..6916ae139 100644 --- a/src/visual_tool_drag.cpp +++ b/src/visual_tool_drag.cpp @@ -42,7 +42,13 @@ static const DraggableFeatureType DRAG_ORIGIN = DRAG_BIG_TRIANGLE; static const DraggableFeatureType DRAG_START = DRAG_BIG_SQUARE; static const DraggableFeatureType DRAG_END = DRAG_BIG_CIRCLE; -#define ICON(name) (OPT_GET("App/Toolbar Icon Size")->GetInt() == 16 ? GETIMAGE(name ## _16) : GETIMAGE(name ## _24)) +#define ICON(name) ( \ + OPT_GET("App/Toolbar Icon Size")->GetInt() >= 64 ? GETIMAGE(name##_64) : \ + OPT_GET("App/Toolbar Icon Size")->GetInt() >= 48 ? GETIMAGE(name##_48) : \ + OPT_GET("App/Toolbar Icon Size")->GetInt() >= 32 ? GETIMAGE(name##_32) : \ + OPT_GET("App/Toolbar Icon Size")->GetInt() >= 24 ? GETIMAGE(name##_24) : \ + GETIMAGE(name##_16) \ +) VisualToolDrag::VisualToolDrag(VideoDisplay *parent, agi::Context *context) : VisualTool(parent, context) diff --git a/src/visual_tool_vector_clip.cpp b/src/visual_tool_vector_clip.cpp index bbe00d8e9..c80caab51 100644 --- a/src/visual_tool_vector_clip.cpp +++ b/src/visual_tool_vector_clip.cpp @@ -54,7 +54,13 @@ void VisualToolVectorClip::SetToolbar(wxToolBar *toolBar) { int icon_size = OPT_GET("App/Toolbar Icon Size")->GetInt(); -#define ICON(name) icon_size == 16 ? GETIMAGE(name ## _16) : GETIMAGE(name ## _24) +#define ICON(name) ( \ + icon_size >= 64 ? GETIMAGE(name##_64) : \ + icon_size >= 48 ? GETIMAGE(name##_48) : \ + icon_size >= 32 ? GETIMAGE(name##_32) : \ + icon_size >= 24 ? GETIMAGE(name##_24) : \ + GETIMAGE(name##_16) \ +) toolBar->AddTool(BUTTON_DRAG, _("Drag"), ICON(visual_vector_clip_drag), _("Drag control points"), wxITEM_CHECK); toolBar->AddTool(BUTTON_LINE, _("Line"), ICON(visual_vector_clip_line), _("Appends a line"), wxITEM_CHECK); toolBar->AddTool(BUTTON_BICUBIC, _("Bicubic"), ICON(visual_vector_clip_bicubic), _("Appends a bezier bicubic curve"), wxITEM_CHECK);