]> git.saurik.com Git - wxWidgets.git/commitdiff
added test for changing toolbar on the fly
authorVadim Zeitlin <vadim@wxwidgets.org>
Wed, 15 Sep 1999 16:15:50 +0000 (16:15 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Wed, 15 Sep 1999 16:15:50 +0000 (16:15 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3678 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

samples/toolbar/test.cpp
samples/toolbar/test.h

index 3385bb3e37bd630f4a1fbf9e497e0554d2e701e2..f157066d7e9deb8c3aa09303195ec44bed064112 100644 (file)
@@ -42,54 +42,60 @@ IMPLEMENT_APP(MyApp)
 
 // The `main program' equivalent, creating the windows and returning the
 // main frame
-bool MyApp::OnInit(void)
+bool MyApp::OnInit()
 {
-  // Create the main frame window
-  MyFrame* frame = new MyFrame((wxFrame *) NULL, -1, (const wxString) "wxToolBar Sample",
-     wxPoint(100, 100), wxSize(450, 300));
+    // Create the main frame window
+    MyFrame* frame = new MyFrame((wxFrame *) NULL, -1, (const wxString) "wxToolBar Sample",
+            wxPoint(100, 100), wxSize(450, 300));
 
-  // Give it a status line
-  frame->CreateStatusBar();
+    // Give it a status line
+    frame->CreateStatusBar();
 
-  // Give it an icon
-  frame->SetIcon(wxICON(mondrian));
+    // Give it an icon
+    frame->SetIcon(wxICON(mondrian));
 
-  // Make a menubar
-  wxMenu *fileMenu = new wxMenu;
-  fileMenu->Append(wxID_EXIT, "E&xit", "Quit toolbar sample" );
+    // Make a menubar
+    wxMenu *tbarMenu = new wxMenu;
+    tbarMenu->Append(IDM_TOOLBAR_TOGGLETOOLBAR, "&Toggle toolbar", "Change the toolbar kind");
+    tbarMenu->Append(IDM_TOOLBAR_ENABLEPRINT, "&Enable print button", "");
+    tbarMenu->Append(IDM_TOOLBAR_TOGGLEHELP, "Toggle &help button", "");
 
-  wxMenu *helpMenu = new wxMenu;
-  helpMenu->Append(wxID_HELP, "&About", "About toolbar sample");
+    wxMenu *fileMenu = new wxMenu;
+    fileMenu->Append(wxID_EXIT, "E&xit", "Quit toolbar sample" );
 
-  wxMenuBar* menuBar = new wxMenuBar( wxMB_DOCKABLE );
+    wxMenu *helpMenu = new wxMenu;
+    helpMenu->Append(wxID_HELP, "&About", "About toolbar sample");
 
-  menuBar->Append(fileMenu, "&File");
-  menuBar->Append(helpMenu, "&Help");
+    wxMenuBar* menuBar = new wxMenuBar( wxMB_DOCKABLE );
 
-  // Associate the menu bar with the frame
-  frame->SetMenuBar(menuBar);
+    menuBar->Append(fileMenu, "&File");
+    menuBar->Append(tbarMenu, "&Toolbar");
+    menuBar->Append(helpMenu, "&Help");
 
-  // Create the toolbar
-  frame->CreateToolBar(wxNO_BORDER|wxTB_HORIZONTAL|wxTB_FLAT|wxTB_DOCKABLE, ID_TOOLBAR);
-  
-  frame->GetToolBar()->SetMargins( 2, 2 );
+    // Associate the menu bar with the frame
+    frame->SetMenuBar(menuBar);
 
-  InitToolbar(frame->GetToolBar());
+    // Create the toolbar
+    frame->CreateToolBar(wxNO_BORDER|wxTB_HORIZONTAL|wxTB_FLAT|wxTB_DOCKABLE, ID_TOOLBAR);
 
-  // Force a resize. This should probably be replaced by a call to a wxFrame
-  // function that lays out default decorations and the remaining content window.
-  wxSizeEvent event(wxSize(-1, -1), frame->GetId());
-  frame->OnSize(event);
-  frame->Show(TRUE);
+    frame->GetToolBar()->SetMargins( 2, 2 );
 
-  frame->SetStatusText("Hello, wxWindows");
-  
-  SetTopWindow(frame);
+    InitToolbar(frame->GetToolBar());
 
-  return TRUE;
+    // Force a resize. This should probably be replaced by a call to a wxFrame
+    // function that lays out default decorations and the remaining content window.
+    wxSizeEvent event(wxSize(-1, -1), frame->GetId());
+    frame->OnSize(event);
+    frame->Show(TRUE);
+
+    frame->SetStatusText("Hello, wxWindows");
+
+    SetTopWindow(frame);
+
+    return TRUE;
 }
 
-bool MyApp::InitToolbar(wxToolBar* toolBar)
+bool MyApp::InitToolbar(wxToolBar* toolBar, bool small)
 {
   // Set up toolbar
   wxBitmap* toolBarBitmaps[8];
@@ -97,22 +103,27 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
 #ifdef __WXMSW__
   toolBarBitmaps[0] = new wxBitmap("icon1");
   toolBarBitmaps[1] = new wxBitmap("icon2");
-  toolBarBitmaps[2] = new wxBitmap("icon3");
-  toolBarBitmaps[3] = new wxBitmap("icon4");
-  toolBarBitmaps[4] = new wxBitmap("icon5");
-  toolBarBitmaps[5] = new wxBitmap("icon6");
-  toolBarBitmaps[6] = new wxBitmap("icon7");
-  toolBarBitmaps[7] = new wxBitmap("icon8");
+  if ( !small )
+  {
+      toolBarBitmaps[2] = new wxBitmap("icon3");
+      toolBarBitmaps[3] = new wxBitmap("icon4");
+      toolBarBitmaps[4] = new wxBitmap("icon5");
+      toolBarBitmaps[5] = new wxBitmap("icon6");
+      toolBarBitmaps[6] = new wxBitmap("icon7");
+      toolBarBitmaps[7] = new wxBitmap("icon8");
+  }
 #else
   toolBarBitmaps[0] = new wxBitmap( new_xpm );
   toolBarBitmaps[1] = new wxBitmap( open_xpm );
-  toolBarBitmaps[2] = new wxBitmap( save_xpm );
-  toolBarBitmaps[3] = new wxBitmap( copy_xpm );
-  toolBarBitmaps[4] = new wxBitmap( cut_xpm );
-//  toolBarBitmaps[5] = new wxBitmap( paste_xpm );
-  toolBarBitmaps[5] = new wxBitmap( preview_xpm );
-  toolBarBitmaps[6] = new wxBitmap( print_xpm );
-  toolBarBitmaps[7] = new wxBitmap( help_xpm );
+  if ( !small )
+  {
+      toolBarBitmaps[2] = new wxBitmap( save_xpm );
+      toolBarBitmaps[3] = new wxBitmap( copy_xpm );
+      toolBarBitmaps[4] = new wxBitmap( cut_xpm );
+      toolBarBitmaps[5] = new wxBitmap( preview_xpm );
+      toolBarBitmaps[6] = new wxBitmap( print_xpm );
+      toolBarBitmaps[7] = new wxBitmap( help_xpm );
+  }
 #endif
 
 #ifdef __WXMSW__
@@ -125,29 +136,33 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
   toolBar->AddTool(wxID_NEW, *(toolBarBitmaps[0]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "New file");
   currentX += width + 5;
   toolBar->AddTool(wxID_OPEN, *(toolBarBitmaps[1]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Open file");
-  currentX += width + 5;
-  toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file");
-  currentX += width + 5;
-  toolBar->AddSeparator();
-  toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Disable/Enable print button");
-  currentX += width + 5;
-  toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Toggle/Untoggle help button");
-  currentX += width + 5;
-  toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste");
-  currentX += width + 5;
-  toolBar->AddSeparator();
-  toolBar->AddTool(wxID_PRINT, *(toolBarBitmaps[6]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Print");
-  currentX += width + 5;
-  toolBar->AddSeparator();
-  toolBar->AddTool(wxID_HELP, *(toolBarBitmaps[7]), *(toolBarBitmaps[6]), TRUE, currentX, -1, (wxObject *) NULL, "Help");
-  
-  toolBar->EnableTool( wxID_PRINT, FALSE );
+
+  if ( !small )
+  {
+      currentX += width + 5;
+      toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file");
+      currentX += width + 5;
+      toolBar->AddSeparator();
+      toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Disable/Enable print button");
+      currentX += width + 5;
+      toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Toggle/Untoggle help button");
+      currentX += width + 5;
+      toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste");
+      currentX += width + 5;
+      toolBar->AddSeparator();
+      toolBar->AddTool(wxID_PRINT, *(toolBarBitmaps[6]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Print");
+      currentX += width + 5;
+      toolBar->AddSeparator();
+      toolBar->AddTool(wxID_HELP, *(toolBarBitmaps[7]), *(toolBarBitmaps[6]), TRUE, currentX, -1, (wxObject *) NULL, "Help");
+      
+      toolBar->EnableTool( wxID_PRINT, FALSE );
+  }
 
   toolBar->Realize();
 
   // Can delete the bitmaps since they're reference counted
-  int i;
-  for (i = 0; i < 8; i++)
+  int i, max = small ? 2 : WXSIZEOF(toolBarBitmaps);
+  for (i = 0; i < max; i++)
     delete toolBarBitmaps[i];
 
   return TRUE;
@@ -158,17 +173,36 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
 BEGIN_EVENT_TABLE(MyFrame, wxFrame)
     EVT_MENU(wxID_EXIT, MyFrame::OnQuit)
     EVT_MENU(wxID_HELP, MyFrame::OnAbout)
-    EVT_CLOSE(MyFrame::OnCloseWindow)
+
+    EVT_MENU(IDM_TOOLBAR_TOGGLETOOLBAR, OnToggleToolbar)
+    EVT_MENU(IDM_TOOLBAR_ENABLEPRINT, OnEnablePrint)
+    EVT_MENU(IDM_TOOLBAR_TOGGLEHELP, OnToggleHelp)
+
     EVT_MENU(-1, MyFrame::OnToolLeftClick)
     EVT_TOOL_ENTER(ID_TOOLBAR, MyFrame::OnToolEnter)
 END_EVENT_TABLE()
 
 // Define my frame constructor
-MyFrame::MyFrame(wxFrame* parent, wxWindowID id, const wxString& title, const wxPoint& pos,
-        const wxSize& size, long style):
-  wxFrame(parent, id, title, pos, size, style)
+MyFrame::MyFrame(wxFrame* parent,
+                 wxWindowID id,
+                 const wxString& title,
+                 const wxPoint& pos,
+                 const wxSize& size,
+                 long style)
+       : wxFrame(parent, id, title, pos, size, style)
 {
     m_textWindow = new wxTextCtrl(this, -1, "", wxPoint(0, 0), wxSize(-1, -1), wxTE_MULTILINE);
+    m_smallToolbar = FALSE;
+}
+
+void MyFrame::OnToggleToolbar(wxCommandEvent& event)
+{
+    delete GetToolBar();
+    SetToolBar(NULL);
+    CreateToolBar(wxNO_BORDER|wxTB_HORIZONTAL|wxTB_FLAT|wxTB_DOCKABLE, ID_TOOLBAR);
+
+    m_smallToolbar = !m_smallToolbar;
+    wxGetApp().InitToolbar(GetToolBar(), m_smallToolbar);
 }
 
 void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
@@ -181,13 +215,6 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
     (void)wxMessageBox("wxWindows toolbar sample", "About wxToolBar");
 }
 
-// Define the behaviour for the frame closing
-// - must delete all frames except for the main one.
-void MyFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event))
-{
-    Destroy();
-}
-
 void MyFrame::OnToolLeftClick(wxCommandEvent& event)
 {
     wxString str;
@@ -204,20 +231,30 @@ void MyFrame::OnToolLeftClick(wxCommandEvent& event)
   
     if (event.GetId() == wxID_COPY)
     {
-        wxToolBar *tb = GetToolBar();
-        if (tb->GetToolEnabled(wxID_PRINT))
-            tb->EnableTool( wxID_PRINT, FALSE );
-        else
-            tb->EnableTool( wxID_PRINT, TRUE );
+        DoEnablePrint();
     }
     
     if (event.GetId() == wxID_CUT)
     {
-        wxToolBar *tb = GetToolBar();
-        tb->ToggleTool( wxID_HELP, !tb->GetToolState( wxID_HELP ) );
+        DoToggleHelp();
     }
 }
 
+void MyFrame::DoEnablePrint()
+{
+    wxToolBar *tb = GetToolBar();
+    if (tb->GetToolEnabled(wxID_PRINT))
+        tb->EnableTool( wxID_PRINT, FALSE );
+    else
+        tb->EnableTool( wxID_PRINT, TRUE );
+}
+
+void MyFrame::DoToggleHelp()
+{
+    wxToolBar *tb = GetToolBar();
+    tb->ToggleTool( wxID_HELP, !tb->GetToolState( wxID_HELP ) );
+}
+
 void MyFrame::OnToolEnter(wxCommandEvent& event)
 {
   if (event.GetSelection() > -1)
index 81ad6c421b60fde86fbc6287ed13a7826ab3b8e2..bea026b55bc0a51b029d9c4a740ec6983642e1a1 100644 (file)
 
 // Define a new application
 class MyApp: public wxApp
-{
-  public:
-    bool OnInit(void);
-    bool InitToolbar(wxToolBar* toolBar);
-};
-
-class MyTimer : public wxTimer
 {
 public:
-  MyTimer(wxFrame *frame) { m_frame = frame; }
-
-  virtual void Notify() { wxLogStatus(m_frame, _T("Timer arrived!") ); }
-
-private:
-  wxFrame *m_frame;
+    bool OnInit();
+    bool InitToolbar(wxToolBar* toolBar, bool small = FALSE);
 };
 
 // Define a new frame
 class MyFrame: public wxFrame
 {
 public:
-    MyFrame(wxFrame *parent, wxWindowID id = -1, const wxString& title = "wxToolBar Sample",
-        const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
-        long style = wxDEFAULT_FRAME_STYLE);
+    MyFrame(wxFrame *parent,
+            wxWindowID id = -1,
+            const wxString& title = "wxToolBar Sample",
+            const wxPoint& pos = wxDefaultPosition,
+            const wxSize& size = wxDefaultSize,
+            long style = wxDEFAULT_FRAME_STYLE);
 
-    void OnCloseWindow(wxCloseEvent& event);
     void OnQuit(wxCommandEvent& event);
     void OnAbout(wxCommandEvent& event);
+
+    void OnToggleToolbar(wxCommandEvent& event);
+    void OnEnablePrint(wxCommandEvent& event) { DoEnablePrint(); }
+    void OnToggleHelp(wxCommandEvent& event) { DoToggleHelp(); }
+
     void OnToolLeftClick(wxCommandEvent& event);
     void OnToolEnter(wxCommandEvent& event);
 
 private:
+    void DoEnablePrint();
+    void DoToggleHelp();
+
+    bool                m_smallToolbar;
     wxTextCtrl*         m_textWindow;
 
     DECLARE_EVENT_TABLE()
 };
 
-#define ID_TOOLBAR  500
+// ----------------------------------------------------------------------------
+// constants
+// ----------------------------------------------------------------------------
 
+const int ID_TOOLBAR = 500;
+
+enum
+{
+    IDM_TOOLBAR_TOGGLETOOLBAR = 200,
+    IDM_TOOLBAR_ENABLEPRINT,
+    IDM_TOOLBAR_TOGGLEHELP
+};