Fix Dark Mode Menu Bar cluttered issue
Use correct enums for dark mode menubar Fix #14910, fix #10130, close #14911
This commit is contained in:
parent
60034edf37
commit
243112d04d
|
@ -41,6 +41,10 @@
|
|||
#define WINAPI_LAMBDA
|
||||
#endif
|
||||
|
||||
#ifndef WM_DPICHANGED
|
||||
#define WM_DPICHANGED 0x02E0
|
||||
#endif
|
||||
|
||||
// already added in project files
|
||||
// keep for plugin authors
|
||||
//#ifdef _MSC_VER
|
||||
|
@ -770,16 +774,15 @@ namespace NppDarkMode
|
|||
|
||||
// processes messages related to UAH / custom menubar drawing.
|
||||
// return true if handled, false to continue with normal processing in your wndproc
|
||||
bool runUAHWndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam, LRESULT* lr)
|
||||
bool runUAHWndProc(HWND hWnd, UINT message, WPARAM /*wParam*/, LPARAM lParam, LRESULT* lr)
|
||||
{
|
||||
static HTHEME g_menuTheme = nullptr;
|
||||
|
||||
UNREFERENCED_PARAMETER(wParam);
|
||||
switch (message)
|
||||
{
|
||||
case WM_UAHDRAWMENU:
|
||||
{
|
||||
UAHMENU* pUDM = (UAHMENU*)lParam;
|
||||
auto pUDM = reinterpret_cast<UAHMENU*>(lParam);
|
||||
RECT rc{};
|
||||
|
||||
// get the menubar rect
|
||||
|
@ -804,9 +807,10 @@ namespace NppDarkMode
|
|||
|
||||
return true;
|
||||
}
|
||||
|
||||
case WM_UAHDRAWMENUITEM:
|
||||
{
|
||||
UAHDRAWMENUITEM* pUDMI = (UAHDRAWMENUITEM*)lParam;
|
||||
auto pUDMI = reinterpret_cast<UAHDRAWMENUITEM*>(lParam);
|
||||
|
||||
// get the menu item string
|
||||
wchar_t menuString[256] = { '\0' };
|
||||
|
@ -824,32 +828,32 @@ namespace NppDarkMode
|
|||
|
||||
DWORD dwFlags = DT_CENTER | DT_SINGLELINE | DT_VCENTER;
|
||||
|
||||
int iTextStateID = MPI_NORMAL;
|
||||
int iBackgroundStateID = MPI_NORMAL;
|
||||
int iTextStateID = MBI_NORMAL;
|
||||
int iBackgroundStateID = MBI_NORMAL;
|
||||
{
|
||||
if ((pUDMI->dis.itemState & ODS_INACTIVE) | (pUDMI->dis.itemState & ODS_DEFAULT))
|
||||
{
|
||||
// normal display
|
||||
iTextStateID = MPI_NORMAL;
|
||||
iBackgroundStateID = MPI_NORMAL;
|
||||
iTextStateID = MBI_NORMAL;
|
||||
iBackgroundStateID = MBI_NORMAL;
|
||||
}
|
||||
if (pUDMI->dis.itemState & ODS_HOTLIGHT)
|
||||
{
|
||||
// hot tracking
|
||||
iTextStateID = MPI_HOT;
|
||||
iBackgroundStateID = MPI_HOT;
|
||||
iTextStateID = MBI_HOT;
|
||||
iBackgroundStateID = MBI_HOT;
|
||||
}
|
||||
if (pUDMI->dis.itemState & ODS_SELECTED)
|
||||
{
|
||||
// clicked -- MENU_POPUPITEM has no state for this, though MENU_BARITEM does
|
||||
iTextStateID = MPI_HOT;
|
||||
iBackgroundStateID = MPI_HOT;
|
||||
// clicked
|
||||
iTextStateID = MBI_PUSHED;
|
||||
iBackgroundStateID = MBI_PUSHED;
|
||||
}
|
||||
if ((pUDMI->dis.itemState & ODS_GRAYED) || (pUDMI->dis.itemState & ODS_DISABLED))
|
||||
{
|
||||
// disabled / grey text
|
||||
iTextStateID = MPI_DISABLED;
|
||||
iBackgroundStateID = MPI_DISABLED;
|
||||
iTextStateID = MBI_DISABLED;
|
||||
iBackgroundStateID = MBI_DISABLED;
|
||||
}
|
||||
if (pUDMI->dis.itemState & ODS_NOACCEL)
|
||||
{
|
||||
|
@ -862,31 +866,57 @@ namespace NppDarkMode
|
|||
g_menuTheme = OpenThemeData(hWnd, L"Menu");
|
||||
}
|
||||
|
||||
if (iBackgroundStateID == MPI_NORMAL || iBackgroundStateID == MPI_DISABLED)
|
||||
switch (iBackgroundStateID)
|
||||
{
|
||||
FillRect(pUDMI->um.hdc, &pUDMI->dis.rcItem, NppDarkMode::getDarkerBackgroundBrush());
|
||||
}
|
||||
else if (iBackgroundStateID == MPI_HOT || iBackgroundStateID == MPI_DISABLEDHOT)
|
||||
case MBI_NORMAL:
|
||||
case MBI_DISABLED:
|
||||
{
|
||||
FillRect(pUDMI->um.hdc, &pUDMI->dis.rcItem, NppDarkMode::getHotBackgroundBrush());
|
||||
::FillRect(pUDMI->um.hdc, &pUDMI->dis.rcItem, NppDarkMode::getDarkerBackgroundBrush());
|
||||
break;
|
||||
}
|
||||
else
|
||||
|
||||
case MBI_HOT:
|
||||
case MBI_DISABLEDHOT:
|
||||
{
|
||||
DrawThemeBackground(g_menuTheme, pUDMI->um.hdc, MENU_POPUPITEM, iBackgroundStateID, &pUDMI->dis.rcItem, nullptr);
|
||||
::FillRect(pUDMI->um.hdc, &pUDMI->dis.rcItem, NppDarkMode::getHotBackgroundBrush());
|
||||
break;
|
||||
}
|
||||
|
||||
case MBI_PUSHED:
|
||||
case MBI_DISABLEDPUSHED:
|
||||
{
|
||||
::FillRect(pUDMI->um.hdc, &pUDMI->dis.rcItem, NppDarkMode::getSofterBackgroundBrush());
|
||||
break;
|
||||
}
|
||||
|
||||
default:
|
||||
{
|
||||
::DrawThemeBackground(g_menuTheme, pUDMI->um.hdc, MENU_BARITEM, iBackgroundStateID, &pUDMI->dis.rcItem, nullptr);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
DTTOPTS dttopts{};
|
||||
dttopts.dwSize = sizeof(DTTOPTS);
|
||||
if (iTextStateID == MPI_NORMAL || iTextStateID == MPI_HOT)
|
||||
if (iTextStateID == MBI_NORMAL || iTextStateID == MBI_HOT || iTextStateID == MBI_PUSHED)
|
||||
{
|
||||
dttopts.dwFlags |= DTT_TEXTCOLOR;
|
||||
dttopts.crText = NppDarkMode::getTextColor();
|
||||
}
|
||||
DrawThemeTextEx(g_menuTheme, pUDMI->um.hdc, MENU_POPUPITEM, iTextStateID, menuString, mii.cch, dwFlags, &pUDMI->dis.rcItem, &dttopts);
|
||||
else if (iTextStateID == MBI_DISABLED || iTextStateID == MBI_DISABLEDHOT || iTextStateID == MBI_DISABLEDPUSHED)
|
||||
{
|
||||
dttopts.dwFlags |= DTT_TEXTCOLOR;
|
||||
dttopts.crText = NppDarkMode::getDisabledTextColor();
|
||||
}
|
||||
|
||||
::DrawThemeTextEx(g_menuTheme, pUDMI->um.hdc, MENU_BARITEM, iTextStateID, menuString, mii.cch, dwFlags, &pUDMI->dis.rcItem, &dttopts);
|
||||
|
||||
*lr = 0;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
case WM_DPICHANGED:
|
||||
case WM_THEMECHANGED:
|
||||
{
|
||||
if (g_menuTheme)
|
||||
|
|
Loading…
Reference in New Issue