Add new wxCommandLinkButton class.
A command link button wraps a native MSW control under recent Windows versions and is implemented generically as a simple bitmap button elsewhere. In the future, GTK implementation should allow using a different font for the button label and its note. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@65327 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -547,6 +547,14 @@
|
||||
# endif
|
||||
#endif /* !defined(wxUSE_COMBOBOX) */
|
||||
|
||||
#ifndef wxUSE_COMMANDLINKBUTTON
|
||||
# ifdef wxABORT_ON_CONFIG_ERROR
|
||||
# error "wxUSE_COMMANDLINKBUTTON must be defined, please read comment near the top of this file."
|
||||
# else
|
||||
# define wxUSE_COMMANDLINKBUTTON 0
|
||||
# endif
|
||||
#endif /* !defined(wxUSE_COMMANDLINKBUTTON) */
|
||||
|
||||
#ifndef wxUSE_COMBOCTRL
|
||||
# ifdef wxABORT_ON_CONFIG_ERROR
|
||||
# error "wxUSE_COMBOCTRL must be defined, please read comment near the top of this file."
|
||||
@@ -1425,6 +1433,17 @@
|
||||
# endif
|
||||
#endif /* wxUSE_BMPBUTTON */
|
||||
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
# if !wxUSE_BUTTON
|
||||
# ifdef wxABORT_ON_CONFIG_ERROR
|
||||
# error "wxUSE_COMMANDLINKBUTTON requires wxUSE_BUTTON"
|
||||
# else
|
||||
# undef wxUSE_BUTTON
|
||||
# define wxUSE_BUTTON 1
|
||||
# endif
|
||||
# endif
|
||||
#endif /* wxUSE_COMMANDLINKBUTTON */
|
||||
|
||||
/*
|
||||
wxUSE_BOOKCTRL should be only used if any of the controls deriving from it
|
||||
are used
|
||||
|
168
include/wx/commandlinkbutton.h
Normal file
168
include/wx/commandlinkbutton.h
Normal file
@@ -0,0 +1,168 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/commandlinkbutton.h
|
||||
// Purpose: wxCommandLinkButtonBase and wxGenericCommandLinkButton classes
|
||||
// Author: Rickard Westerlund
|
||||
// Created: 2010-06-11
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2010 wxWidgets team
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_COMMANDLINKBUTTON_H_
|
||||
#define _WX_COMMANDLINKBUTTON_H_
|
||||
|
||||
#include "wx/defs.h"
|
||||
|
||||
#if wxUSE_COMMANDLINKBUTTON
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// Command link button common base class
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// This class has separate "main label" (title-like string) and (possibly
|
||||
// multiline) "note" which can be set and queried separately but can also be
|
||||
// set both at once by joining them with a new line and setting them as a
|
||||
// label and queried by breaking the label into the parts before the first new
|
||||
// line and after it.
|
||||
|
||||
class WXDLLIMPEXP_ADV wxCommandLinkButtonBase : public wxButton
|
||||
{
|
||||
public:
|
||||
wxCommandLinkButtonBase() : wxButton() { }
|
||||
|
||||
wxCommandLinkButtonBase(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator =
|
||||
wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr)
|
||||
: wxButton(parent,
|
||||
id,
|
||||
mainLabel + '\n' + note,
|
||||
pos,
|
||||
size,
|
||||
style,
|
||||
validator,
|
||||
name)
|
||||
{ }
|
||||
|
||||
virtual void SetMainLabelAndNote(const wxString& mainLabel,
|
||||
const wxString& note) = 0;
|
||||
|
||||
virtual void SetMainLabel(const wxString& mainLabel)
|
||||
{
|
||||
SetMainLabelAndNote(mainLabel, GetNote());
|
||||
}
|
||||
|
||||
virtual void SetNote(const wxString& note)
|
||||
{
|
||||
SetMainLabelAndNote(GetMainLabel(), note);
|
||||
}
|
||||
|
||||
virtual wxString GetMainLabel() const
|
||||
{
|
||||
return GetLabel().BeforeFirst('\n');
|
||||
}
|
||||
|
||||
virtual wxString GetNote() const
|
||||
{
|
||||
return GetLabel().AfterFirst('\n');
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual bool HasNativeBitmap() const { return false; }
|
||||
|
||||
private:
|
||||
wxDECLARE_NO_COPY_CLASS(wxCommandLinkButtonBase);
|
||||
};
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// Generic command link button
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// Trivial generic implementation simply using a multiline label to show both
|
||||
// the main label and the note.
|
||||
|
||||
class WXDLLIMPEXP_ADV wxGenericCommandLinkButton
|
||||
: public wxCommandLinkButtonBase
|
||||
{
|
||||
public:
|
||||
wxGenericCommandLinkButton() : wxCommandLinkButtonBase() { }
|
||||
|
||||
|
||||
wxGenericCommandLinkButton(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator = wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr)
|
||||
: wxCommandLinkButtonBase()
|
||||
{
|
||||
Create(parent, id, mainLabel, note, pos, size, style, validator, name);
|
||||
}
|
||||
|
||||
bool Create(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator = wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr);
|
||||
|
||||
virtual void SetMainLabelAndNote(const wxString& mainLabel,
|
||||
const wxString& note)
|
||||
{
|
||||
wxButton::SetLabel(mainLabel + '\n' + note);
|
||||
}
|
||||
|
||||
private:
|
||||
void SetDefaultBitmap();
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxGenericCommandLinkButton);
|
||||
};
|
||||
|
||||
#if defined(__WXMSW__)
|
||||
#include "wx/msw/commandlinkbutton.h"
|
||||
#else
|
||||
class WXDLLIMPEXP_ADV wxCommandLinkButton : public wxGenericCommandLinkButton
|
||||
{
|
||||
public:
|
||||
wxCommandLinkButton() : wxGenericCommandLinkButton() { }
|
||||
|
||||
wxCommandLinkButton(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator = wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr)
|
||||
: wxGenericCommandLinkButton(parent,
|
||||
id,
|
||||
mainLabel,
|
||||
note,
|
||||
pos,
|
||||
size,
|
||||
style,
|
||||
validator,
|
||||
name)
|
||||
{ }
|
||||
|
||||
private:
|
||||
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxCommandLinkButton);
|
||||
};
|
||||
#endif // __WXMSW__/!__WXMSW__
|
||||
|
||||
#endif // wxUSE_COMMANDLINKBUTTON
|
||||
|
||||
#endif // _WX_COMMANDLINKBUTTON_H_
|
@@ -736,6 +736,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -88,13 +88,17 @@ protected:
|
||||
virtual void DoSetBitmapMargins(wxCoord x, wxCoord y);
|
||||
virtual void DoSetBitmapPosition(wxDirection dir);
|
||||
|
||||
// Increases the passed in size if necessary to account for the
|
||||
// button image, if any
|
||||
void AdjustForBitmapSize(wxSize& size) const;
|
||||
|
||||
class wxButtonImageData *m_imageData;
|
||||
|
||||
// true if the UAC symbol is shown
|
||||
bool m_authNeeded;
|
||||
|
||||
private:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxButton)
|
||||
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxButton);
|
||||
};
|
||||
|
||||
#endif // _WX_BUTTON_H_
|
||||
|
74
include/wx/msw/commandlinkbutton.h
Normal file
74
include/wx/msw/commandlinkbutton.h
Normal file
@@ -0,0 +1,74 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/msw/commandlinkbutton.h
|
||||
// Purpose: wxCommandLinkButton class
|
||||
// Author: Rickard Westerlund
|
||||
// Created: 2010-06-11
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2010 wxWidgets team
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_MSW_COMMANDLINKBUTTON_H_
|
||||
#define _WX_MSW_COMMANDLINKBUTTON_H_
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// Command link button for wxMSW
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// Derive from the generic version to be able to fall back to it during
|
||||
// run-time if the command link buttons are not supported by the system we're
|
||||
// running under.
|
||||
|
||||
class WXDLLIMPEXP_ADV wxCommandLinkButton : public wxGenericCommandLinkButton
|
||||
{
|
||||
public:
|
||||
wxCommandLinkButton () : wxGenericCommandLinkButton() { }
|
||||
|
||||
wxCommandLinkButton(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator = wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr)
|
||||
: wxGenericCommandLinkButton()
|
||||
{
|
||||
Create(parent, id, mainLabel, note, pos, size, style, validator, name);
|
||||
}
|
||||
|
||||
bool Create(wxWindow *parent,
|
||||
wxWindowID id,
|
||||
const wxString& mainLabel = wxEmptyString,
|
||||
const wxString& note = wxEmptyString,
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = 0,
|
||||
const wxValidator& validator = wxDefaultValidator,
|
||||
const wxString& name = wxButtonNameStr);
|
||||
|
||||
// overridden base class methods
|
||||
// -----------------------------
|
||||
|
||||
// do the same thing as in the generic case here
|
||||
virtual void SetLabel(const wxString& label)
|
||||
{
|
||||
SetMainLabelAndNote(label.BeforeFirst('\n'), label.AfterFirst('\n'));
|
||||
}
|
||||
|
||||
virtual void SetMainLabelAndNote(const wxString& mainLabel,
|
||||
const wxString& note);
|
||||
|
||||
virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
|
||||
|
||||
protected:
|
||||
virtual wxSize DoGetBestSize() const;
|
||||
|
||||
virtual bool HasNativeBitmap() const;
|
||||
|
||||
private:
|
||||
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxCommandLinkButton);
|
||||
};
|
||||
|
||||
#endif // _WX_MSW_COMMANDLINKBUTTON_H_
|
@@ -736,6 +736,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -736,6 +736,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -736,6 +736,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -737,6 +737,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -736,6 +736,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -732,6 +732,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
@@ -735,6 +735,7 @@
|
||||
#define wxUSE_COLLPANE 1 // wxCollapsiblePane
|
||||
#define wxUSE_COLOURPICKERCTRL 1 // wxColourPickerCtrl
|
||||
#define wxUSE_COMBOBOX 1 // wxComboBox
|
||||
#define wxUSE_COMMANDLINKBUTTON 1 // wxCommandLinkButton
|
||||
#define wxUSE_DATAVIEWCTRL 1 // wxDataViewCtrl
|
||||
#define wxUSE_DATEPICKCTRL 1 // wxDatePickerCtrl
|
||||
#define wxUSE_DIRPICKERCTRL 1 // wxDirPickerCtrl
|
||||
|
Reference in New Issue
Block a user