X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4bc1afd502a0f6f31bddb349a63f41a828f54ded..9cfadba2327cf1535b0f155fdec82ffe119b77c0:/src/msw/textctrl.cpp diff --git a/src/msw/textctrl.cpp b/src/msw/textctrl.cpp index ff6b6c1c97..9d68d44fc6 100644 --- a/src/msw/textctrl.cpp +++ b/src/msw/textctrl.cpp @@ -60,10 +60,15 @@ # include #endif -#if wxUSE_RICHEDIT && !defined(__GNUWIN32_OLD__) +#if wxUSE_RICHEDIT && (!defined(__GNUWIN32_OLD__) || defined(__CYGWIN10__)) #include #endif +// old mingw32 doesn't define this +#ifndef CFM_CHARSET + #define CFM_CHARSET 0x08000000 +#endif // CFM_CHARSET + // ---------------------------------------------------------------------------- // private classes // ---------------------------------------------------------------------------- @@ -1228,10 +1233,11 @@ bool wxTextCtrl::SetStyle(long start, long end, const wxTextAttr& style) // the rich text control doesn't handle setting background colour, so don't // even try if it's the only thing we want to change - if ( !style.HasFont() && !style.HasTextColour() ) + if ( wxRichEditModule::GetLoadedVersion() < 2 && + !style.HasFont() && !style.HasTextColour() ) { - // nothing to do: return TRUE if there was really nothing to doand - // FALSE fi we failed to set bg colour + // nothing to do: return TRUE if there was really nothing to do and + // FALSE if we failed to set bg colour return !style.HasBackgroundColour(); } @@ -1255,7 +1261,11 @@ bool wxTextCtrl::SetStyle(long start, long end, const wxTextAttr& style) SendMessage(GetHwnd(), EM_SETSEL, (WPARAM) start, (LPARAM) end); // initialize CHARFORMAT struct +#if wxUSE_RICHEDIT2 + CHARFORMAT2 cf; +#else CHARFORMAT cf; +#endif wxZeroMemory(cf); cf.cbSize = sizeof(cf); @@ -1302,6 +1312,13 @@ bool wxTextCtrl::SetStyle(long start, long end, const wxTextAttr& style) cf.crTextColor = wxColourToRGB(style.GetTextColour()); } +#if wxUSE_RICHEDIT2 + if ( wxRichEditModule::GetLoadedVersion() > 1 && style.HasBackgroundColour() ) + { + cf.dwMask |= CFM_BACKCOLOR; + cf.crBackColor = wxColourToRGB(style.GetBackgroundColour()); + } +#endif // do format the selection bool ok = ::SendMessage(GetHwnd(), EM_SETCHARFORMAT, SCF_SELECTION, (LPARAM)&cf) != 0;