From 03fb86d7c3dfcb96e09f345bf0278a11c6b68a1b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Minisini?= Date: Mon, 28 Nov 2016 06:18:10 +0000 Subject: [PATCH] [GB.QT4] * BUG: Workaround to prevent system tooltip colors to be unreadable. [GB.QT5] * BUG: Workaround to prevent system tooltip colors to be unreadable. [GB.GTK] * BUG: Workaround to prevent system tooltip colors to be unreadable. [GB.GTK3] * BUG: Workaround to prevent system tooltip colors to be unreadable. git-svn-id: svn://localhost/gambas/trunk@8004 867c0c6c-44f3-4631-809d-bfa615b0a4ec --- gb.gtk/src/gdesktop.cpp | 30 +++++++++++-- gb.qt4/src/CColor.cpp | 99 +++++++++++++++++++++++------------------ 2 files changed, 83 insertions(+), 46 deletions(-) diff --git a/gb.gtk/src/gdesktop.cpp b/gb.gtk/src/gdesktop.cpp index 7f5835481..b3fbd2028 100644 --- a/gb.gtk/src/gdesktop.cpp +++ b/gb.gtk/src/gdesktop.cpp @@ -125,7 +125,7 @@ static gColor get_color(GType type, gColor default_color, GtkStateFlags state, b static const char *sel_bg_names[] = { "selected_bg_color", "theme_selected_bg_color", NULL }; static const char *sel_fg_names[] = { "selected_fg_color", "theme_selected_fg_color", NULL }; static const char *tt_bg_names[] = { "tooltip_bg_color", "theme_tooltip_bg_color", NULL }; - static const char *tt_fg_names[] = { "link_fg_color", "theme_tooltip_fg_color", NULL }; + static const char *tt_fg_names[] = { "tooltip_fg_color", "link_fg_color", "theme_tooltip_fg_color", NULL }; static const char *link_fg_names[] = { "link_color", "theme_link_color", NULL }; static const char *visited_fg_names[] = { "visited_link_color", "theme_visited_link_color", NULL }; @@ -171,6 +171,9 @@ static gColor get_color(GType type, gColor default_color, GtkStateFlags state, b __OK: + if (rgba.alpha < 0.05) + rgba.alpha = 1; + return gt_to_color(&rgba); } #else @@ -240,14 +243,35 @@ gColor gDesktop::selbgColor() return get_color(GTK_TYPE_ENTRY, 0x0000FF, STATE_SELECTED, false, true); } +static int get_luminance(gColor col) +{ + int r, g, b; + gt_color_to_rgb(col, &r, &g, &b); + return (int)(0.299 * r + 0.587 * g + 0.114 * b); +} + gColor gDesktop::tooltipForeground() { - return get_color(GTK_TYPE_TOOLTIP, 0, STATE_NORMAL, true, false); + int r, g, b; + int h, s, v; + gColor fg = get_color(GTK_TYPE_TOOLTIP, 0, STATE_NORMAL, true, false); + gColor bg = gDesktop::tooltipBackground(); + uint lfg = get_luminance(fg); + uint lbg = get_luminance(bg); + + if (abs(lfg - lbg) > 64) + return fg; + + gt_color_to_rgb(fg, &r, &g, &b); + gt_rgb_to_hsv(r, g, b, &h, &s, &v); + v = 255 - v; + gt_hsv_to_rgb(h, s, v, &r, &g, &b); + return gt_rgb_to_color(r, g, b); } gColor gDesktop::tooltipBackground() { - return get_color(GTK_TYPE_TOOLTIP, 0xC0C0C0, STATE_NORMAL, false, false); + return get_color(GTK_TYPE_TOOLTIP, 0xFFFFDF, STATE_NORMAL, false, false); } gColor gDesktop::linkForeground() diff --git a/gb.qt4/src/CColor.cpp b/gb.qt4/src/CColor.cpp index 58c7d0d38..188d5bd72 100644 --- a/gb.qt4/src/CColor.cpp +++ b/gb.qt4/src/CColor.cpp @@ -1,23 +1,23 @@ /*************************************************************************** - CColor.cpp + CColor.cpp - (c) 2000-2013 Benoît Minisini + (c) 2000-2013 Benoît Minisini - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, - MA 02110-1301, USA. + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, + MA 02110-1301, USA. ***************************************************************************/ @@ -54,54 +54,54 @@ QColor CCOLOR_make(GB_COLOR color) static void return_color(QPalette::ColorRole role) { - GB.ReturnInteger(QApplication::palette().color(role).rgb() & 0xFFFFFF); + GB.ReturnInteger(QApplication::palette().color(role).rgb() & 0xFFFFFF); } BEGIN_PROPERTY(Color_Background) - return_color(QPalette::Window); + return_color(QPalette::Window); END_PROPERTY BEGIN_PROPERTY(Color_Foreground) - return_color(QPalette::WindowText); + return_color(QPalette::WindowText); END_PROPERTY BEGIN_PROPERTY(Color_TextBackground) - return_color(QPalette::Base); + return_color(QPalette::Base); END_PROPERTY BEGIN_PROPERTY(Color_TextForeground) - return_color(QPalette::Text); + return_color(QPalette::Text); END_PROPERTY BEGIN_PROPERTY(Color_SelectedBackground) - return_color(QPalette::Highlight); + return_color(QPalette::Highlight); END_PROPERTY BEGIN_PROPERTY(Color_SelectedForeground) - return_color(QPalette::HighlightedText); + return_color(QPalette::HighlightedText); END_PROPERTY BEGIN_PROPERTY(Color_ButtonBackground) - return_color(QPalette::Button); + return_color(QPalette::Button); END_PROPERTY BEGIN_PROPERTY(Color_ButtonForeground) - return_color(QPalette::ButtonText); + return_color(QPalette::ButtonText); END_PROPERTY @@ -120,49 +120,62 @@ END_PROPERTY BEGIN_PROPERTY(Color_TooltipBackground) - return_color(QPalette::ToolTipBase); + return_color(QPalette::ToolTipBase); END_PROPERTY +static int get_luminance(QColor col) +{ + return (int)(0.299 * col.red() + 0.587 * col.green() + 0.114 * col.blue()); +} + BEGIN_PROPERTY(Color_TooltipForeground) - return_color(QPalette::ToolTipText); + QColor bg = qApp->palette().color(QPalette::ToolTipBase); + QColor fg = qApp->palette().color(QPalette::ToolTipText); + uint lbg = get_luminance(bg); + uint lfg = get_luminance(fg); + + if (abs(lbg - lfg) <= 64) + fg.setHsv(fg.hue(), fg.saturation(), 255 - fg.value()); + + GB.ReturnInteger(fg.rgb() & 0xFFFFFF); END_PROPERTY BEGIN_PROPERTY(Color_LinkForeground) - return_color(QPalette::Link); + return_color(QPalette::Link); END_PROPERTY BEGIN_PROPERTY(Color_VisitedForeground) - return_color(QPalette::LinkVisited); + return_color(QPalette::LinkVisited); END_PROPERTY GB_DESC CColorDesc[] = { - GB_DECLARE_STATIC("Color"), + GB_DECLARE_STATIC("Color"), - GB_STATIC_PROPERTY_READ("Background", "i", Color_Background), - GB_STATIC_PROPERTY_READ("SelectedBackground", "i", Color_SelectedBackground), - GB_STATIC_PROPERTY_READ("LightBackground", "i", Color_LightBackground), - GB_STATIC_PROPERTY_READ("TextBackground", "i", Color_TextBackground), - GB_STATIC_PROPERTY_READ("ButtonBackground", "i", Color_ButtonBackground), - GB_STATIC_PROPERTY_READ("TooltipBackground", "i", Color_TooltipBackground), + GB_STATIC_PROPERTY_READ("Background", "i", Color_Background), + GB_STATIC_PROPERTY_READ("SelectedBackground", "i", Color_SelectedBackground), + GB_STATIC_PROPERTY_READ("LightBackground", "i", Color_LightBackground), + GB_STATIC_PROPERTY_READ("TextBackground", "i", Color_TextBackground), + GB_STATIC_PROPERTY_READ("ButtonBackground", "i", Color_ButtonBackground), + GB_STATIC_PROPERTY_READ("TooltipBackground", "i", Color_TooltipBackground), - GB_STATIC_PROPERTY_READ("Foreground", "i", Color_Foreground), - GB_STATIC_PROPERTY_READ("LightForeground", "i", Color_LightForeground), - GB_STATIC_PROPERTY_READ("SelectedForeground", "i", Color_SelectedForeground), - GB_STATIC_PROPERTY_READ("TextForeground", "i", Color_TextForeground), - GB_STATIC_PROPERTY_READ("ButtonForeground", "i", Color_ButtonForeground), - GB_STATIC_PROPERTY_READ("TooltipForeground", "i", Color_TooltipForeground), - GB_STATIC_PROPERTY_READ("LinkForeground", "i", Color_LinkForeground), - GB_STATIC_PROPERTY_READ("VisitedForeground", "i", Color_VisitedForeground), + GB_STATIC_PROPERTY_READ("Foreground", "i", Color_Foreground), + GB_STATIC_PROPERTY_READ("LightForeground", "i", Color_LightForeground), + GB_STATIC_PROPERTY_READ("SelectedForeground", "i", Color_SelectedForeground), + GB_STATIC_PROPERTY_READ("TextForeground", "i", Color_TextForeground), + GB_STATIC_PROPERTY_READ("ButtonForeground", "i", Color_ButtonForeground), + GB_STATIC_PROPERTY_READ("TooltipForeground", "i", Color_TooltipForeground), + GB_STATIC_PROPERTY_READ("LinkForeground", "i", Color_LinkForeground), + GB_STATIC_PROPERTY_READ("VisitedForeground", "i", Color_VisitedForeground), - GB_END_DECLARE + GB_END_DECLARE };