]> git.saurik.com Git - wxWidgets.git/commitdiff
wxToggleButton page added to widgets sample.
authorWłodzimierz Skiba <abx@abx.art.pl>
Wed, 24 May 2006 14:56:15 +0000 (14:56 +0000)
committerWłodzimierz Skiba <abx@abx.art.pl>
Wed, 24 May 2006 14:56:15 +0000 (14:56 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@39317 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

samples/widgets/Makefile.in
samples/widgets/icons/toggle.xpm [new file with mode: 0644]
samples/widgets/makefile.bcc
samples/widgets/makefile.gcc
samples/widgets/makefile.vc
samples/widgets/makefile.wat
samples/widgets/toggle.cpp [new file with mode: 0644]
samples/widgets/widgets.bkl
samples/widgets/widgets.dsp

index 6398cbcb278e356f19cb3fdd2ca1707f08381a0b..336f16422f8836681e6b0ec7f0c3e2809e87a1c5 100644 (file)
@@ -59,6 +59,7 @@ WIDGETS_OBJECTS =  \
        widgets_spinbtn.o \
        widgets_static.o \
        widgets_textctrl.o \
+       widgets_toggle.o \
        widgets_widgets.o \
        $(__widgets___win32rc)
 
@@ -235,6 +236,9 @@ widgets_static.o: $(srcdir)/static.cpp
 widgets_textctrl.o: $(srcdir)/textctrl.cpp
        $(CXXC) -c -o $@ $(WIDGETS_CXXFLAGS) $(srcdir)/textctrl.cpp
 
+widgets_toggle.o: $(srcdir)/toggle.cpp
+       $(CXXC) -c -o $@ $(WIDGETS_CXXFLAGS) $(srcdir)/toggle.cpp
+
 widgets_widgets.o: $(srcdir)/widgets.cpp
        $(CXXC) -c -o $@ $(WIDGETS_CXXFLAGS) $(srcdir)/widgets.cpp
 
diff --git a/samples/widgets/icons/toggle.xpm b/samples/widgets/icons/toggle.xpm
new file mode 100644 (file)
index 0000000..4b9bcd3
--- /dev/null
@@ -0,0 +1,54 @@
+/* XPM */\r
+static char *toggle_xpm[] = {\r
+/* columns rows colors chars-per-pixel */\r
+"32 32 16 1",\r
+"  c Gray0",\r
+". c #808000",\r
+"X c #000080",\r
+"o c #c0c0c0",\r
+"O c #000000",\r
+"+ c #808000",\r
+"@ c #000080",\r
+"# c none",\r
+"$ c #808080",\r
+"% c Red",\r
+"& c Green",\r
+"* c Yellow",\r
+"= c Blue",\r
+"- c Magenta",\r
+"; c Cyan",\r
+": c Gray100",\r
+/* pixels */\r
+"################################",\r
+"####              ##############",\r
+"### :::::::::::::: #############",\r
+"## :::::::::::::::$ ############",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"# ::oooooooooooooo$$ ###########",\r
+"## $$$$$$$$$$$$$$$$ ############",\r
+"### $$$$$$$$$$$$$$ #############",\r
+"####              ##############",\r
+"################################",\r
+"################################",\r
+"##############              ####",\r
+"############# $$$$$$$$$$$$$$ ###",\r
+"############ $$$$$$$$$$$$$$$: ##",\r
+"########### $$:o:o:o:o:o:o:o:: #",\r
+"########### $$o:o:o:o:o:o:o::: #",\r
+"########### $$:o:o:o:o:o:o:o:: #",\r
+"########### $$o:o:o:o:o:o:o::: #",\r
+"########### $$:o:o:o:o:o:o:o:: #",\r
+"########### $$o:o:o:o:o:o:o::: #",\r
+"########### $$:o:o:o:o:o:o:o:: #",\r
+"########### $$o:o:o:o:o:o:o::: #",\r
+"############ :::::::::::::::: ##",\r
+"############# :::::::::::::: ###",\r
+"##############              ####",\r
+"################################"\r
+};\r
index f8742ac09efd5a969371a9e773070ff5b3eabdea..ccfc6c6643029f781dce83f4b517c6a4e3f4802e 100644 (file)
@@ -46,6 +46,7 @@ WIDGETS_OBJECTS =  \
        $(OBJS)\widgets_spinbtn.obj \
        $(OBJS)\widgets_static.obj \
        $(OBJS)\widgets_textctrl.obj \
+       $(OBJS)\widgets_toggle.obj \
        $(OBJS)\widgets_widgets.obj
 
 ### Conditionally set variables: ###
@@ -273,6 +274,9 @@ $(OBJS)\widgets_static.obj: .\static.cpp
 $(OBJS)\widgets_textctrl.obj: .\textctrl.cpp
        $(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
 
+$(OBJS)\widgets_toggle.obj: .\toggle.cpp
+       $(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
+
 $(OBJS)\widgets_widgets.obj: .\widgets.cpp
        $(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
 
index 0b70216fa92c2bbd798f58d628345da670a53e78..40e91ab6b2048277dbef81117b38af0bc36dc739 100644 (file)
@@ -39,6 +39,7 @@ WIDGETS_OBJECTS =  \
        $(OBJS)\widgets_spinbtn.o \
        $(OBJS)\widgets_static.o \
        $(OBJS)\widgets_textctrl.o \
+       $(OBJS)\widgets_toggle.o \
        $(OBJS)\widgets_widgets.o \
        $(OBJS)\widgets_sample_rc.o
 
@@ -266,6 +267,9 @@ $(OBJS)\widgets_static.o: ./static.cpp
 $(OBJS)\widgets_textctrl.o: ./textctrl.cpp
        $(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
 
+$(OBJS)\widgets_toggle.o: ./toggle.cpp
+       $(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
+
 $(OBJS)\widgets_widgets.o: ./widgets.cpp
        $(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
 
index fb186dc7aa966f52e8e428fc81f8dd06bff34b29..421d7223aec6b4a5e8e2ae70d5f34bdb5438aa29 100644 (file)
@@ -39,6 +39,7 @@ WIDGETS_OBJECTS =  \
        $(OBJS)\widgets_spinbtn.obj \
        $(OBJS)\widgets_static.obj \
        $(OBJS)\widgets_textctrl.obj \
+       $(OBJS)\widgets_toggle.obj \
        $(OBJS)\widgets_widgets.obj \
        $(OBJS)\widgets_sample.res
 
@@ -348,6 +349,9 @@ $(OBJS)\widgets_static.obj: .\static.cpp
 $(OBJS)\widgets_textctrl.obj: .\textctrl.cpp
        $(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
 
+$(OBJS)\widgets_toggle.obj: .\toggle.cpp
+       $(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
+
 $(OBJS)\widgets_widgets.obj: .\widgets.cpp
        $(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
 
index e346b7db877b08a63f1b367e9a58a26b55f30097..20615ff4f1b55c31f7f52c38b85517bbee32490d 100644 (file)
@@ -236,6 +236,7 @@ WIDGETS_OBJECTS =  &
        $(OBJS)\widgets_spinbtn.obj &
        $(OBJS)\widgets_static.obj &
        $(OBJS)\widgets_textctrl.obj &
+       $(OBJS)\widgets_toggle.obj &
        $(OBJS)\widgets_widgets.obj
 
 
@@ -303,6 +304,9 @@ $(OBJS)\widgets_static.obj :  .AUTODEPEND .\static.cpp
 $(OBJS)\widgets_textctrl.obj :  .AUTODEPEND .\textctrl.cpp
        $(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
 
+$(OBJS)\widgets_toggle.obj :  .AUTODEPEND .\toggle.cpp
+       $(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
+
 $(OBJS)\widgets_widgets.obj :  .AUTODEPEND .\widgets.cpp
        $(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
 
diff --git a/samples/widgets/toggle.cpp b/samples/widgets/toggle.cpp
new file mode 100644 (file)
index 0000000..626bc0c
--- /dev/null
@@ -0,0 +1,207 @@
+/////////////////////////////////////////////////////////////////////////////
+// Program:     wxWidgets Widgets Sample
+// Name:        toggle.cpp
+// Purpose:     Part of the widgets sample showing toggle control
+// Author:      Dimitri Schoolwerth, Vadim Zeitlin
+// Created:     27 Sep 2003
+// Id:          $Id$
+// Copyright:   (c) 2006 Wlodzmierz Skiba
+// License:     wxWindows license
+/////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// declarations
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
+
+// for compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+    #pragma hdrstop
+#endif
+
+#if wxUSE_TOGGLEBTN
+
+#include "wx/tglbtn.h"
+
+#include "widgets.h"
+
+// for all others, include the necessary headers
+#ifndef WX_PRECOMP
+    #include "wx/sizer.h"
+    #include "wx/statbox.h"
+#endif
+
+#include "icons/toggle.xpm"
+
+// ----------------------------------------------------------------------------
+// constants
+// ----------------------------------------------------------------------------
+
+// control ids
+enum
+{
+    TogglePage_Reset = wxID_HIGHEST,
+    TogglePage_ChangeLabel,
+    TogglePage_Picker
+};
+
+// ----------------------------------------------------------------------------
+// CheckBoxWidgetsPage
+// ----------------------------------------------------------------------------
+
+class ToggleWidgetsPage : public WidgetsPage
+{
+public:
+    ToggleWidgetsPage(WidgetsBookCtrl *book, wxImageList *imaglist);
+    virtual ~ToggleWidgetsPage(){};
+
+    virtual wxControl *GetWidget() const { return m_toggle; }
+    virtual void RecreateWidget() { CreateToggle(); }
+
+protected:
+    // event handlers
+    void OnButtonReset(wxCommandEvent& event);
+    void OnButtonChangeLabel(wxCommandEvent& event);
+
+    // reset the toggle parameters
+    void Reset();
+
+    // (re)create the toggle
+    void CreateToggle();
+
+    // the controls
+    // ------------
+
+    // the checkbox itself and the sizer it is in
+    wxToggleButton *m_toggle;
+    wxSizer *m_sizerToggle;
+
+    // the text entries for command parameters
+    wxTextCtrl *m_textLabel;
+
+private:
+    DECLARE_EVENT_TABLE()
+    DECLARE_WIDGETS_PAGE(ToggleWidgetsPage)
+};
+
+// ----------------------------------------------------------------------------
+// event tables
+// ----------------------------------------------------------------------------
+
+BEGIN_EVENT_TABLE(ToggleWidgetsPage, WidgetsPage)
+    EVT_BUTTON(TogglePage_Reset, ToggleWidgetsPage::OnButtonReset)
+    EVT_BUTTON(TogglePage_ChangeLabel, ToggleWidgetsPage::OnButtonChangeLabel)
+END_EVENT_TABLE()
+
+// ============================================================================
+// implementation
+// ============================================================================
+
+#if defined(__WXUNIVERSAL__)
+    #define FAMILY_CTRLS UNIVERSAL_CTRLS
+#else
+    #define FAMILY_CTRLS NATIVE_CTRLS
+#endif
+
+IMPLEMENT_WIDGETS_PAGE(ToggleWidgetsPage, wxT("ToggleButton"),
+                       FAMILY_CTRLS
+                       );
+
+ToggleWidgetsPage::ToggleWidgetsPage(WidgetsBookCtrl *book,
+                                     wxImageList *imaglist)
+                      :WidgetsPage(book)
+{
+    imaglist->Add(wxBitmap(toggle_xpm));
+
+    wxSizer *sizerTop = new wxBoxSizer(wxHORIZONTAL);
+
+    // left pane
+//    wxStaticBox *box = new wxStaticBox(this, wxID_ANY, wxT("Styles"));
+
+//    wxSizer *sizerLeft = new wxStaticBoxSizer(box, wxVERTICAL);
+
+    // middle pane
+    wxStaticBox *box2 = new wxStaticBox(this, wxID_ANY, _T("&Operations"));
+    wxSizer *sizerMiddle = new wxStaticBoxSizer(box2, wxVERTICAL);
+
+    wxSizer *sizerRow = CreateSizerWithTextAndButton(TogglePage_ChangeLabel,
+                                                     _T("Change label"),
+                                                     wxID_ANY,
+                                                     &m_textLabel);
+    m_textLabel->SetValue(_T("&Toggle me!"));
+
+    sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5);
+
+    // right pane
+    wxSizer *sizerRight = new wxBoxSizer(wxHORIZONTAL);
+
+    m_toggle = new wxToggleButton(this, TogglePage_Picker, wxT("Toggle Button"));
+
+    sizerRight->Add(0, 0, 1, wxCENTRE);
+    sizerRight->Add(m_toggle, 1, wxCENTRE);
+    sizerRight->Add(0, 0, 1, wxCENTRE);
+    sizerRight->SetMinSize(150, 0);
+    m_sizerToggle = sizerRight; // save it to modify it later
+
+    // the 3 panes panes compose the window
+//    sizerTop->Add(sizerLeft, 0, (wxALL & ~wxLEFT), 10);
+    sizerTop->Add(sizerMiddle, 1, wxGROW | wxALL, 10);
+    sizerTop->Add(sizerRight, 1, wxGROW | (wxALL & ~wxRIGHT), 10);
+
+    // final initializations
+    Reset();
+
+    SetSizer(sizerTop);
+
+    sizerTop->Fit(this);
+}
+
+void ToggleWidgetsPage::Reset()
+{
+    m_toggle->SetValue(false);
+}
+
+void ToggleWidgetsPage::CreateToggle()
+{
+    const bool value = m_toggle->GetValue();
+
+    size_t count = m_sizerToggle->GetChildren().GetCount();
+    for ( size_t n = 0; n < count; n++ )
+    {
+        m_sizerToggle->Remove(0);
+    }
+
+    delete m_toggle;
+
+    m_toggle = new wxToggleButton(this, TogglePage_Picker, wxT("Toggle Button"));
+
+    m_toggle->SetValue(value);
+
+    m_sizerToggle->Add(0, 0, 1, wxCENTRE);
+    m_sizerToggle->Add(m_toggle, 1, wxCENTRE);
+    m_sizerToggle->Add(0, 0, 1, wxCENTRE);
+    m_sizerToggle->Layout();
+}
+
+// ----------------------------------------------------------------------------
+// event handlers
+// ----------------------------------------------------------------------------
+
+void ToggleWidgetsPage::OnButtonReset(wxCommandEvent& WXUNUSED(event))
+{
+    Reset();
+
+    CreateToggle();
+}
+
+void ToggleWidgetsPage::OnButtonChangeLabel(wxCommandEvent& WXUNUSED(event))
+{
+    m_toggle->SetLabel(m_textLabel->GetValue());
+}
+
+#endif // wxUSE_TOGGLEBTN
index 5c61f2efe787df5779e81b32a13a57a1c84da8a6..1f57e7e8a3cb52b88d234ebae9143355ab5f53c5 100644 (file)
@@ -4,9 +4,22 @@
     <include file="../../build/bakefiles/common_samples.bkl"/>
 
     <exe id="widgets" template="wx_sample" template_append="wx_append">
-        <sources>button.cpp checkbox.cpp combobox.cpp datepick.cpp gauge.cpp listbox.cpp
-                 notebook.cpp radiobox.cpp slider.cpp spinbtn.cpp static.cpp
-                 textctrl.cpp widgets.cpp</sources>
+        <sources>
+            button.cpp
+            checkbox.cpp
+            combobox.cpp
+            datepick.cpp
+            gauge.cpp
+            listbox.cpp
+            notebook.cpp
+            radiobox.cpp
+            slider.cpp
+            spinbtn.cpp
+            static.cpp
+            textctrl.cpp
+            toggle.cpp
+            widgets.cpp
+        </sources>
         <wx-lib>adv</wx-lib>
         <wx-lib>html</wx-lib>
         <wx-lib>core</wx-lib>
index 45fb9399e98d9ab0bba691310f795b57bab4f9c2..9b7a89b87559a41668ede0373261225168cfad6e 100644 (file)
@@ -520,6 +520,10 @@ SOURCE=.\textctrl.cpp
 # End Source File
 # Begin Source File
 
+SOURCE=.\toggle.cpp
+# End Source File
+# Begin Source File
+
 SOURCE=.\widgets.cpp
 # End Source File
 # End Group