added test for changing toolbar on the fly

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3678 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 1999-09-15 16:15:50 +00:00
parent 93840b31b9
commit 7fb233050c
2 changed files with 148 additions and 101 deletions

View File

@ -42,54 +42,60 @@ IMPLEMENT_APP(MyApp)
// The `main program' equivalent, creating the windows and returning the // The `main program' equivalent, creating the windows and returning the
// main frame // main frame
bool MyApp::OnInit(void) bool MyApp::OnInit()
{ {
// Create the main frame window // Create the main frame window
MyFrame* frame = new MyFrame((wxFrame *) NULL, -1, (const wxString) "wxToolBar Sample", MyFrame* frame = new MyFrame((wxFrame *) NULL, -1, (const wxString) "wxToolBar Sample",
wxPoint(100, 100), wxSize(450, 300)); wxPoint(100, 100), wxSize(450, 300));
// Give it a status line // Give it a status line
frame->CreateStatusBar(); frame->CreateStatusBar();
// Give it an icon // Give it an icon
frame->SetIcon(wxICON(mondrian)); frame->SetIcon(wxICON(mondrian));
// Make a menubar // Make a menubar
wxMenu *fileMenu = new wxMenu; wxMenu *tbarMenu = new wxMenu;
fileMenu->Append(wxID_EXIT, "E&xit", "Quit toolbar sample" ); 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; wxMenu *fileMenu = new wxMenu;
helpMenu->Append(wxID_HELP, "&About", "About toolbar sample"); 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"); wxMenuBar* menuBar = new wxMenuBar( wxMB_DOCKABLE );
menuBar->Append(helpMenu, "&Help");
// Associate the menu bar with the frame menuBar->Append(fileMenu, "&File");
frame->SetMenuBar(menuBar); menuBar->Append(tbarMenu, "&Toolbar");
menuBar->Append(helpMenu, "&Help");
// Create the toolbar // Associate the menu bar with the frame
frame->CreateToolBar(wxNO_BORDER|wxTB_HORIZONTAL|wxTB_FLAT|wxTB_DOCKABLE, ID_TOOLBAR); frame->SetMenuBar(menuBar);
frame->GetToolBar()->SetMargins( 2, 2 );
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 frame->GetToolBar()->SetMargins( 2, 2 );
// 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"); InitToolbar(frame->GetToolBar());
SetTopWindow(frame);
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 // Set up toolbar
wxBitmap* toolBarBitmaps[8]; wxBitmap* toolBarBitmaps[8];
@ -97,22 +103,27 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
#ifdef __WXMSW__ #ifdef __WXMSW__
toolBarBitmaps[0] = new wxBitmap("icon1"); toolBarBitmaps[0] = new wxBitmap("icon1");
toolBarBitmaps[1] = new wxBitmap("icon2"); toolBarBitmaps[1] = new wxBitmap("icon2");
toolBarBitmaps[2] = new wxBitmap("icon3"); if ( !small )
toolBarBitmaps[3] = new wxBitmap("icon4"); {
toolBarBitmaps[4] = new wxBitmap("icon5"); toolBarBitmaps[2] = new wxBitmap("icon3");
toolBarBitmaps[5] = new wxBitmap("icon6"); toolBarBitmaps[3] = new wxBitmap("icon4");
toolBarBitmaps[6] = new wxBitmap("icon7"); toolBarBitmaps[4] = new wxBitmap("icon5");
toolBarBitmaps[7] = new wxBitmap("icon8"); toolBarBitmaps[5] = new wxBitmap("icon6");
toolBarBitmaps[6] = new wxBitmap("icon7");
toolBarBitmaps[7] = new wxBitmap("icon8");
}
#else #else
toolBarBitmaps[0] = new wxBitmap( new_xpm ); toolBarBitmaps[0] = new wxBitmap( new_xpm );
toolBarBitmaps[1] = new wxBitmap( open_xpm ); toolBarBitmaps[1] = new wxBitmap( open_xpm );
toolBarBitmaps[2] = new wxBitmap( save_xpm ); if ( !small )
toolBarBitmaps[3] = new wxBitmap( copy_xpm ); {
toolBarBitmaps[4] = new wxBitmap( cut_xpm ); toolBarBitmaps[2] = new wxBitmap( save_xpm );
// toolBarBitmaps[5] = new wxBitmap( paste_xpm ); toolBarBitmaps[3] = new wxBitmap( copy_xpm );
toolBarBitmaps[5] = new wxBitmap( preview_xpm ); toolBarBitmaps[4] = new wxBitmap( cut_xpm );
toolBarBitmaps[6] = new wxBitmap( print_xpm ); toolBarBitmaps[5] = new wxBitmap( preview_xpm );
toolBarBitmaps[7] = new wxBitmap( help_xpm ); toolBarBitmaps[6] = new wxBitmap( print_xpm );
toolBarBitmaps[7] = new wxBitmap( help_xpm );
}
#endif #endif
#ifdef __WXMSW__ #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"); toolBar->AddTool(wxID_NEW, *(toolBarBitmaps[0]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "New file");
currentX += width + 5; currentX += width + 5;
toolBar->AddTool(wxID_OPEN, *(toolBarBitmaps[1]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Open file"); 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"); if ( !small )
currentX += width + 5; {
toolBar->AddSeparator(); currentX += width + 5;
toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Disable/Enable print button"); toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file");
currentX += width + 5; currentX += width + 5;
toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Toggle/Untoggle help button"); toolBar->AddSeparator();
currentX += width + 5; toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Disable/Enable print button");
toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste"); currentX += width + 5;
currentX += width + 5; toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Toggle/Untoggle help button");
toolBar->AddSeparator(); currentX += width + 5;
toolBar->AddTool(wxID_PRINT, *(toolBarBitmaps[6]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Print"); toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste");
currentX += width + 5; currentX += width + 5;
toolBar->AddSeparator(); toolBar->AddSeparator();
toolBar->AddTool(wxID_HELP, *(toolBarBitmaps[7]), *(toolBarBitmaps[6]), TRUE, currentX, -1, (wxObject *) NULL, "Help"); toolBar->AddTool(wxID_PRINT, *(toolBarBitmaps[6]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Print");
currentX += width + 5;
toolBar->EnableTool( wxID_PRINT, FALSE ); toolBar->AddSeparator();
toolBar->AddTool(wxID_HELP, *(toolBarBitmaps[7]), *(toolBarBitmaps[6]), TRUE, currentX, -1, (wxObject *) NULL, "Help");
toolBar->EnableTool( wxID_PRINT, FALSE );
}
toolBar->Realize(); toolBar->Realize();
// Can delete the bitmaps since they're reference counted // Can delete the bitmaps since they're reference counted
int i; int i, max = small ? 2 : WXSIZEOF(toolBarBitmaps);
for (i = 0; i < 8; i++) for (i = 0; i < max; i++)
delete toolBarBitmaps[i]; delete toolBarBitmaps[i];
return TRUE; return TRUE;
@ -158,17 +173,36 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
BEGIN_EVENT_TABLE(MyFrame, wxFrame) BEGIN_EVENT_TABLE(MyFrame, wxFrame)
EVT_MENU(wxID_EXIT, MyFrame::OnQuit) EVT_MENU(wxID_EXIT, MyFrame::OnQuit)
EVT_MENU(wxID_HELP, MyFrame::OnAbout) 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_MENU(-1, MyFrame::OnToolLeftClick)
EVT_TOOL_ENTER(ID_TOOLBAR, MyFrame::OnToolEnter) EVT_TOOL_ENTER(ID_TOOLBAR, MyFrame::OnToolEnter)
END_EVENT_TABLE() END_EVENT_TABLE()
// Define my frame constructor // Define my frame constructor
MyFrame::MyFrame(wxFrame* parent, wxWindowID id, const wxString& title, const wxPoint& pos, MyFrame::MyFrame(wxFrame* parent,
const wxSize& size, long style): wxWindowID id,
wxFrame(parent, id, title, pos, size, style) 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_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)) void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
@ -181,13 +215,6 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
(void)wxMessageBox("wxWindows toolbar sample", "About wxToolBar"); (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) void MyFrame::OnToolLeftClick(wxCommandEvent& event)
{ {
wxString str; wxString str;
@ -204,20 +231,30 @@ void MyFrame::OnToolLeftClick(wxCommandEvent& event)
if (event.GetId() == wxID_COPY) if (event.GetId() == wxID_COPY)
{ {
wxToolBar *tb = GetToolBar(); DoEnablePrint();
if (tb->GetToolEnabled(wxID_PRINT))
tb->EnableTool( wxID_PRINT, FALSE );
else
tb->EnableTool( wxID_PRINT, TRUE );
} }
if (event.GetId() == wxID_CUT) if (event.GetId() == wxID_CUT)
{ {
wxToolBar *tb = GetToolBar(); DoToggleHelp();
tb->ToggleTool( wxID_HELP, !tb->GetToolState( wxID_HELP ) );
} }
} }
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) void MyFrame::OnToolEnter(wxCommandEvent& event)
{ {
if (event.GetSelection() > -1) if (event.GetSelection() > -1)

View File

@ -11,42 +11,52 @@
// Define a new application // Define a new application
class MyApp: public wxApp class MyApp: public wxApp
{
public:
bool OnInit(void);
bool InitToolbar(wxToolBar* toolBar);
};
class MyTimer : public wxTimer
{ {
public: public:
MyTimer(wxFrame *frame) { m_frame = frame; } bool OnInit();
bool InitToolbar(wxToolBar* toolBar, bool small = FALSE);
virtual void Notify() { wxLogStatus(m_frame, _T("Timer arrived!") ); }
private:
wxFrame *m_frame;
}; };
// Define a new frame // Define a new frame
class MyFrame: public wxFrame class MyFrame: public wxFrame
{ {
public: public:
MyFrame(wxFrame *parent, wxWindowID id = -1, const wxString& title = "wxToolBar Sample", MyFrame(wxFrame *parent,
const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, wxWindowID id = -1,
long style = wxDEFAULT_FRAME_STYLE); 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 OnQuit(wxCommandEvent& event);
void OnAbout(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 OnToolLeftClick(wxCommandEvent& event);
void OnToolEnter(wxCommandEvent& event); void OnToolEnter(wxCommandEvent& event);
private: private:
void DoEnablePrint();
void DoToggleHelp();
bool m_smallToolbar;
wxTextCtrl* m_textWindow; wxTextCtrl* m_textWindow;
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
}; };
#define ID_TOOLBAR 500 // ----------------------------------------------------------------------------
// constants
// ----------------------------------------------------------------------------
const int ID_TOOLBAR = 500;
enum
{
IDM_TOOLBAR_TOGGLETOOLBAR = 200,
IDM_TOOLBAR_ENABLEPRINT,
IDM_TOOLBAR_TOGGLEHELP
};