Add markup support to wxMSW wxButton and show it in the sample.

Use recently added wxMarkupText to implement support for markup in wxMSW
wxButton.

Update the button page of the widgets sample to show markup support.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@67065 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2011-02-27 12:48:26 +00:00
parent c27126c7bc
commit 95912bddde
3 changed files with 124 additions and 12 deletions

View File

@ -85,6 +85,10 @@ protected:
virtual void DoSetBitmapMargins(wxCoord x, wxCoord y); virtual void DoSetBitmapMargins(wxCoord x, wxCoord y);
virtual void DoSetBitmapPosition(wxDirection dir); virtual void DoSetBitmapPosition(wxDirection dir);
#if wxUSE_MARKUP
virtual bool DoSetLabelMarkup(const wxString& markup);
#endif // wxUSE_MARKUP
// Increases the passed in size to account for the button image. // Increases the passed in size to account for the button image.
// //
// Should only be called if we do have a button, i.e. if m_imageData is // Should only be called if we do have a button, i.e. if m_imageData is
@ -93,6 +97,10 @@ protected:
class wxButtonImageData *m_imageData; class wxButtonImageData *m_imageData;
#if wxUSE_MARKUP
class wxMarkupText *m_markupText;
#endif // wxUSE_MARKUP
// true if the UAC symbol is shown // true if the UAC symbol is shown
bool m_authNeeded; bool m_authNeeded;
@ -100,6 +108,9 @@ private:
void Init() void Init()
{ {
m_imageData = NULL; m_imageData = NULL;
#if wxUSE_MARKUP
m_markupText = NULL;
#endif // wxUSE_MARKUP
m_authNeeded = false; m_authNeeded = false;
} }

View File

@ -131,6 +131,9 @@ protected:
#if wxUSE_COMMANDLINKBUTTON #if wxUSE_COMMANDLINKBUTTON
*m_chkCommandLink, *m_chkCommandLink,
#endif // wxUSE_COMMANDLINKBUTTON #endif // wxUSE_COMMANDLINKBUTTON
#if wxUSE_MARKUP
*m_chkUseMarkup,
#endif // wxUSE_MARKUP
*m_chkDefault; *m_chkDefault;
// more checkboxes for wxBitmapButton only // more checkboxes for wxBitmapButton only
@ -209,6 +212,9 @@ ButtonWidgetsPage::ButtonWidgetsPage(WidgetsBookCtrl *book,
#if wxUSE_COMMANDLINKBUTTON #if wxUSE_COMMANDLINKBUTTON
m_chkCommandLink = m_chkCommandLink =
#endif // wxUSE_COMMANDLINKBUTTON #endif // wxUSE_COMMANDLINKBUTTON
#if wxUSE_MARKUP
m_chkUseMarkup =
#endif // wxUSE_MARKUP
m_chkDefault = m_chkDefault =
m_chkUsePressed = m_chkUsePressed =
m_chkUseFocused = m_chkUseFocused =
@ -241,6 +247,9 @@ void ButtonWidgetsPage::CreateContent()
#if wxUSE_COMMANDLINKBUTTON #if wxUSE_COMMANDLINKBUTTON
m_chkCommandLink = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("Use command &link button")); m_chkCommandLink = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("Use command &link button"));
#endif #endif
#if wxUSE_MARKUP
m_chkUseMarkup = CreateCheckBoxAndAddToSizer(sizerLeft, "Interpret &markup");
#endif // wxUSE_MARKUP
m_chkDefault = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("&Default")); m_chkDefault = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("&Default"));
sizerLeft->AddSpacer(5); sizerLeft->AddSpacer(5);
@ -351,6 +360,9 @@ void ButtonWidgetsPage::Reset()
#if wxUSE_COMMANDLINKBUTTON #if wxUSE_COMMANDLINKBUTTON
m_chkCommandLink->SetValue(false); m_chkCommandLink->SetValue(false);
#endif #endif
#if wxUSE_MARKUP
m_chkUseMarkup->SetValue(false);
#endif // wxUSE_MARKUP
m_chkUsePressed->SetValue(true); m_chkUsePressed->SetValue(true);
m_chkUseFocused->SetValue(true); m_chkUseFocused->SetValue(true);
@ -547,12 +559,21 @@ void ButtonWidgetsPage::OnCheckOrRadioBox(wxCommandEvent& WXUNUSED(event))
void ButtonWidgetsPage::OnButtonChangeLabel(wxCommandEvent& WXUNUSED(event)) void ButtonWidgetsPage::OnButtonChangeLabel(wxCommandEvent& WXUNUSED(event))
{ {
const wxString labelText = m_textLabel->GetValue();
#if wxUSE_COMMANDLINKBUTTON #if wxUSE_COMMANDLINKBUTTON
if ( m_cmdLnkButton ) if ( m_cmdLnkButton )
m_cmdLnkButton->SetMainLabel(m_textLabel->GetValue()); m_cmdLnkButton->SetMainLabel(labelText);
else else
#endif // wxUSE_COMMANDLINKBUTTON #endif // wxUSE_COMMANDLINKBUTTON
m_button->SetLabel(m_textLabel->GetValue()); {
#if wxUSE_MARKUP
if ( m_chkUseMarkup->GetValue() )
m_button->SetLabelMarkup(labelText);
else
#endif // wxUSE_MARKUP
m_button->SetLabel(labelText);
}
m_sizerButton->Layout(); m_sizerButton->Layout();
} }

View File

@ -48,6 +48,10 @@
#include "wx/msw/private/dc.h" #include "wx/msw/private/dc.h"
#include "wx/private/window.h" #include "wx/private/window.h"
#if wxUSE_MARKUP
#include "wx/generic/private/markuptext.h"
#endif // wxUSE_MARKUP
using namespace wxMSWImpl; using namespace wxMSWImpl;
#if wxUSE_UXTHEME #if wxUSE_UXTHEME
@ -490,6 +494,9 @@ wxButton::~wxButton()
} }
delete m_imageData; delete m_imageData;
#if wxUSE_MARKUP
delete m_markupText;
#endif // wxUSE_MARKUP
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@ -533,6 +540,23 @@ void wxButton::SetLabel(const wxString& label)
wxMSWButton::UpdateMultilineStyle(GetHwnd(), label); wxMSWButton::UpdateMultilineStyle(GetHwnd(), label);
wxButtonBase::SetLabel(label); wxButtonBase::SetLabel(label);
#if wxUSE_MARKUP
// If we have a plain text label, we shouldn't be using markup any longer.
if ( m_markupText )
{
delete m_markupText;
m_markupText = NULL;
// Unfortunately we don't really know whether we can reset the button
// to be non-owner-drawn or not: if we had made it owner-drawn just
// because of a call to SetLabelMarkup(), we could, but not if there
// were [also] calls to Set{Fore,Back}groundColour(). If it's really a
// problem to have button remain owner-drawn forever just because it
// had markup label once, we should record the reason for our current
// owner-drawnness and check it here.
}
#endif // wxUSE_MARKUP
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@ -616,7 +640,19 @@ wxSize wxButton::DoGetBestSize() const
if ( GetAuthNeeded() ) if ( GetAuthNeeded() )
flags |= wxMSWButton::Size_AuthNeeded; flags |= wxMSWButton::Size_AuthNeeded;
size = wxMSWButton::ComputeBestFittingSize(self, flags); #if wxUSE_MARKUP
if ( m_markupText )
{
wxClientDC dc(self);
size = wxMSWButton::GetFittingSize(self,
m_markupText->Measure(dc),
flags);
}
else // Normal plain text (but possibly multiline) label.
#endif // wxUSE_MARKUP
{
size = wxMSWButton::ComputeBestFittingSize(self, flags);
}
} }
if ( m_imageData ) if ( m_imageData )
@ -1005,6 +1041,35 @@ void wxButton::DoSetBitmapPosition(wxDirection dir)
InvalidateBestSize(); InvalidateBestSize();
} }
// ----------------------------------------------------------------------------
// markup support
// ----------------------------------------------------------------------------
#if wxUSE_MARKUP
bool wxButton::DoSetLabelMarkup(const wxString& markup)
{
if ( !wxButtonBase::DoSetLabelMarkup(markup) )
return false;
if ( !m_markupText )
{
m_markupText = new wxMarkupText(markup);
MakeOwnerDrawn();
}
else
{
// We are already owner-drawn so just update the text.
m_markupText->SetMarkup(markup);
}
Refresh();
return true;
}
#endif // wxUSE_MARKUP
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// owner-drawn buttons support // owner-drawn buttons support
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@ -1035,12 +1100,8 @@ wxButton::State GetButtonState(wxButton *btn, UINT state)
void DrawButtonText(HDC hdc, void DrawButtonText(HDC hdc,
RECT *pRect, RECT *pRect,
const wxString& text, const wxString& text,
COLORREF col,
int flags) int flags)
{ {
wxTextColoursChanger changeFg(hdc, col, CLR_INVALID);
wxBkModeChanger changeBkMode(hdc, wxBRUSHSTYLE_TRANSPARENT);
// center text horizontally in any case // center text horizontally in any case
flags |= DT_CENTER; flags |= DT_CENTER;
@ -1393,11 +1454,30 @@ bool wxButton::MSWOnDraw(WXDRAWITEMSTRUCT *wxdis)
? ::GetSysColor(COLOR_GRAYTEXT) ? ::GetSysColor(COLOR_GRAYTEXT)
: wxColourToRGB(GetForegroundColour()); : wxColourToRGB(GetForegroundColour());
// notice that DT_HIDEPREFIX doesn't work on old (pre-Windows 2000) wxTextColoursChanger changeFg(hdc, colFg, CLR_INVALID);
// systems but by happy coincidence ODS_NOACCEL is not used under them wxBkModeChanger changeBkMode(hdc, wxBRUSHSTYLE_TRANSPARENT);
// neither so DT_HIDEPREFIX should never be used there
DrawButtonText(hdc, &rectBtn, GetLabel(), colFg, #if wxUSE_MARKUP
state & ODS_NOACCEL ? DT_HIDEPREFIX : 0); if ( m_markupText )
{
wxDCTemp dc((WXHDC)hdc);
dc.SetTextForeground(wxColour(colFg));
dc.SetFont(GetFont());
m_markupText->Render(dc, wxRectFromRECT(rectBtn),
state & ODS_NOACCEL
? wxMarkupText::Render_Default
: wxMarkupText::Render_ShowAccels);
}
else // Plain text label
#endif // wxUSE_MARKUP
{
// notice that DT_HIDEPREFIX doesn't work on old (pre-Windows 2000)
// systems but by happy coincidence ODS_NOACCEL is not used under
// them neither so DT_HIDEPREFIX should never be used there
DrawButtonText(hdc, &rectBtn, GetLabel(),
state & ODS_NOACCEL ? DT_HIDEPREFIX : 0);
}
} }
return true; return true;