1998-05-20 10:25:30 -04:00
|
|
|
\section{Toolbar overview}\label{wxtoolbaroverview}
|
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
Classes: \helpref{wxToolBar}{wxtoolbar}
|
1998-05-20 10:25:30 -04:00
|
|
|
|
|
|
|
The toolbar family of classes allows an application to use toolbars
|
|
|
|
in a variety of configurations and styles.
|
|
|
|
|
|
|
|
The toolbar is a popular user interface component and contains a set of bitmap
|
|
|
|
buttons or toggles. A toolbar gives faster access to an application's facilities than
|
|
|
|
menus, which have to be popped up and selected rather laboriously.
|
|
|
|
|
|
|
|
Instead of supplying one toolbar class with a number
|
|
|
|
of different implementations depending on platform, wxWindows separates
|
|
|
|
out the classes. This is because there are a number of different toolbar
|
|
|
|
styles that you may wish to use simultaneously, and also, future
|
|
|
|
toolbar implementations will emerge (for example, using the
|
|
|
|
new-style Windows `coolbar' as seen in Microsoft applications) which
|
1998-07-27 05:47:57 -04:00
|
|
|
cannot all be shoe-horned into the one class.
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
For each platform, the symbol {\bf wxToolBar} is defined to be one of the
|
|
|
|
specific toolbar classes.
|
1998-05-20 10:25:30 -04:00
|
|
|
|
|
|
|
The following is a summary of the toolbar classes and their differences.
|
|
|
|
|
|
|
|
\begin{itemize}\itemsep=0pt
|
|
|
|
\item {\bf wxToolBarBase.} This is a base class with pure virtual functions,
|
|
|
|
and should not be used directly.
|
|
|
|
\item {\bf wxToolBarSimple.} A simple toolbar class written entirely with generic wxWindows
|
|
|
|
functionality. A simply 3D effect for buttons is possible, but it is not consistent
|
|
|
|
with the Windows look and feel. This toolbar can scroll, and you can have arbitrary
|
|
|
|
numbers of rows and columns.
|
|
|
|
\item {\bf wxToolBarMSW.} This class implements an old-style Windows toolbar, only on
|
|
|
|
Windows. There are small, three-dimensional buttons, which do not (currently) reflect
|
1998-07-27 05:47:57 -04:00
|
|
|
the current Windows colour settings: the buttons are grey. This is the default wxToolBar
|
|
|
|
on 16-bit windows.
|
1998-05-20 10:25:30 -04:00
|
|
|
\item {\bf wxToolBar95.} Uses the native Windows 95 toolbar class. It dynamically adjusts its
|
|
|
|
background and button colours according to user colour settings.
|
|
|
|
CreateTools must be called after the tools have been added.
|
|
|
|
No absolute positioning is supported but you can specify the number
|
1998-07-27 05:47:57 -04:00
|
|
|
of rows, and add tool separators with {\bf AddSeparator}.
|
|
|
|
Tooltips are supported. {\bf OnRightClick} is not supported. This is the default wxToolBar
|
|
|
|
on Windows 95, Windows NT 4 and above.
|
1998-05-20 10:25:30 -04:00
|
|
|
\end{itemize}
|
|
|
|
|
|
|
|
A toolbar might appear as a single row of images under
|
|
|
|
the menubar, or it might be in a separate frame layout in several rows
|
|
|
|
and columns. The class handles the layout of the images, unless explicit
|
|
|
|
positioning is requested.
|
|
|
|
|
|
|
|
A tool is a bitmap which can either be a button (there is no `state',
|
|
|
|
it just generates an event when clicked) or it can be a toggle. If a
|
|
|
|
toggle, a second bitmap can be provided to depict the `on' state; if
|
|
|
|
the second bitmap is omitted, either the inverse of the first bitmap
|
|
|
|
will be used (for monochrome displays) or a thick border is drawn
|
|
|
|
around the bitmap (for colour displays where inverting will not have
|
|
|
|
the desired result).
|
|
|
|
|
|
|
|
The Windows-specific toolbar classes expect 16-colour bitmaps that are 16 pixels wide and 15 pixels
|
1998-07-31 05:33:36 -04:00
|
|
|
high. If you want to use a different size, call {\bf SetToolBitmapSize}\rtfsp
|
1998-05-20 10:25:30 -04:00
|
|
|
as the demo shows, before adding tools to the button bar. Don't supply more than
|
|
|
|
one bitmap for each tool, because the toolbar generates all three images (normal,
|
|
|
|
depressed and checked) from the single bitmap you give it.
|
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
To intercept
|
1998-05-20 10:25:30 -04:00
|
|
|
|
|
|
|
\subsection{Using the toolbar library}
|
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
Include {\tt "wx/toolbar.h"}, or if using a class directly, one of:
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
\begin{itemize}\itemsep=0pt
|
|
|
|
\item {\tt "wx/msw/tbarmsw.h} for wxToolBarMSW
|
|
|
|
\item {\tt "wx/msw/tbar95.h} for wxToolBar95
|
|
|
|
\item {\tt "wx/tbarsmpl.h} for wxToolBarSimple
|
|
|
|
\end{itemize}
|
|
|
|
|
|
|
|
Example of toolbar use are given in the sample program ``toolbar''. The
|
|
|
|
source is given below.
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
{\small
|
|
|
|
\begin{verbatim}
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: test.cpp
|
|
|
|
// Purpose: wxToolBar sample
|
|
|
|
// Author: Julian Smart
|
|
|
|
// Modified by:
|
|
|
|
// Created: 04/01/98
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) Julian Smart
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
// For compilers that support precompilation, includes "wx/wx.h".
|
|
|
|
#include "wx/wxprec.h"
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
#ifdef __BORLANDC__
|
|
|
|
#pragma hdrstop
|
|
|
|
#endif
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
#ifndef WX_PRECOMP
|
|
|
|
#include "wx/wx.h"
|
|
|
|
#endif
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
#include "wx/toolbar.h"
|
1999-02-09 16:22:58 -05:00
|
|
|
#include <wx/log.h>
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
#include "test.h"
|
1998-07-27 05:47:57 -04:00
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
#if defined(__WXGTK__) || defined(__WXMOTIF__)
|
|
|
|
#include "mondrian.xpm"
|
|
|
|
#include "bitmaps/new.xpm"
|
|
|
|
#include "bitmaps/open.xpm"
|
|
|
|
#include "bitmaps/save.xpm"
|
|
|
|
#include "bitmaps/copy.xpm"
|
|
|
|
#include "bitmaps/cut.xpm"
|
|
|
|
#include "bitmaps/print.xpm"
|
|
|
|
#include "bitmaps/preview.xpm"
|
|
|
|
#include "bitmaps/help.xpm"
|
1998-07-27 05:47:57 -04:00
|
|
|
#endif
|
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
IMPLEMENT_APP(MyApp)
|
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
// The `main program' equivalent, creating the windows and returning the
|
|
|
|
// main frame
|
|
|
|
bool MyApp::OnInit(void)
|
|
|
|
{
|
|
|
|
// Create the main frame window
|
1999-02-09 16:22:58 -05:00
|
|
|
MyFrame* frame = new MyFrame((wxFrame *) NULL, -1, (const wxString) "wxToolBar Sample",
|
1998-07-27 05:47:57 -04:00
|
|
|
wxPoint(100, 100), wxSize(450, 300));
|
|
|
|
|
|
|
|
// Give it a status line
|
|
|
|
frame->CreateStatusBar();
|
|
|
|
|
|
|
|
// Give it an icon
|
1999-02-09 16:22:58 -05:00
|
|
|
frame->SetIcon(wxICON(mondrian));
|
1998-07-27 05:47:57 -04:00
|
|
|
|
|
|
|
// Make a menubar
|
|
|
|
wxMenu *fileMenu = new wxMenu;
|
1999-02-09 16:22:58 -05:00
|
|
|
fileMenu->Append(wxID_EXIT, "E&xit", "Quit toolbar sample" );
|
1998-07-27 05:47:57 -04:00
|
|
|
|
|
|
|
wxMenu *helpMenu = new wxMenu;
|
1999-02-09 16:22:58 -05:00
|
|
|
helpMenu->Append(wxID_HELP, "&About", "About toolbar sample");
|
1998-07-27 05:47:57 -04:00
|
|
|
|
|
|
|
wxMenuBar* menuBar = new wxMenuBar;
|
|
|
|
|
|
|
|
menuBar->Append(fileMenu, "&File");
|
|
|
|
menuBar->Append(helpMenu, "&Help");
|
|
|
|
|
|
|
|
// Associate the menu bar with the frame
|
|
|
|
frame->SetMenuBar(menuBar);
|
|
|
|
|
|
|
|
// Create the toolbar
|
|
|
|
frame->CreateToolBar(wxNO_BORDER|wxHORIZONTAL|wxTB_FLAT, ID_TOOLBAR);
|
1999-02-09 16:22:58 -05:00
|
|
|
|
|
|
|
frame->GetToolBar()->SetMargins( 2, 2 );
|
1998-07-27 05:47:57 -04:00
|
|
|
|
|
|
|
InitToolbar(frame->GetToolBar());
|
|
|
|
|
|
|
|
// 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.
|
1999-02-09 16:22:58 -05:00
|
|
|
wxSizeEvent event(wxSize(-1, -1), frame->GetId());
|
|
|
|
frame->OnSize(event);
|
1998-07-27 05:47:57 -04:00
|
|
|
frame->Show(TRUE);
|
|
|
|
|
|
|
|
frame->SetStatusText("Hello, wxWindows");
|
|
|
|
|
|
|
|
SetTopWindow(frame);
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool MyApp::InitToolbar(wxToolBar* toolBar)
|
|
|
|
{
|
|
|
|
// Set up toolbar
|
|
|
|
wxBitmap* toolBarBitmaps[8];
|
|
|
|
|
|
|
|
#ifdef __WXMSW__
|
1998-05-20 10:25:30 -04:00
|
|
|
toolBarBitmaps[0] = new wxBitmap("icon1");
|
|
|
|
toolBarBitmaps[1] = new wxBitmap("icon2");
|
|
|
|
toolBarBitmaps[2] = new wxBitmap("icon3");
|
1998-07-27 05:47:57 -04:00
|
|
|
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");
|
1999-02-09 16:22:58 -05:00
|
|
|
#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( preview_xpm );
|
|
|
|
toolBarBitmaps[6] = new wxBitmap( print_xpm );
|
|
|
|
toolBarBitmaps[7] = new wxBitmap( help_xpm );
|
1998-07-27 05:47:57 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __WXMSW__
|
|
|
|
int width = 24;
|
|
|
|
#else
|
|
|
|
int width = 16;
|
|
|
|
#endif
|
|
|
|
int currentX = 5;
|
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_NEW, *(toolBarBitmaps[0]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "New file");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_OPEN, *(toolBarBitmaps[1]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Open file");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
|
|
|
toolBar->AddSeparator();
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Copy");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Cut");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
|
|
|
toolBar->AddSeparator();
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_PRINT, *(toolBarBitmaps[6]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Print");
|
1998-07-27 05:47:57 -04:00
|
|
|
currentX += width + 5;
|
|
|
|
toolBar->AddSeparator();
|
1999-02-09 16:22:58 -05:00
|
|
|
toolBar->AddTool(wxID_HELP, *(toolBarBitmaps[7]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Help");
|
1998-07-27 05:47:57 -04:00
|
|
|
|
|
|
|
toolBar->Realize();
|
|
|
|
|
|
|
|
// Can delete the bitmaps since they're reference counted
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 8; i++)
|
|
|
|
delete toolBarBitmaps[i];
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// wxID_HELP will be processed for the 'About' menu and the toolbar help button.
|
|
|
|
|
|
|
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|
|
|
EVT_MENU(wxID_EXIT, MyFrame::OnQuit)
|
|
|
|
EVT_MENU(wxID_HELP, MyFrame::OnAbout)
|
|
|
|
EVT_CLOSE(MyFrame::OnCloseWindow)
|
|
|
|
EVT_TOOL_RANGE(wxID_OPEN, wxID_PASTE, MyFrame::OnToolLeftClick)
|
1999-02-09 16:22:58 -05:00
|
|
|
EVT_TOOL_ENTER(wxID_OPEN, MyFrame::OnToolEnter)
|
1998-07-27 05:47:57 -04:00
|
|
|
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)
|
|
|
|
{
|
|
|
|
m_textWindow = new wxTextCtrl(this, -1, "", wxPoint(0, 0), wxSize(-1, -1), wxTE_MULTILINE);
|
|
|
|
}
|
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
|
1998-07-27 05:47:57 -04:00
|
|
|
{
|
|
|
|
Close(TRUE);
|
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1999-02-09 16:22:58 -05:00
|
|
|
void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
1998-07-27 05:47:57 -04:00
|
|
|
{
|
1999-02-09 16:22:58 -05:00
|
|
|
(void)wxMessageBox("wxWindows toolbar sample", "About wxToolBar");
|
1998-07-27 05:47:57 -04:00
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
// Define the behaviour for the frame closing
|
|
|
|
// - must delete all frames except for the main one.
|
1999-02-09 16:22:58 -05:00
|
|
|
void MyFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event))
|
1998-07-27 05:47:57 -04:00
|
|
|
{
|
|
|
|
Destroy();
|
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
void MyFrame::OnToolLeftClick(wxCommandEvent& event)
|
|
|
|
{
|
|
|
|
wxString str;
|
|
|
|
str.Printf("Clicked on tool %d", event.GetId());
|
|
|
|
SetStatusText(str);
|
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
|
1998-07-27 05:47:57 -04:00
|
|
|
void MyFrame::OnToolEnter(wxCommandEvent& event)
|
|
|
|
{
|
|
|
|
if (event.GetSelection() > -1)
|
|
|
|
{
|
|
|
|
wxString str;
|
|
|
|
str.Printf("This is tool number %d", event.GetSelection());
|
|
|
|
SetStatusText(str);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
SetStatusText("");
|
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
\end{verbatim}
|
1998-07-27 05:47:57 -04:00
|
|
|
}
|
1998-05-20 10:25:30 -04:00
|
|
|
|