// Created: 29.01.01
// RCS-ID: $Id$
// Copyright: (c) 2001 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
-// License: wxWindows license
+// License: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
// ============================================================================
// headers
// ----------------------------------------------------------------------------
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "spinctlg.h"
#endif
#pragma hdrstop
#endif
-#if !(defined(__WXMSW__) || defined(__WXGTK__) || defined(__WXPM__)) || defined(__WXMAC__) || \
- defined(__WXUNIVERSAL__)
+#if !(defined(__WXMSW__) || defined(__WXGTK__) || defined(__WXPM__)) || \
+ defined(__WXMAC__) || defined(__WXUNIVERSAL__)
#ifndef WX_PRECOMP
#include "wx/textctrl.h"
protected:
void OnSpinButton(wxSpinEvent& eventSpin)
{
-#ifdef __WXMAC__
- m_spin->SetTextValue(eventSpin.GetPosition());
+ m_spin->SetTextValue(eventSpin.GetPosition());
- wxCommandEvent event(wxEVT_COMMAND_SPINCTRL_UPDATED, m_spin->GetId());
- event.SetEventObject(m_spin);
- event.SetInt(eventSpin.GetPosition());
+ wxCommandEvent event(wxEVT_COMMAND_SPINCTRL_UPDATED, m_spin->GetId());
+ event.SetEventObject(m_spin);
+ event.SetInt(eventSpin.GetPosition());
+
+ m_spin->GetEventHandler()->ProcessEvent(event);
- m_spin->GetEventHandler()->ProcessEvent(event);
-#else
- m_spin->SetTextValue(eventSpin.GetPosition());
eventSpin.Skip();
-#endif
}
private:
}
DoSetSize(pos.x, pos.y, csize.x, csize.y);
#else
- DoSetSize(pos.x, pos.y, size.x, size.y);
+ wxSize best = GetBestSize();
+ if ( size.x != -1 ) best.x = size.x;
+ if ( size.y != -1 ) best.y = size.y;
+ DoSetSize(pos.x, pos.y, best.x, best.y);
#endif
// have to disable this window to avoid interfering it with message
// processing to the text and the button... but pretend it is enabled to
// geometry
// ----------------------------------------------------------------------------
-wxSize wxSpinCtrl::DoGetBestClientSize() const
+wxSize wxSpinCtrl::DoGetBestSize() const
{
wxSize sizeBtn = m_btn->GetBestSize(),
sizeText = m_text->GetBestSize();
{
wxControl::DoMoveWindow(x, y, width, height);
- wxPoint p = GetParent() ?
- GetParent()->GetClientAreaOrigin() : wxPoint(0,0);
-
// position the subcontrols inside the client area
wxSize sizeBtn = m_btn->GetSize();
wxCoord wText = width - sizeBtn.x;
- m_text->SetSize(x-p.x, y-p.y, wText, height);
+ m_text->SetSize(x, y, wText, height);
#ifdef __WXMAC__
- m_btn->SetSize(x-p.x + wText + MARGIN, y-p.y, -1, -1);
+ m_btn->SetSize(x + wText + MARGIN, y, -1, -1);
#else
- m_btn->SetSize(x-p.x + wText + MARGIN, y-p.y, -1, height);
+ m_btn->SetSize(x + wText + MARGIN, y, -1, height);
#endif
}
m_text->SetSelection(0, -1);
// and give focus to the control!
- m_text->SetFocus();
+ // m_text->SetFocus(); Why???? TODO.
}
void wxSpinCtrl::SetValue(int val)
m_btn->SetRange(min, max);
}
+void wxSpinCtrl::SetSelection(long from, long to)
+{
+ wxCHECK_RET( m_text, _T("invalid call to wxSpinCtrl::SetSelection") );
+
+ m_text->SetSelection(from, to);
+}
+
#endif // wxUSE_SPINCTRL
#endif // !wxPort-with-native-spinctrl