X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8907154c1a8a6882c6797d1f16393ddfb23e7f3a..d43803715268f5396741b3f0eb4b94d1408c9f9d:/src/univ/button.cpp diff --git a/src/univ/button.cpp b/src/univ/button.cpp index f41f45b6e6..7bda74e449 100644 --- a/src/univ/button.cpp +++ b/src/univ/button.cpp @@ -39,6 +39,34 @@ #include "wx/univ/colschem.h" #include "wx/stockitem.h" +// ---------------------------------------------------------------------------- +// wxStdButtonInputHandler: translates SPACE and ENTER keys and the left mouse +// click into button press/release actions +// ---------------------------------------------------------------------------- + +class WXDLLEXPORT wxStdButtonInputHandler : public wxStdInputHandler +{ +public: + wxStdButtonInputHandler(wxInputHandler *inphand); + + virtual bool HandleKey(wxInputConsumer *consumer, + const wxKeyEvent& event, + bool pressed); + virtual bool HandleMouse(wxInputConsumer *consumer, + const wxMouseEvent& event); + virtual bool HandleMouseMove(wxInputConsumer *consumer, + const wxMouseEvent& event); + virtual bool HandleFocus(wxInputConsumer *consumer, + const wxFocusEvent& event); + virtual bool HandleActivation(wxInputConsumer *consumer, bool activated); + +private: + // the window (button) which has capture or NULL and the flag telling if + // the mouse is inside the button which captured it or not + wxWindow *m_winCapture; + bool m_winHasMouse; +}; + // ---------------------------------------------------------------------------- // constants // ---------------------------------------------------------------------------- @@ -78,9 +106,7 @@ bool wxButton::Create(wxWindow *parent, label = wxGetStockLabel(id); long ctrl_style = style & ~wxBU_ALIGN_MASK; - - wxASSERT_MSG( (ctrl_style & wxALIGN_MASK) == 0, - _T("Some style conflicts with align flags") ); + ctrl_style = ctrl_style & ~wxALIGN_MASK; if((style & wxBU_RIGHT) == wxBU_RIGHT) ctrl_style |= wxALIGN_RIGHT; @@ -100,8 +126,11 @@ bool wxButton::Create(wxWindow *parent, return false; SetLabel(label); - SetImageLabel(bitmap); - // SetBestSize(size); -- called by SetImageLabel() + + if (bitmap.Ok()) + SetImageLabel(bitmap); // SetInitialSize called by SetImageLabel() + else + SetInitialSize(size); CreateInputHandler(wxINP_HANDLER_BUTTON); @@ -274,6 +303,14 @@ bool wxButton::PerformAction(const wxControlAction& action, return true; } +/* static */ +wxInputHandler *wxButton::GetStdInputHandler(wxInputHandler *handlerDef) +{ + static wxStdButtonInputHandler s_handlerBtn(handlerDef); + + return &s_handlerBtn; +} + // ---------------------------------------------------------------------------- // misc // ---------------------------------------------------------------------------- @@ -290,12 +327,14 @@ void wxButton::SetImageMargins(wxCoord x, wxCoord y) m_marginBmpX = x + 2; m_marginBmpY = y + 2; - SetBestSize(wxDefaultSize); + SetInitialSize(wxDefaultSize); } -void wxButton::SetDefault() +wxWindow *wxButton::SetDefault() { m_isDefault = true; + + return wxButtonBase::SetDefault(); } // ============================================================================