X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/dbf858b5d69f53efd3950cae99322f54355aa983..0dd9646ea8b9e6f3a5fa8c42b6a4954cf8e3a48d:/include/wx/gtk/bmpbuttn.h diff --git a/include/wx/gtk/bmpbuttn.h b/include/wx/gtk/bmpbuttn.h index 380642dc6a..a8a396b8c5 100644 --- a/include/wx/gtk/bmpbuttn.h +++ b/include/wx/gtk/bmpbuttn.h @@ -1,71 +1,77 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: bmpbutton.h +// Name: wx/gtk/bmpbutton.h // Purpose: // Author: Robert Roebling // Id: $Id$ // Copyright: (c) 1998 Robert Roebling -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// +#ifndef _WX_GTK_BMPBUTTON_H_ +#define _WX_GTK_BMPBUTTON_H_ -#ifndef __BMPBUTTONH__ -#define __BMPBUTTONH__ +// ---------------------------------------------------------------------------- +// wxBitmapButton +// ---------------------------------------------------------------------------- -#ifdef __GNUG__ -#pragma interface -#endif +class WXDLLIMPEXP_CORE wxBitmapButton: public wxBitmapButtonBase +{ +public: + wxBitmapButton() { Init(); } -#include "wx/defs.h" -#include "wx/object.h" -#include "wx/list.h" -#include "wx/control.h" + wxBitmapButton(wxWindow *parent, + wxWindowID id, + const wxBitmap& bitmap, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = wxBU_AUTODRAW, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxButtonNameStr) + { + Init(); -//----------------------------------------------------------------------------- -// classes -//----------------------------------------------------------------------------- + Create(parent, id, bitmap, pos, size, style, validator, name); + } -class wxBitmapButton; + bool Create(wxWindow *parent, + wxWindowID id, + const wxBitmap& bitmap, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = wxBU_AUTODRAW, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxButtonNameStr); -//----------------------------------------------------------------------------- -// global data -//----------------------------------------------------------------------------- + void SetLabel( const wxString &label ); + virtual void SetLabel( const wxBitmap& bitmap ) { SetBitmapLabel(bitmap); } -extern const char *wxButtonNameStr; + virtual bool Enable(bool enable = true); -//----------------------------------------------------------------------------- -// wxBitmapButton -//----------------------------------------------------------------------------- + // implementation + // -------------- -class wxBitmapButton: public wxControl -{ - DECLARE_DYNAMIC_CLASS(wxBitmapButton) + void GTKMouseEnters(); + void GTKMouseLeaves(); + void GTKPressed(); + void GTKReleased(); - public: +protected: + virtual void OnSetBitmap(); + virtual wxSize DoGetBestSize() const; + void DoApplyWidgetStyle(GtkRcStyle *style); - wxBitmapButton(void); - inline wxBitmapButton(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxButtonNameStr) - { - Create(parent, id, bitmap, pos, size, style, validator, name); - } - bool Create(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxButtonNameStr); - void SetDefault(void); - void SetLabel( const wxString &label ); - wxString GetLabel(void) const; - virtual void SetLabel(const wxBitmap& bitmap) { SetBitmapLabel(bitmap); } - virtual void SetBitmapLabel( const wxBitmap& bitmap ); - wxBitmap& GetBitmapLabel(void) const { return (wxBitmap&) m_bitmap; } - - public: - - wxBitmap m_bitmap; - + void Init(); + +private: + void OnFocusChange(wxFocusEvent& event); + + // true iff mouse hovers over the button + bool m_mouseHovers; + // true iff the button is in pressed state + bool m_isPressed; + + DECLARE_DYNAMIC_CLASS(wxBitmapButton) + DECLARE_EVENT_TABLE() }; -#endif // __BMPBUTTONH__ + +#endif // _WX_GTK_BMPBUTTON_H_