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:
parent
c27126c7bc
commit
95912bddde
@ -85,6 +85,10 @@ protected:
|
||||
virtual void DoSetBitmapMargins(wxCoord x, wxCoord y);
|
||||
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.
|
||||
//
|
||||
// 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;
|
||||
|
||||
#if wxUSE_MARKUP
|
||||
class wxMarkupText *m_markupText;
|
||||
#endif // wxUSE_MARKUP
|
||||
|
||||
// true if the UAC symbol is shown
|
||||
bool m_authNeeded;
|
||||
|
||||
@ -100,6 +108,9 @@ private:
|
||||
void Init()
|
||||
{
|
||||
m_imageData = NULL;
|
||||
#if wxUSE_MARKUP
|
||||
m_markupText = NULL;
|
||||
#endif // wxUSE_MARKUP
|
||||
m_authNeeded = false;
|
||||
}
|
||||
|
||||
|
@ -131,6 +131,9 @@ protected:
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
*m_chkCommandLink,
|
||||
#endif // wxUSE_COMMANDLINKBUTTON
|
||||
#if wxUSE_MARKUP
|
||||
*m_chkUseMarkup,
|
||||
#endif // wxUSE_MARKUP
|
||||
*m_chkDefault;
|
||||
|
||||
// more checkboxes for wxBitmapButton only
|
||||
@ -209,6 +212,9 @@ ButtonWidgetsPage::ButtonWidgetsPage(WidgetsBookCtrl *book,
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
m_chkCommandLink =
|
||||
#endif // wxUSE_COMMANDLINKBUTTON
|
||||
#if wxUSE_MARKUP
|
||||
m_chkUseMarkup =
|
||||
#endif // wxUSE_MARKUP
|
||||
m_chkDefault =
|
||||
m_chkUsePressed =
|
||||
m_chkUseFocused =
|
||||
@ -241,6 +247,9 @@ void ButtonWidgetsPage::CreateContent()
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
m_chkCommandLink = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("Use command &link button"));
|
||||
#endif
|
||||
#if wxUSE_MARKUP
|
||||
m_chkUseMarkup = CreateCheckBoxAndAddToSizer(sizerLeft, "Interpret &markup");
|
||||
#endif // wxUSE_MARKUP
|
||||
m_chkDefault = CreateCheckBoxAndAddToSizer(sizerLeft, wxT("&Default"));
|
||||
|
||||
sizerLeft->AddSpacer(5);
|
||||
@ -351,6 +360,9 @@ void ButtonWidgetsPage::Reset()
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
m_chkCommandLink->SetValue(false);
|
||||
#endif
|
||||
#if wxUSE_MARKUP
|
||||
m_chkUseMarkup->SetValue(false);
|
||||
#endif // wxUSE_MARKUP
|
||||
|
||||
m_chkUsePressed->SetValue(true);
|
||||
m_chkUseFocused->SetValue(true);
|
||||
@ -547,12 +559,21 @@ void ButtonWidgetsPage::OnCheckOrRadioBox(wxCommandEvent& WXUNUSED(event))
|
||||
|
||||
void ButtonWidgetsPage::OnButtonChangeLabel(wxCommandEvent& WXUNUSED(event))
|
||||
{
|
||||
const wxString labelText = m_textLabel->GetValue();
|
||||
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
if ( m_cmdLnkButton )
|
||||
m_cmdLnkButton->SetMainLabel(m_textLabel->GetValue());
|
||||
m_cmdLnkButton->SetMainLabel(labelText);
|
||||
else
|
||||
#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();
|
||||
}
|
||||
|
@ -48,6 +48,10 @@
|
||||
#include "wx/msw/private/dc.h"
|
||||
#include "wx/private/window.h"
|
||||
|
||||
#if wxUSE_MARKUP
|
||||
#include "wx/generic/private/markuptext.h"
|
||||
#endif // wxUSE_MARKUP
|
||||
|
||||
using namespace wxMSWImpl;
|
||||
|
||||
#if wxUSE_UXTHEME
|
||||
@ -490,6 +494,9 @@ wxButton::~wxButton()
|
||||
}
|
||||
|
||||
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);
|
||||
|
||||
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,8 +640,20 @@ wxSize wxButton::DoGetBestSize() const
|
||||
if ( GetAuthNeeded() )
|
||||
flags |= wxMSWButton::Size_AuthNeeded;
|
||||
|
||||
#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 )
|
||||
AdjustForBitmapSize(size);
|
||||
@ -1005,6 +1041,35 @@ void wxButton::DoSetBitmapPosition(wxDirection dir)
|
||||
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
|
||||
// ----------------------------------------------------------------------------
|
||||
@ -1035,12 +1100,8 @@ wxButton::State GetButtonState(wxButton *btn, UINT state)
|
||||
void DrawButtonText(HDC hdc,
|
||||
RECT *pRect,
|
||||
const wxString& text,
|
||||
COLORREF col,
|
||||
int flags)
|
||||
{
|
||||
wxTextColoursChanger changeFg(hdc, col, CLR_INVALID);
|
||||
wxBkModeChanger changeBkMode(hdc, wxBRUSHSTYLE_TRANSPARENT);
|
||||
|
||||
// center text horizontally in any case
|
||||
flags |= DT_CENTER;
|
||||
|
||||
@ -1393,12 +1454,31 @@ bool wxButton::MSWOnDraw(WXDRAWITEMSTRUCT *wxdis)
|
||||
? ::GetSysColor(COLOR_GRAYTEXT)
|
||||
: wxColourToRGB(GetForegroundColour());
|
||||
|
||||
wxTextColoursChanger changeFg(hdc, colFg, CLR_INVALID);
|
||||
wxBkModeChanger changeBkMode(hdc, wxBRUSHSTYLE_TRANSPARENT);
|
||||
|
||||
#if wxUSE_MARKUP
|
||||
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(), colFg,
|
||||
// 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;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user