#pragma hdrstop
#endif
+#if wxUSE_SLIDER
+
// for all others, include the necessary headers
#ifndef WX_PRECOMP
#include "wx/log.h"
#include "wx/sizer.h"
#include "widgets.h"
-#if wxUSE_SLIDER
+
#include "icons/slider.xpm"
// ----------------------------------------------------------------------------
// sides radiobox values
enum
{
- StaticSides_Top,
- StaticSides_Bottom,
- StaticSides_Left,
- StaticSides_Right
+ SliderTicks_Top,
+ SliderTicks_Bottom,
+ SliderTicks_Left,
+ SliderTicks_Right
};
// ----------------------------------------------------------------------------
class SliderWidgetsPage : public WidgetsPage
{
public:
- SliderWidgetsPage(wxNotebook *notebook, wxImageList *imaglist);
- virtual ~SliderWidgetsPage();
+ SliderWidgetsPage(wxBookCtrlBase *book, wxImageList *imaglist);
+ virtual ~SliderWidgetsPage(){};
+
+ virtual wxControl *GetWidget() const { return m_slider; }
protected:
// event handlers
// the check/radio boxes for styles
wxCheckBox *m_chkLabels,
- *m_chkVert,
+ *m_chkInverse,
*m_chkTicks,
*m_chkBothSides;
IMPLEMENT_WIDGETS_PAGE(SliderWidgetsPage, _T("Slider"));
-SliderWidgetsPage::SliderWidgetsPage(wxNotebook *notebook,
- wxImageList *imaglist)
- : WidgetsPage(notebook)
+SliderWidgetsPage::SliderWidgetsPage(wxBookCtrlBase *book,
+ wxImageList *imaglist)
+ : WidgetsPage(book)
{
imaglist->Add(wxBitmap(slider_xpm));
m_min = 0;
m_max = 100;
- m_chkVert =
+ m_chkInverse =
m_chkTicks =
m_chkLabels =
m_chkBothSides = (wxCheckBox *)NULL;
wxStaticBox *box = new wxStaticBox(this, wxID_ANY, _T("&Set style"));
wxSizer *sizerLeft = new wxStaticBoxSizer(box, wxVERTICAL);
- m_chkVert = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Vertical"));
+ m_chkInverse = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Inverse"));
m_chkTicks = CreateCheckBoxAndAddToSizer(sizerLeft, _T("Show &ticks"));
m_chkLabels = CreateCheckBoxAndAddToSizer(sizerLeft, _T("Show &labels"));
static const wxString sides[] =
sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5);
sizerRow = CreateSizerWithTextAndButton(SliderPage_SetThumbLen,
- _T("Thumb &lenght"),
+ _T("Thumb &length"),
SliderPage_ThumbLenText,
&m_textThumbLen);
sizerTop->Fit(this);
}
-SliderWidgetsPage::~SliderWidgetsPage()
-{
-}
-
// ----------------------------------------------------------------------------
// operations
// ----------------------------------------------------------------------------
void SliderWidgetsPage::Reset()
{
- m_chkVert->SetValue(false);
+ m_chkInverse->SetValue(false);
m_chkTicks->SetValue(true);
m_chkLabels->SetValue(true);
m_chkBothSides->SetValue(false);
- m_radioSides->SetSelection(StaticSides_Top);
+ m_radioSides->SetSelection(SliderTicks_Top);
}
void SliderWidgetsPage::CreateSlider()
{
int flags = 0;
- bool isVert = m_chkVert->GetValue();
- if ( isVert )
- flags |= wxSL_VERTICAL;
- else
- flags |= wxSL_HORIZONTAL;
+ if ( m_chkInverse->GetValue() )
+ {
+ flags |= wxSL_INVERSE;
+ }
if ( m_chkLabels->GetValue() )
{
switch ( m_radioSides->GetSelection() )
{
- case StaticSides_Top:
+ case SliderTicks_Top:
flags |= wxSL_TOP;
break;
- case StaticSides_Left:
+
+ case SliderTicks_Left:
flags |= wxSL_LEFT;
break;
- case StaticSides_Bottom:
+
+ case SliderTicks_Bottom:
flags |= wxSL_BOTTOM;
break;
- case StaticSides_Right:
+
+ case SliderTicks_Right:
flags |= wxSL_RIGHT;
break;
+
default:
wxFAIL_MSG(_T("unexpected radiobox selection"));
// fall through
wxDefaultPosition, wxDefaultSize,
flags);
- if ( isVert )
+ if ( m_slider->HasFlag(wxSL_VERTICAL) )
{
m_sizerSlider->Add(0, 0, 1);
m_sizerSlider->Add(m_slider, 0, wxGROW | wxALL, 5);
long len;
if ( !m_textThumbLen->GetValue().ToLong(&len) )
{
- wxLogWarning(_T("Invalid slider thumb lenght"));
+ wxLogWarning(_T("Invalid slider thumb length"));
return;
}
m_max = maxNew;
m_slider->SetRange(minNew, maxNew);
+
+ if ( m_slider->GetMin() != m_min ||
+ m_slider->GetMax() != m_max )
+ {
+ wxLogWarning(_T("Invalid range in slider."));
+ }
}
void SliderWidgetsPage::OnButtonSetValue(wxCommandEvent& WXUNUSED(event))
void SliderWidgetsPage::OnUpdateUIResetButton(wxUpdateUIEvent& event)
{
- event.Enable( m_chkVert->GetValue() ||
+ event.Enable( m_chkInverse->GetValue() ||
!m_chkTicks->GetValue() ||
!m_chkLabels->GetValue() ||
- m_chkBothSides->GetValue() );
+ m_chkBothSides->GetValue() ||
+ m_radioSides->GetSelection() != SliderTicks_Top );
}
void SliderWidgetsPage::OnCheckOrRadioBox(wxCommandEvent& WXUNUSED(event))
void SliderWidgetsPage::OnUpdateUIBothSides(wxUpdateUIEvent& event)
{
-#if defined(__WIN95__) || defined(__WXUNIVERSAL__)
+#if defined(__WXMSW__) || defined(__WXUNIVERSAL__)
event.Enable( m_chkTicks->GetValue() );
#else
event.Enable( false );
-#endif // defined(__WIN95__) || defined(__WXUNIVERSAL__)
+#endif // defined(__WXMSW__) || defined(__WXUNIVERSAL__)
}
void SliderWidgetsPage::OnSlider(wxScrollEvent& event)
wxT("wxEVT_SCROLL_PAGEDOWN"),
wxT("wxEVT_SCROLL_THUMBTRACK"),
wxT("wxEVT_SCROLL_THUMBRELEASE"),
- wxT("wxEVT_SCROLL_ENDSCROLL")
+ wxT("wxEVT_SCROLL_CHANGED")
};
int index = eventType - wxEVT_SCROLL_TOP;
static int s_numSliderEvents = 0;
- wxLogMessage(wxT("Slider event #%d: %s (pos = %d)"),
+ wxLogMessage(wxT("Slider event #%d: %s (pos = %d, int value = %ld)"),
s_numSliderEvents++,
eventNames[index],
- event.GetPosition());
+ event.GetPosition(),
+ event.GetInt());
}
-#endif
- // wxUSE_SLIDER
+#endif // wxUSE_SLIDER