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:
parent
93840b31b9
commit
7fb233050c
@ -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)
|
||||||
|
@ -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
|
||||||
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user