X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/acbeb7b368483cba589ffac08906367af911d4e2..6033bbc1ff95fb69b65b081d03b4a679dd958e75:/include/wx/gtk1/tglbtn.h diff --git a/include/wx/gtk1/tglbtn.h b/include/wx/gtk1/tglbtn.h index f3ddd49404..7da1777c18 100644 --- a/include/wx/gtk1/tglbtn.h +++ b/include/wx/gtk1/tglbtn.h @@ -13,11 +13,14 @@ #ifndef _WX_GTK_TOGGLEBUTTON_H_ #define _WX_GTK_TOGGLEBUTTON_H_ +#include "wx/bitmap.h" + //----------------------------------------------------------------------------- // classes //----------------------------------------------------------------------------- class wxToggleButton; +class wxToggleBitmapButton; //----------------------------------------------------------------------------- // global data @@ -25,6 +28,62 @@ class wxToggleButton; extern const wxChar *wxCheckBoxNameStr; +//----------------------------------------------------------------------------- +// wxToggleBitmapButton +//----------------------------------------------------------------------------- + +class wxToggleBitmapButton: public wxControl +{ +public: + // construction/destruction + wxToggleBitmapButton() {} + wxToggleBitmapButton(wxWindow *parent, + wxWindowID id, + const wxBitmap& label, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxCheckBoxNameStr) + { + Create(parent, id, label, pos, size, style, validator, name); + } + + // Create the control + bool Create(wxWindow *parent, + wxWindowID id, + const wxBitmap& label, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxCheckBoxNameStr); + + // Get/set the value + void SetValue(bool state); + bool GetValue() const; + + // Set the label + void SetLabel(const wxBitmap& label); + bool Enable(bool enable = TRUE); + + static wxVisualAttributes + GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL); + + // implementation + bool m_blockEvent; + wxBitmap m_bitmap; + + void OnSetBitmap(); + void ApplyWidgetStyle(); + bool IsOwnGtkWindow(GdkWindow *window); + + virtual void OnInternalIdle(); + virtual wxSize DoGetBestSize() const; + +private: + DECLARE_DYNAMIC_CLASS(wxToggleBitmapButton) +}; + //----------------------------------------------------------------------------- // wxToggleButton //----------------------------------------------------------------------------- @@ -63,6 +122,8 @@ public: void SetLabel(const wxString& label); bool Enable(bool enable = TRUE); + static wxVisualAttributes + GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL); // implementation bool m_blockEvent;