3534 lines
108 KiB
C++
3534 lines
108 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: dialogs.cpp
|
|
// Purpose: Common dialogs demo
|
|
// Author: Julian Smart, Vadim Zeitlin, ABX
|
|
// Created: 04/01/98
|
|
// Copyright: (c) Julian Smart
|
|
// (c) 2004 ABX
|
|
// (c) Vadim Zeitlin
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// For compilers that support precompilation, includes "wx/wx.h".
|
|
#include "wx/wxprec.h"
|
|
|
|
#ifdef __BORLANDC__
|
|
#pragma hdrstop
|
|
#endif
|
|
|
|
#ifndef WX_PRECOMP
|
|
#include "wx/wx.h"
|
|
#endif
|
|
|
|
#include "../sample.xpm"
|
|
|
|
#include "wx/apptrait.h"
|
|
#include "wx/datetime.h"
|
|
#include "wx/filename.h"
|
|
#include "wx/image.h"
|
|
#include "wx/bookctrl.h"
|
|
#include "wx/artprov.h"
|
|
#include "wx/imaglist.h"
|
|
#include "wx/minifram.h"
|
|
#include "wx/sysopt.h"
|
|
#include "wx/notifmsg.h"
|
|
#include "wx/modalhook.h"
|
|
|
|
#if wxUSE_RICHMSGDLG
|
|
#include "wx/richmsgdlg.h"
|
|
#endif // wxUSE_RICHMSGDLG
|
|
|
|
#if wxUSE_COLOURDLG
|
|
#include "wx/colordlg.h"
|
|
#endif // wxUSE_COLOURDLG
|
|
|
|
#if wxUSE_CHOICEDLG
|
|
#include "wx/choicdlg.h"
|
|
#endif // wxUSE_CHOICEDLG
|
|
|
|
#include "wx/rearrangectrl.h"
|
|
#include "wx/addremovectrl.h"
|
|
|
|
#if wxUSE_STARTUP_TIPS
|
|
#include "wx/tipdlg.h"
|
|
#endif // wxUSE_STARTUP_TIPS
|
|
|
|
#if wxUSE_PROGRESSDLG
|
|
#if wxUSE_STOPWATCH && wxUSE_LONGLONG
|
|
#include "wx/datetime.h" // wxDateTime
|
|
#endif
|
|
|
|
#include "wx/progdlg.h"
|
|
#endif // wxUSE_PROGRESSDLG
|
|
|
|
#include "wx/appprogress.h"
|
|
|
|
#if wxUSE_ABOUTDLG
|
|
#include "wx/aboutdlg.h"
|
|
|
|
// these headers are only needed for custom about dialog
|
|
#include "wx/statline.h"
|
|
#include "wx/generic/aboutdlgg.h"
|
|
#endif // wxUSE_ABOUTDLG
|
|
|
|
#if wxUSE_BUSYINFO
|
|
#include "wx/busyinfo.h"
|
|
#endif // wxUSE_BUSYINFO
|
|
|
|
#if wxUSE_NUMBERDLG
|
|
#include "wx/numdlg.h"
|
|
#endif // wxUSE_NUMBERDLG
|
|
|
|
#if wxUSE_FILEDLG
|
|
#include "wx/filedlg.h"
|
|
#endif // wxUSE_FILEDLG
|
|
|
|
#if wxUSE_DIRDLG
|
|
#include "wx/dirdlg.h"
|
|
#endif // wxUSE_DIRDLG
|
|
|
|
#if wxUSE_FONTDLG
|
|
#include "wx/fontdlg.h"
|
|
#endif // wxUSE_FONTDLG
|
|
|
|
#if wxUSE_FINDREPLDLG
|
|
#include "wx/fdrepdlg.h"
|
|
#endif // wxUSE_FINDREPLDLG
|
|
|
|
#if wxUSE_INFOBAR
|
|
#include "wx/infobar.h"
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
#include "wx/spinctrl.h"
|
|
#include "wx/propdlg.h"
|
|
|
|
#include "dialogs.h"
|
|
|
|
#if USE_COLOURDLG_GENERIC
|
|
#include "wx/generic/colrdlgg.h"
|
|
#endif // USE_COLOURDLG_GENERIC
|
|
|
|
#if USE_DIRDLG_GENERIC
|
|
#include "wx/generic/dirdlgg.h"
|
|
#endif // USE_DIRDLG_GENERIC
|
|
|
|
#if USE_FILEDLG_GENERIC
|
|
#include "wx/generic/filedlgg.h"
|
|
#endif // USE_FILEDLG_GENERIC
|
|
|
|
#if USE_FONTDLG_GENERIC
|
|
#include "wx/generic/fontdlgg.h"
|
|
#endif // USE_FONTDLG_GENERIC
|
|
|
|
wxIMPLEMENT_APP(MyApp);
|
|
|
|
wxBEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow)
|
|
EVT_PAINT(MyCanvas::OnPaint)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
|
|
|
|
wxBEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|
#if wxUSE_MSGDLG
|
|
EVT_MENU(DIALOGS_MESSAGE_BOX, MyFrame::MessageBox)
|
|
EVT_MENU(DIALOGS_MESSAGE_BOX_WINDOW_MODAL, MyFrame::MessageBoxWindowModal)
|
|
EVT_MENU(DIALOGS_MESSAGE_DIALOG, MyFrame::MessageBoxDialog)
|
|
EVT_MENU(DIALOGS_MESSAGE_BOX_WXINFO, MyFrame::MessageBoxInfo)
|
|
#endif // wxUSE_MSGDLG
|
|
#if wxUSE_RICHMSGDLG
|
|
EVT_MENU(DIALOGS_RICH_MESSAGE_DIALOG, MyFrame::RichMessageDialog)
|
|
#endif // wxUSE_RICHMSGDLG
|
|
#if wxUSE_COLOURDLG
|
|
EVT_MENU(DIALOGS_CHOOSE_COLOUR, MyFrame::ChooseColour)
|
|
EVT_MENU(DIALOGS_CHOOSE_COLOUR_ALPHA, MyFrame::ChooseColour)
|
|
EVT_MENU(DIALOGS_GET_COLOUR, MyFrame::GetColour)
|
|
#endif // wxUSE_COLOURDLG
|
|
|
|
#if wxUSE_FONTDLG
|
|
EVT_MENU(DIALOGS_CHOOSE_FONT, MyFrame::ChooseFont)
|
|
#endif // wxUSE_FONTDLG
|
|
|
|
#if wxUSE_LOG_DIALOG
|
|
EVT_MENU(DIALOGS_LOG_DIALOG, MyFrame::LogDialog)
|
|
#endif // wxUSE_LOG_DIALOG
|
|
#if wxUSE_INFOBAR
|
|
EVT_MENU(DIALOGS_INFOBAR_SIMPLE, MyFrame::InfoBarSimple)
|
|
EVT_MENU(DIALOGS_INFOBAR_ADVANCED, MyFrame::InfoBarAdvanced)
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
#if wxUSE_TEXTDLG
|
|
EVT_MENU(DIALOGS_LINE_ENTRY, MyFrame::LineEntry)
|
|
EVT_MENU(DIALOGS_TEXT_ENTRY, MyFrame::TextEntry)
|
|
EVT_MENU(DIALOGS_PASSWORD_ENTRY, MyFrame::PasswordEntry)
|
|
#endif // wxUSE_TEXTDLG
|
|
|
|
#if wxUSE_NUMBERDLG
|
|
EVT_MENU(DIALOGS_NUM_ENTRY, MyFrame::NumericEntry)
|
|
#endif // wxUSE_NUMBERDLG
|
|
|
|
#if wxUSE_CHOICEDLG
|
|
EVT_MENU(DIALOGS_SINGLE_CHOICE, MyFrame::SingleChoice)
|
|
EVT_MENU(DIALOGS_MULTI_CHOICE, MyFrame::MultiChoice)
|
|
#endif // wxUSE_CHOICEDLG
|
|
|
|
#if wxUSE_REARRANGECTRL
|
|
EVT_MENU(DIALOGS_REARRANGE, MyFrame::Rearrange)
|
|
#endif // wxUSE_REARRANGECTRL
|
|
|
|
#if wxUSE_ADDREMOVECTRL
|
|
EVT_MENU(DIALOGS_ADDREMOVE, MyFrame::AddRemove)
|
|
#endif // wxUSE_ADDREMOVECTRL
|
|
|
|
#if wxUSE_FILEDLG
|
|
EVT_MENU(DIALOGS_FILE_OPEN, MyFrame::FileOpen)
|
|
EVT_MENU(DIALOGS_FILE_OPEN2, MyFrame::FileOpen2)
|
|
EVT_MENU(DIALOGS_FILES_OPEN, MyFrame::FilesOpen)
|
|
EVT_MENU(DIALOGS_FILE_SAVE, MyFrame::FileSave)
|
|
#endif // wxUSE_FILEDLG
|
|
|
|
#if USE_FILEDLG_GENERIC
|
|
EVT_MENU(DIALOGS_FILE_OPEN_GENERIC, MyFrame::FileOpenGeneric)
|
|
EVT_MENU(DIALOGS_FILES_OPEN_GENERIC, MyFrame::FilesOpenGeneric)
|
|
EVT_MENU(DIALOGS_FILE_SAVE_GENERIC, MyFrame::FileSaveGeneric)
|
|
#endif // USE_FILEDLG_GENERIC
|
|
|
|
#if wxUSE_DIRDLG
|
|
EVT_MENU(DIALOGS_DIR_CHOOSE, MyFrame::DirChoose)
|
|
EVT_MENU(DIALOGS_DIRNEW_CHOOSE, MyFrame::DirChooseNew)
|
|
#endif // wxUSE_DIRDLG
|
|
|
|
#if USE_MODAL_PRESENTATION
|
|
EVT_MENU(DIALOGS_MODAL, MyFrame::ModalDlg)
|
|
#endif // USE_MODAL_PRESENTATION
|
|
EVT_MENU(DIALOGS_MODELESS, MyFrame::ModelessDlg)
|
|
EVT_MENU(DIALOGS_CENTRE_SCREEN, MyFrame::DlgCenteredScreen)
|
|
EVT_MENU(DIALOGS_CENTRE_PARENT, MyFrame::DlgCenteredParent)
|
|
#if wxUSE_MINIFRAME
|
|
EVT_MENU(DIALOGS_MINIFRAME, MyFrame::MiniFrame)
|
|
#endif // wxUSE_MINIFRAME
|
|
EVT_MENU(DIALOGS_ONTOP, MyFrame::DlgOnTop)
|
|
|
|
#if wxUSE_STARTUP_TIPS
|
|
EVT_MENU(DIALOGS_TIP, MyFrame::ShowTip)
|
|
#endif // wxUSE_STARTUP_TIPS
|
|
|
|
#if USE_FONTDLG_GENERIC
|
|
EVT_MENU(DIALOGS_CHOOSE_FONT_GENERIC, MyFrame::ChooseFontGeneric)
|
|
#endif // USE_FONTDLG_GENERIC
|
|
|
|
#if USE_DIRDLG_GENERIC
|
|
EVT_MENU(DIALOGS_GENERIC_DIR_CHOOSE, MyFrame::GenericDirChoose)
|
|
#endif // wxMSW || wxMAC
|
|
|
|
#if USE_COLOURDLG_GENERIC
|
|
EVT_MENU(DIALOGS_CHOOSE_COLOUR_GENERIC, MyFrame::ChooseColourGeneric)
|
|
EVT_MENU(DIALOGS_CHOOSE_COLOUR_GENERIC_ALPHA, MyFrame::ChooseColourGeneric)
|
|
#endif // USE_COLOURDLG_GENERIC
|
|
|
|
#if wxUSE_PROGRESSDLG
|
|
EVT_MENU(DIALOGS_PROGRESS, MyFrame::ShowProgress)
|
|
#endif // wxUSE_PROGRESSDLG
|
|
|
|
EVT_MENU(DIALOGS_APP_PROGRESS, MyFrame::ShowAppProgress)
|
|
|
|
#if wxUSE_ABOUTDLG
|
|
EVT_MENU(DIALOGS_ABOUTDLG_SIMPLE, MyFrame::ShowSimpleAboutDialog)
|
|
EVT_MENU(DIALOGS_ABOUTDLG_FANCY, MyFrame::ShowFancyAboutDialog)
|
|
EVT_MENU(DIALOGS_ABOUTDLG_FULL, MyFrame::ShowFullAboutDialog)
|
|
EVT_MENU(DIALOGS_ABOUTDLG_CUSTOM, MyFrame::ShowCustomAboutDialog)
|
|
#endif // wxUSE_ABOUTDLG
|
|
|
|
#if wxUSE_BUSYINFO
|
|
EVT_MENU(DIALOGS_BUSYINFO, MyFrame::ShowBusyInfo)
|
|
EVT_MENU(DIALOGS_BUSYINFO_RICH, MyFrame::ShowRichBusyInfo)
|
|
#endif // wxUSE_BUSYINFO
|
|
|
|
#if wxUSE_FINDREPLDLG
|
|
EVT_MENU(DIALOGS_FIND, MyFrame::ShowFindDialog)
|
|
EVT_MENU(DIALOGS_REPLACE, MyFrame::ShowReplaceDialog)
|
|
|
|
EVT_FIND(wxID_ANY, MyFrame::OnFindDialog)
|
|
EVT_FIND_NEXT(wxID_ANY, MyFrame::OnFindDialog)
|
|
EVT_FIND_REPLACE(wxID_ANY, MyFrame::OnFindDialog)
|
|
EVT_FIND_REPLACE_ALL(wxID_ANY, MyFrame::OnFindDialog)
|
|
EVT_FIND_CLOSE(wxID_ANY, MyFrame::OnFindDialog)
|
|
#endif // wxUSE_FINDREPLDLG
|
|
|
|
#if USE_SETTINGS_DIALOG
|
|
EVT_MENU(DIALOGS_PROPERTY_SHEET, MyFrame::OnPropertySheet)
|
|
EVT_MENU(DIALOGS_PROPERTY_SHEET_TOOLBOOK, MyFrame::OnPropertySheet)
|
|
EVT_MENU(DIALOGS_PROPERTY_SHEET_BUTTONTOOLBOOK, MyFrame::OnPropertySheet)
|
|
#endif // USE_SETTINGS_DIALOG
|
|
|
|
EVT_MENU(DIALOGS_STANDARD_BUTTON_SIZER_DIALOG, MyFrame::OnStandardButtonsSizerDialog)
|
|
EVT_MENU(DIALOGS_TEST_DEFAULT_ACTION, MyFrame::OnTestDefaultActionDialog)
|
|
EVT_MENU(DIALOGS_MODAL_HOOK, MyFrame::OnModalHook)
|
|
|
|
EVT_MENU(DIALOGS_REQUEST, MyFrame::OnRequestUserAttention)
|
|
#if wxUSE_NOTIFICATION_MESSAGE
|
|
EVT_MENU(DIALOGS_NOTIFY_AUTO, MyFrame::OnNotifMsgAuto)
|
|
EVT_MENU(DIALOGS_NOTIFY_SHOW, MyFrame::OnNotifMsgShow)
|
|
EVT_MENU(DIALOGS_NOTIFY_HIDE, MyFrame::OnNotifMsgHide)
|
|
#endif // wxUSE_NOTIFICATION_MESSAGE
|
|
|
|
#if wxUSE_RICHTOOLTIP
|
|
EVT_MENU(DIALOGS_RICHTIP_DIALOG, MyFrame::OnRichTipDialog)
|
|
#endif // wxUSE_RICHTOOLTIP
|
|
|
|
EVT_MENU(wxID_EXIT, MyFrame::OnExit)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
#if USE_MODAL_PRESENTATION
|
|
|
|
wxBEGIN_EVENT_TABLE(MyModalDialog, wxDialog)
|
|
EVT_BUTTON(wxID_ANY, MyModalDialog::OnButton)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
wxBEGIN_EVENT_TABLE(MyModelessDialog, wxDialog)
|
|
EVT_BUTTON(DIALOGS_MODELESS_BTN, MyModelessDialog::OnButton)
|
|
EVT_CLOSE(MyModelessDialog::OnClose)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
#endif // USE_MODAL_PRESENTATION
|
|
|
|
wxBEGIN_EVENT_TABLE(StdButtonSizerDialog, wxDialog)
|
|
EVT_CHECKBOX(wxID_ANY, StdButtonSizerDialog::OnEvent)
|
|
EVT_RADIOBUTTON(wxID_ANY, StdButtonSizerDialog::OnEvent)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
#if wxUSE_CMDLINE_PARSER
|
|
|
|
#include "wx/cmdline.h"
|
|
|
|
static const char *PROGRESS_SWITCH = "progress";
|
|
|
|
void MyApp::OnInitCmdLine(wxCmdLineParser& parser)
|
|
{
|
|
wxApp::OnInitCmdLine(parser);
|
|
|
|
parser.AddOption("", PROGRESS_SWITCH,
|
|
"Style for the startup progress dialog (wxPD_XXX)",
|
|
wxCMD_LINE_VAL_NUMBER);
|
|
}
|
|
|
|
bool MyApp::OnCmdLineParsed(wxCmdLineParser& parser)
|
|
{
|
|
if ( !wxApp::OnCmdLineParsed(parser) )
|
|
return false;
|
|
|
|
parser.Found(PROGRESS_SWITCH, &m_startupProgressStyle);
|
|
|
|
return true;
|
|
}
|
|
|
|
#endif // wxUSE_CMDLINE_PARSER
|
|
|
|
// `Main program' equivalent, creating windows and returning main app frame
|
|
bool MyApp::OnInit()
|
|
{
|
|
if ( !wxApp::OnInit() )
|
|
return false;
|
|
|
|
#if wxUSE_PROGRESSDLG
|
|
if ( m_startupProgressStyle != -1 )
|
|
{
|
|
// Show a test progress dialog before the main event loop is started:
|
|
// it should still work.
|
|
const int PROGRESS_COUNT = 100;
|
|
wxProgressDialog dlg
|
|
(
|
|
"Progress in progress",
|
|
"Please wait, starting...",
|
|
PROGRESS_COUNT,
|
|
NULL,
|
|
m_startupProgressStyle
|
|
);
|
|
for ( int i = 0; i <= PROGRESS_COUNT; i++ )
|
|
{
|
|
if ( !dlg.Update(i) )
|
|
break;
|
|
|
|
wxMilliSleep(50);
|
|
}
|
|
}
|
|
#endif // wxUSE_PROGRESSDLG
|
|
|
|
#if wxUSE_IMAGE
|
|
wxInitAllImageHandlers();
|
|
#endif
|
|
|
|
// Create the main frame window
|
|
MyFrame *frame = new MyFrame(wxT("wxWidgets dialogs example"));
|
|
|
|
// Make a menubar
|
|
wxMenu *menuDlg = new wxMenu;
|
|
|
|
menuDlg->Append(DIALOGS_MESSAGE_BOX, wxT("&Message box\tCtrl-M"));
|
|
menuDlg->Append(DIALOGS_MESSAGE_BOX_WINDOW_MODAL, wxT("Window-Modal Message box "));
|
|
menuDlg->Append(DIALOGS_MESSAGE_DIALOG, wxT("Message dialog\tShift-Ctrl-M"));
|
|
#if wxUSE_RICHMSGDLG
|
|
menuDlg->Append(DIALOGS_RICH_MESSAGE_DIALOG, wxT("Rich message dialog"));
|
|
#endif // wxUSE_RICHMSGDLG
|
|
|
|
|
|
#if wxUSE_COLOURDLG || wxUSE_FONTDLG || wxUSE_CHOICEDLG
|
|
|
|
wxMenu *choices_menu = new wxMenu;
|
|
|
|
#if wxUSE_COLOURDLG
|
|
wxMenu *choices_bg_colour = new wxMenu;
|
|
choices_bg_colour->Append(DIALOGS_CHOOSE_COLOUR, wxT("&No opacity"));
|
|
choices_bg_colour->Append(DIALOGS_CHOOSE_COLOUR_ALPHA, wxT("&With opacity"));
|
|
choices_menu->Append(wxID_ANY, wxT("&Choose bg colour"), choices_bg_colour);
|
|
choices_menu->Append(DIALOGS_GET_COLOUR, wxT("&Choose fg colour"));
|
|
#endif // wxUSE_COLOURDLG
|
|
|
|
#if wxUSE_FONTDLG
|
|
choices_menu->Append(DIALOGS_CHOOSE_FONT, wxT("Choose &font"));
|
|
#endif // wxUSE_FONTDLG
|
|
|
|
#if wxUSE_CHOICEDLG
|
|
choices_menu->Append(DIALOGS_SINGLE_CHOICE, wxT("&Single choice\tCtrl-C"));
|
|
choices_menu->Append(DIALOGS_MULTI_CHOICE, wxT("M&ultiple choice\tCtrl-U"));
|
|
#endif // wxUSE_CHOICEDLG
|
|
|
|
#if wxUSE_REARRANGECTRL
|
|
choices_menu->Append(DIALOGS_REARRANGE, wxT("&Rearrange dialog\tCtrl-R"));
|
|
#endif // wxUSE_REARRANGECTRL
|
|
|
|
#if wxUSE_ADDREMOVECTRL
|
|
choices_menu->Append(DIALOGS_ADDREMOVE, "&Add/remove items control\tCtrl-A");
|
|
#endif // wxUSE_ADDREMOVECTRL
|
|
|
|
#if USE_COLOURDLG_GENERIC || USE_FONTDLG_GENERIC
|
|
choices_menu->AppendSeparator();
|
|
#endif // USE_COLOURDLG_GENERIC || USE_FONTDLG_GENERIC
|
|
|
|
#if USE_COLOURDLG_GENERIC
|
|
wxMenu *colourGeneric_menu = new wxMenu;
|
|
colourGeneric_menu->Append(DIALOGS_CHOOSE_COLOUR_GENERIC, wxT("&No opacity"));
|
|
colourGeneric_menu->Append(DIALOGS_CHOOSE_COLOUR_GENERIC_ALPHA, wxT("&With opacity"));
|
|
choices_menu->Append(wxID_ANY, wxT("&Choose colour (generic)"), colourGeneric_menu);
|
|
#endif // USE_COLOURDLG_GENERIC
|
|
|
|
#if USE_FONTDLG_GENERIC
|
|
choices_menu->Append(DIALOGS_CHOOSE_FONT_GENERIC, wxT("Choose &font (generic)"));
|
|
#endif // USE_FONTDLG_GENERIC
|
|
|
|
menuDlg->Append(wxID_ANY,wxT("&Choices and selectors"),choices_menu);
|
|
#endif // wxUSE_COLOURDLG || wxUSE_FONTDLG || wxUSE_CHOICEDLG
|
|
|
|
|
|
#if wxUSE_TEXTDLG || wxUSE_NUMBERDLG
|
|
|
|
wxMenu *entry_menu = new wxMenu;
|
|
|
|
#if wxUSE_TEXTDLG
|
|
entry_menu->Append(DIALOGS_LINE_ENTRY, wxT("Single line &entry\tCtrl-E"));
|
|
entry_menu->Append(DIALOGS_TEXT_ENTRY, wxT("Multi line text &entry\tShift-Ctrl-E"));
|
|
entry_menu->Append(DIALOGS_PASSWORD_ENTRY, wxT("&Password entry\tCtrl-P"));
|
|
#endif // wxUSE_TEXTDLG
|
|
|
|
#if wxUSE_NUMBERDLG
|
|
entry_menu->Append(DIALOGS_NUM_ENTRY, wxT("&Numeric entry\tCtrl-N"));
|
|
#endif // wxUSE_NUMBERDLG
|
|
|
|
menuDlg->Append(wxID_ANY,wxT("&Entry dialogs"),entry_menu);
|
|
|
|
#endif // wxUSE_TEXTDLG || wxUSE_NUMBERDLG
|
|
|
|
|
|
#if wxUSE_FILEDLG
|
|
|
|
wxMenu *filedlg_menu = new wxMenu;
|
|
filedlg_menu->Append(DIALOGS_FILE_OPEN, wxT("&Open file\tCtrl-O"));
|
|
filedlg_menu->Append(DIALOGS_FILE_OPEN2, wxT("&Second open file\tCtrl-2"));
|
|
filedlg_menu->Append(DIALOGS_FILES_OPEN, wxT("Open &files\tCtrl-Q"));
|
|
filedlg_menu->Append(DIALOGS_FILE_SAVE, wxT("Sa&ve file\tCtrl-S"));
|
|
|
|
#if USE_FILEDLG_GENERIC
|
|
filedlg_menu->AppendSeparator();
|
|
filedlg_menu->Append(DIALOGS_FILE_OPEN_GENERIC, wxT("&Open file (generic)"));
|
|
filedlg_menu->Append(DIALOGS_FILES_OPEN_GENERIC, wxT("Open &files (generic)"));
|
|
filedlg_menu->Append(DIALOGS_FILE_SAVE_GENERIC, wxT("Sa&ve file (generic)"));
|
|
#endif // USE_FILEDLG_GENERIC
|
|
|
|
menuDlg->Append(wxID_ANY,wxT("&File operations"),filedlg_menu);
|
|
|
|
#endif // wxUSE_FILEDLG
|
|
|
|
#if wxUSE_DIRDLG
|
|
wxMenu *dir_menu = new wxMenu;
|
|
|
|
dir_menu->Append(DIALOGS_DIR_CHOOSE, wxT("&Choose a directory\tCtrl-D"));
|
|
dir_menu->Append(DIALOGS_DIRNEW_CHOOSE, wxT("Choose a directory (with \"Ne&w\" button)\tShift-Ctrl-D"));
|
|
menuDlg->Append(wxID_ANY,wxT("&Directory operations"),dir_menu);
|
|
|
|
#if USE_DIRDLG_GENERIC
|
|
dir_menu->AppendSeparator();
|
|
dir_menu->Append(DIALOGS_GENERIC_DIR_CHOOSE, wxT("&Choose a directory (generic)"));
|
|
#endif // USE_DIRDLG_GENERIC
|
|
|
|
#endif // wxUSE_DIRDLG
|
|
|
|
|
|
#if wxUSE_STARTUP_TIPS || \
|
|
wxUSE_PROGRESSDLG || \
|
|
wxUSE_BUSYINFO || \
|
|
wxUSE_LOG_DIALOG || \
|
|
wxUSE_MSGDLG
|
|
|
|
wxMenu *info_menu = new wxMenu;
|
|
|
|
#if wxUSE_STARTUP_TIPS
|
|
info_menu->Append(DIALOGS_TIP, wxT("&Tip of the day\tCtrl-T"));
|
|
#endif // wxUSE_STARTUP_TIPS
|
|
|
|
#if wxUSE_PROGRESSDLG
|
|
info_menu->Append(DIALOGS_PROGRESS, wxT("Pro&gress dialog\tCtrl-G"));
|
|
#endif // wxUSE_PROGRESSDLG
|
|
|
|
info_menu->Append(DIALOGS_APP_PROGRESS, wxT("&App progress\tShift-Ctrl-G"));
|
|
|
|
#if wxUSE_BUSYINFO
|
|
info_menu->Append(DIALOGS_BUSYINFO, wxT("&Busy info dialog\tCtrl-B"));
|
|
info_menu->Append(DIALOGS_BUSYINFO_RICH, wxT("&Rich busy info dialog\tShift-Ctrl-B"));
|
|
#endif // wxUSE_BUSYINFO
|
|
|
|
#if wxUSE_LOG_DIALOG
|
|
info_menu->Append(DIALOGS_LOG_DIALOG, wxT("&Log dialog\tCtrl-L"));
|
|
#endif // wxUSE_LOG_DIALOG
|
|
|
|
#if wxUSE_INFOBAR
|
|
info_menu->Append(DIALOGS_INFOBAR_SIMPLE, "Simple &info bar\tCtrl-I");
|
|
info_menu->Append(DIALOGS_INFOBAR_ADVANCED, "&Advanced info bar\tShift-Ctrl-I");
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
#if wxUSE_MSGDLG
|
|
info_menu->Append(DIALOGS_MESSAGE_BOX_WXINFO,
|
|
wxT("&wxWidgets information\tCtrl-W"));
|
|
#endif // wxUSE_MSGDLG
|
|
|
|
menuDlg->Append(wxID_ANY,wxT("&Informative dialogs"),info_menu);
|
|
|
|
#endif // wxUSE_STARTUP_TIPS || wxUSE_PROGRESSDLG || wxUSE_BUSYINFO || wxUSE_LOG_DIALOG
|
|
|
|
|
|
#if wxUSE_FINDREPLDLG
|
|
wxMenu *find_menu = new wxMenu;
|
|
find_menu->AppendCheckItem(DIALOGS_FIND, wxT("&Find dialog\tCtrl-F"));
|
|
find_menu->AppendCheckItem(DIALOGS_REPLACE, wxT("Find and &replace dialog\tShift-Ctrl-F"));
|
|
menuDlg->Append(wxID_ANY,wxT("&Searching"),find_menu);
|
|
#endif // wxUSE_FINDREPLDLG
|
|
|
|
wxMenu *dialogs_menu = new wxMenu;
|
|
#if USE_MODAL_PRESENTATION
|
|
dialogs_menu->Append(DIALOGS_MODAL, wxT("&Modal dialog\tShift-Ctrl-W"));
|
|
#endif // USE_MODAL_PRESENTATION
|
|
dialogs_menu->AppendCheckItem(DIALOGS_MODELESS, wxT("Mode&less dialog\tShift-Ctrl-Z"));
|
|
dialogs_menu->Append(DIALOGS_CENTRE_SCREEN, wxT("Centered on &screen\tShift-Ctrl-1"));
|
|
dialogs_menu->Append(DIALOGS_CENTRE_PARENT, wxT("Centered on &parent\tShift-Ctrl-2"));
|
|
#if wxUSE_MINIFRAME
|
|
dialogs_menu->Append(DIALOGS_MINIFRAME, wxT("&Mini frame"));
|
|
#endif // wxUSE_MINIFRAME
|
|
dialogs_menu->Append(DIALOGS_ONTOP, wxT("Dialog staying on &top"));
|
|
menuDlg->Append(wxID_ANY, wxT("&Generic dialogs"), dialogs_menu);
|
|
|
|
#if USE_SETTINGS_DIALOG
|
|
wxMenu *sheet_menu = new wxMenu;
|
|
sheet_menu->Append(DIALOGS_PROPERTY_SHEET, wxT("&Standard property sheet\tShift-Ctrl-P"));
|
|
sheet_menu->Append(DIALOGS_PROPERTY_SHEET_TOOLBOOK, wxT("&Toolbook sheet\tShift-Ctrl-T"));
|
|
|
|
if (wxPlatformIs(wxPORT_MAC))
|
|
sheet_menu->Append(DIALOGS_PROPERTY_SHEET_BUTTONTOOLBOOK, wxT("Button &Toolbook sheet\tShift-Ctrl-U"));
|
|
/*
|
|
#ifdef __WXMAC__
|
|
sheet_menu->Append(DIALOGS_PROPERTY_SHEET_BUTTONTOOLBOOK, wxT("Button &Toolbook sheet\tShift-Ctrl-U"));
|
|
#endif
|
|
*/
|
|
menuDlg->Append(wxID_ANY, wxT("&Property sheets"), sheet_menu);
|
|
#endif // USE_SETTINGS_DIALOG
|
|
|
|
wxMenu *menuNotif = new wxMenu;
|
|
menuNotif->Append(DIALOGS_REQUEST, wxT("&Request user attention\tCtrl-Shift-R"));
|
|
#if wxUSE_NOTIFICATION_MESSAGE
|
|
menuNotif->Append(DIALOGS_NOTIFY_AUTO, "&Automatically hidden notification");
|
|
menuNotif->Append(DIALOGS_NOTIFY_SHOW, "&Show manual notification");
|
|
menuNotif->Append(DIALOGS_NOTIFY_HIDE, "&Hide manual notification");
|
|
#endif // wxUSE_NOTIFICATION_MESSAGE
|
|
menuDlg->AppendSubMenu(menuNotif, "&User notifications");
|
|
|
|
#if wxUSE_RICHTOOLTIP
|
|
menuDlg->Append(DIALOGS_RICHTIP_DIALOG, "Rich &tooltip dialog...\tCtrl-H");
|
|
menuDlg->AppendSeparator();
|
|
#endif // wxUSE_RICHTOOLTIP
|
|
|
|
menuDlg->Append(DIALOGS_STANDARD_BUTTON_SIZER_DIALOG, wxT("&Standard Buttons Sizer Dialog"));
|
|
menuDlg->Append(DIALOGS_TEST_DEFAULT_ACTION, wxT("&Test dialog default action"));
|
|
menuDlg->AppendCheckItem(DIALOGS_MODAL_HOOK, "Enable modal dialog hook");
|
|
|
|
menuDlg->AppendSeparator();
|
|
menuDlg->Append(wxID_EXIT, wxT("E&xit\tAlt-X"));
|
|
|
|
#if wxUSE_ABOUTDLG
|
|
wxMenu *menuHelp = new wxMenu;
|
|
menuHelp->Append(DIALOGS_ABOUTDLG_SIMPLE, wxT("&About (simple)...\tF1"));
|
|
menuHelp->Append(DIALOGS_ABOUTDLG_FANCY, wxT("About (&fancy)...\tShift-F1"));
|
|
menuHelp->Append(DIALOGS_ABOUTDLG_FULL, wxT("About (f&ull)...\tCtrl-F1"));
|
|
menuHelp->Append(DIALOGS_ABOUTDLG_CUSTOM, wxT("About (&custom)...\tCtrl-Shift-F1"));
|
|
#endif // wxUSE_ABOUTDLG
|
|
|
|
wxMenu* editMenu = new wxMenu;
|
|
editMenu->Append(wxID_UNDO, _("&Undo\tCtrl+Z"));
|
|
editMenu->Append(wxID_REDO, _("&Redo\tCtrl+Y"));
|
|
editMenu->AppendSeparator();
|
|
editMenu->Append(wxID_CUT, _("Cu&t\tCtrl+X"));
|
|
editMenu->Append(wxID_COPY, _("&Copy\tCtrl+C"));
|
|
editMenu->Append(wxID_PASTE, _("&Paste\tCtrl+V"));
|
|
editMenu->Append(wxID_CLEAR, _("&Delete"));
|
|
|
|
editMenu->AppendSeparator();
|
|
editMenu->Append(wxID_SELECTALL, _("Select All\tCtrl+A"));
|
|
|
|
wxMenuBar *menubar = new wxMenuBar;
|
|
menubar->Append(menuDlg, wxT("&Dialogs"));
|
|
|
|
menubar->Append(editMenu, wxT("&Edit"));
|
|
|
|
#if wxUSE_ABOUTDLG
|
|
menubar->Append(menuHelp, wxT("&Help"));
|
|
#endif // wxUSE_ABOUTDLG
|
|
|
|
frame->SetMenuBar(menubar);
|
|
|
|
frame->Centre(wxBOTH);
|
|
frame->Show(true);
|
|
|
|
return true;
|
|
}
|
|
|
|
// My frame constructor
|
|
MyFrame::MyFrame(const wxString& title)
|
|
: wxFrame(NULL, wxID_ANY, title)
|
|
{
|
|
SetIcon(wxICON(sample));
|
|
|
|
#if USE_MODAL_PRESENTATION
|
|
m_dialog = (MyModelessDialog *)NULL;
|
|
#endif // USE_MODAL_PRESENTATION
|
|
|
|
#if wxUSE_FINDREPLDLG
|
|
m_dlgFind =
|
|
m_dlgReplace = NULL;
|
|
#endif
|
|
|
|
#if wxUSE_COLOURDLG
|
|
m_clrData.SetChooseFull(true);
|
|
for (int i = 0; i < wxColourData::NUM_CUSTOM; i++)
|
|
{
|
|
unsigned char n = i*16;
|
|
m_clrData.SetCustomColour(i, wxColour(n, n, n));
|
|
}
|
|
#endif // wxUSE_COLOURDLG
|
|
|
|
#if wxUSE_NOTIFICATION_MESSAGE
|
|
m_notifMsg = NULL;
|
|
#endif // wxUSE_NOTIFICATION_MESSAGE
|
|
|
|
#if wxUSE_STATUSBAR
|
|
CreateStatusBar();
|
|
#endif // wxUSE_STATUSBAR
|
|
|
|
m_canvas = new MyCanvas(this);
|
|
|
|
#if wxUSE_INFOBAR
|
|
// an info bar can be created very simply and used without any extra effort
|
|
m_infoBarSimple = new wxInfoBar(this);
|
|
|
|
// or it can also be customized by
|
|
m_infoBarAdvanced = new wxInfoBar(this);
|
|
|
|
// ... adding extra buttons (but more than two will usually be too many)
|
|
m_infoBarAdvanced->AddButton(wxID_UNDO);
|
|
m_infoBarAdvanced->AddButton(wxID_REDO);
|
|
|
|
m_infoBarAdvanced->Connect(wxID_REDO, wxEVT_BUTTON,
|
|
wxCommandEventHandler(MyFrame::OnInfoBarRedo),
|
|
NULL,
|
|
this);
|
|
|
|
// adding and removing a button immediately doesn't make sense here, of
|
|
// course, it's done just to show that it is possible
|
|
m_infoBarAdvanced->AddButton(wxID_EXIT);
|
|
m_infoBarAdvanced->RemoveButton(wxID_EXIT);
|
|
|
|
// ... changing the colours and/or fonts
|
|
m_infoBarAdvanced->SetOwnBackgroundColour(0xc8ffff);
|
|
m_infoBarAdvanced->SetFont(GetFont().Bold().Larger());
|
|
|
|
// ... and changing the effect (only does anything under MSW currently)
|
|
m_infoBarAdvanced->SetShowHideEffects(wxSHOW_EFFECT_EXPAND,
|
|
wxSHOW_EFFECT_EXPAND);
|
|
m_infoBarAdvanced->SetEffectDuration(1500);
|
|
|
|
|
|
// to use the info bars we need to use sizer for the window layout
|
|
wxBoxSizer * const sizer = new wxBoxSizer(wxVERTICAL);
|
|
sizer->Add(m_infoBarSimple, wxSizerFlags().Expand());
|
|
sizer->Add(m_canvas, wxSizerFlags(1).Expand());
|
|
sizer->Add(m_infoBarAdvanced, wxSizerFlags().Expand());
|
|
SetSizer(sizer);
|
|
|
|
// final touch: under MSW the info bars are shown progressively and parts
|
|
// of the parent window can be seen during the process, so use the same
|
|
// background colour for our background as for the canvas window which
|
|
// covers our entire client area to avoid jarring colour jumps
|
|
SetOwnBackgroundColour(m_canvas->GetBackgroundColour());
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
#ifdef __WXMSW__
|
|
// Test MSW-specific function allowing to access the "system" menu.
|
|
wxMenu * const menu = MSWGetSystemMenu();
|
|
if ( menu )
|
|
{
|
|
menu->AppendSeparator();
|
|
|
|
// The ids of the menu commands in MSW system menu must be multiple of
|
|
// 16 so we can't use DIALOGS_ABOUTDLG_SIMPLE here because it might not
|
|
// satisfy this condition and need to define and connect a separate id.
|
|
static const int DIALOGS_SYSTEM_ABOUT = 0x4010;
|
|
|
|
menu->Append(DIALOGS_SYSTEM_ABOUT, "&About");
|
|
Connect(DIALOGS_SYSTEM_ABOUT, wxEVT_MENU,
|
|
wxCommandEventHandler(MyFrame::ShowSimpleAboutDialog));
|
|
}
|
|
#endif // __WXMSW__
|
|
}
|
|
|
|
MyFrame::~MyFrame()
|
|
{
|
|
#if wxUSE_NOTIFICATION_MESSAGE
|
|
delete m_notifMsg;
|
|
#endif // wxUSE_NOTIFICATION_MESSAGE
|
|
}
|
|
|
|
#if wxUSE_COLOURDLG
|
|
|
|
void MyFrame::ChooseColour(wxCommandEvent& event)
|
|
{
|
|
m_clrData.SetColour(m_canvas->GetBackgroundColour());
|
|
m_clrData.SetChooseAlpha(event.GetId() == DIALOGS_CHOOSE_COLOUR_ALPHA);
|
|
|
|
wxColourDialog dialog(this, &m_clrData);
|
|
dialog.SetTitle(_("Please choose the background colour"));
|
|
if ( dialog.ShowModal() == wxID_OK )
|
|
{
|
|
m_clrData = dialog.GetColourData();
|
|
m_canvas->SetBackgroundColour(m_clrData.GetColour());
|
|
m_canvas->ClearBackground();
|
|
m_canvas->Refresh();
|
|
}
|
|
}
|
|
|
|
void MyFrame::GetColour(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxColour clr = wxGetColourFromUser
|
|
(
|
|
this,
|
|
m_canvas->GetForegroundColour(),
|
|
"Please choose the foreground colour"
|
|
);
|
|
if ( clr.IsOk() )
|
|
{
|
|
m_canvas->SetForegroundColour(clr);
|
|
m_canvas->Refresh();
|
|
}
|
|
//else: dialog cancelled by user
|
|
}
|
|
|
|
#endif // wxUSE_COLOURDLG
|
|
|
|
|
|
#if USE_COLOURDLG_GENERIC
|
|
void MyFrame::ChooseColourGeneric(wxCommandEvent& event)
|
|
{
|
|
m_clrData.SetColour(m_canvas->GetBackgroundColour());
|
|
|
|
//FIXME:TODO:This has no effect...
|
|
m_clrData.SetChooseFull(true);
|
|
m_clrData.SetChooseAlpha(event.GetId() == DIALOGS_CHOOSE_COLOUR_GENERIC_ALPHA);
|
|
|
|
for (int i = 0; i < wxColourData::NUM_CUSTOM; i++)
|
|
{
|
|
unsigned char n = i*(256/wxColourData::NUM_CUSTOM);
|
|
m_clrData.SetCustomColour(i, wxColour(n, n, n));
|
|
}
|
|
|
|
wxGenericColourDialog *dialog = new wxGenericColourDialog(this, &m_clrData);
|
|
if (dialog->ShowModal() == wxID_OK)
|
|
{
|
|
m_clrData = dialog->GetColourData();
|
|
m_canvas->SetBackgroundColour(m_clrData.GetColour());
|
|
m_canvas->ClearBackground();
|
|
m_canvas->Refresh();
|
|
}
|
|
dialog->Destroy();
|
|
}
|
|
#endif // USE_COLOURDLG_GENERIC
|
|
|
|
#if wxUSE_FONTDLG
|
|
void MyFrame::ChooseFont(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxFontData data;
|
|
data.SetInitialFont(m_canvas->GetFont());
|
|
data.SetColour(m_canvas->GetForegroundColour());
|
|
|
|
// you might also do this:
|
|
//
|
|
// wxFontDialog dialog;
|
|
// if ( !dialog.Create(this, data) { ... error ... }
|
|
//
|
|
wxFontDialog dialog(this, data);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxFontData retData = dialog.GetFontData();
|
|
m_canvas->SetFont(retData.GetChosenFont());
|
|
m_canvas->SetForegroundColour(retData.GetColour());
|
|
m_canvas->Refresh();
|
|
}
|
|
//else: cancelled by the user, don't change the font
|
|
}
|
|
#endif // wxUSE_FONTDLG
|
|
|
|
#if USE_FONTDLG_GENERIC
|
|
void MyFrame::ChooseFontGeneric(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxFontData data;
|
|
data.SetInitialFont(m_canvas->GetFont());
|
|
data.SetColour(m_canvas->GetForegroundColour());
|
|
|
|
wxGenericFontDialog *dialog = new wxGenericFontDialog(this, data);
|
|
if (dialog->ShowModal() == wxID_OK)
|
|
{
|
|
wxFontData retData = dialog->GetFontData();
|
|
m_canvas->SetFont(retData.GetChosenFont());
|
|
m_canvas->SetForegroundColour(retData.GetColour());
|
|
m_canvas->Refresh();
|
|
}
|
|
dialog->Destroy();
|
|
}
|
|
#endif // USE_FONTDLG_GENERIC
|
|
|
|
#if wxUSE_LOG_DIALOG
|
|
void MyFrame::LogDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
// calling wxYield() (as ~wxBusyCursor does) shouldn't result in messages
|
|
// being flushed -- test it
|
|
{
|
|
wxBusyCursor bc;
|
|
wxLogMessage(wxT("This is some message - everything is ok so far."));
|
|
wxLogMessage(wxT("Another message...\n... this one is on multiple lines"));
|
|
wxLogWarning(wxT("And then something went wrong!"));
|
|
|
|
// and if ~wxBusyCursor doesn't do it, then call it manually
|
|
wxYield();
|
|
}
|
|
|
|
wxLogError(wxT("Intermediary error handler decided to abort."));
|
|
wxLogError(wxT("The top level caller detected an unrecoverable error."));
|
|
|
|
wxLog::FlushActive();
|
|
|
|
wxLogMessage(wxT("And this is the same dialog but with only one message."));
|
|
}
|
|
#endif // wxUSE_LOG_DIALOG
|
|
|
|
#if wxUSE_INFOBAR
|
|
|
|
void MyFrame::InfoBarSimple(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
static int s_count = 0;
|
|
m_infoBarSimple->ShowMessage
|
|
(
|
|
wxString::Format("Message #%d in the info bar.", ++s_count)
|
|
);
|
|
}
|
|
|
|
void MyFrame::InfoBarAdvanced(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
m_infoBarAdvanced->ShowMessage("Sorry, it didn't work out.", wxICON_WARNING);
|
|
}
|
|
|
|
void MyFrame::OnInfoBarRedo(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
m_infoBarAdvanced->ShowMessage("Still no, sorry again.", wxICON_ERROR);
|
|
}
|
|
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
|
|
#if wxUSE_MSGDLG
|
|
void MyFrame::MessageBox(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxMessageDialog dialog(this,
|
|
"This is a message box\n"
|
|
"This is a long, long string to test out if the message box "
|
|
"is laid out properly.",
|
|
"Message box text",
|
|
wxCENTER |
|
|
wxNO_DEFAULT | wxYES_NO | wxCANCEL |
|
|
wxICON_INFORMATION);
|
|
|
|
wxString extmsg;
|
|
if ( dialog.SetYesNoCancelLabels
|
|
(
|
|
"Answer &Yes",
|
|
"Answer &No",
|
|
"Refuse to answer"
|
|
) )
|
|
{
|
|
extmsg = "This platform supports custom button labels,\n"
|
|
"so you should see the descriptive labels below.";
|
|
}
|
|
else
|
|
{
|
|
extmsg = "Custom button labels are not supported on this platform,\n"
|
|
"so the default \"Yes\"/\"No\"/\"Cancel\" buttons are used.";
|
|
}
|
|
dialog.SetExtendedMessage(extmsg);
|
|
|
|
switch ( dialog.ShowModal() )
|
|
{
|
|
case wxID_YES:
|
|
wxLogStatus(wxT("You pressed \"Yes\""));
|
|
break;
|
|
|
|
case wxID_NO:
|
|
wxLogStatus(wxT("You pressed \"No\""));
|
|
break;
|
|
|
|
case wxID_CANCEL:
|
|
wxLogStatus(wxT("You pressed \"Cancel\""));
|
|
break;
|
|
|
|
default:
|
|
wxLogError(wxT("Unexpected wxMessageDialog return code!"));
|
|
}
|
|
}
|
|
|
|
void MyFrame::MessageBoxWindowModal(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxMessageDialog* dialog = new wxMessageDialog(this,
|
|
"This is a message box\n"
|
|
"This is a long, long string to test out if the message box "
|
|
"is laid out properly.",
|
|
"Message box text",
|
|
wxCENTER |
|
|
wxNO_DEFAULT | wxYES_NO | wxCANCEL |
|
|
wxICON_INFORMATION);
|
|
|
|
wxString extmsg;
|
|
if ( dialog->SetYesNoCancelLabels
|
|
(
|
|
"Answer &Yes",
|
|
"Answer &No",
|
|
"Refuse to answer"
|
|
) )
|
|
{
|
|
extmsg = "This platform supports custom button labels,\n"
|
|
"so you should see the descriptive labels below.";
|
|
}
|
|
else
|
|
{
|
|
extmsg = "Custom button labels are not supported on this platform,\n"
|
|
"so the default \"Yes\"/\"No\"/\"Cancel\" buttons are used.";
|
|
}
|
|
dialog->SetExtendedMessage(extmsg);
|
|
dialog->Connect( wxEVT_WINDOW_MODAL_DIALOG_CLOSED, wxWindowModalDialogEventHandler(MyFrame::MessageBoxWindowModalClosed), NULL, this );
|
|
dialog->ShowWindowModal();
|
|
}
|
|
|
|
void MyFrame::MessageBoxWindowModalClosed(wxWindowModalDialogEvent& event)
|
|
{
|
|
wxDialog* dialog = event.GetDialog();
|
|
switch ( dialog->GetReturnCode() )
|
|
{
|
|
case wxID_YES:
|
|
wxLogStatus(wxT("You pressed \"Yes\""));
|
|
break;
|
|
|
|
case wxID_NO:
|
|
wxLogStatus(wxT("You pressed \"No\""));
|
|
break;
|
|
|
|
case wxID_CANCEL:
|
|
wxLogStatus(wxT("You pressed \"Cancel\""));
|
|
break;
|
|
|
|
default:
|
|
wxLogError(wxT("Unexpected wxMessageDialog return code!"));
|
|
}
|
|
delete dialog;
|
|
}
|
|
|
|
void MyFrame::MessageBoxDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
TestMessageBoxDialog dlg(this);
|
|
dlg.Create();
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
void MyFrame::MessageBoxInfo(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
::wxInfoMessageBox(this);
|
|
}
|
|
#endif // wxUSE_MSGDLG
|
|
|
|
#if wxUSE_RICHMSGDLG
|
|
void MyFrame::RichMessageDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
TestRichMessageDialog dlg(this);
|
|
dlg.Create();
|
|
dlg.ShowModal();
|
|
}
|
|
#endif // wxUSE_RICHMSGDLG
|
|
|
|
#if wxUSE_NUMBERDLG
|
|
void MyFrame::NumericEntry(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
long res = wxGetNumberFromUser( wxT("This is some text, actually a lot of text.\n")
|
|
wxT("Even two rows of text."),
|
|
wxT("Enter a number:"), wxT("Numeric input test"),
|
|
50, 0, 100, this );
|
|
|
|
wxString msg;
|
|
int icon;
|
|
if ( res == -1 )
|
|
{
|
|
msg = wxT("Invalid number entered or dialog cancelled.");
|
|
icon = wxICON_HAND;
|
|
}
|
|
else
|
|
{
|
|
msg.Printf(wxT("You've entered %lu"), res );
|
|
icon = wxICON_INFORMATION;
|
|
}
|
|
|
|
wxMessageBox(msg, wxT("Numeric test result"), wxOK | icon, this);
|
|
}
|
|
#endif // wxUSE_NUMBERDLG
|
|
|
|
#if wxUSE_TEXTDLG
|
|
void MyFrame::PasswordEntry(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxString pwd = wxGetPasswordFromUser(wxT("Enter password:"),
|
|
wxT("Password entry dialog"),
|
|
wxEmptyString,
|
|
this);
|
|
if ( !pwd.empty() )
|
|
{
|
|
wxMessageBox(wxString::Format(wxT("Your password is '%s'"), pwd.c_str()),
|
|
wxT("Got password"), wxOK | wxICON_INFORMATION, this);
|
|
}
|
|
}
|
|
|
|
void MyFrame::LineEntry(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxTextEntryDialog dialog(this,
|
|
wxT("This is a small sample\n")
|
|
wxT("A long, long string to test out the text entrybox"),
|
|
wxT("Please enter a string"),
|
|
wxT("Default value"),
|
|
wxOK | wxCANCEL);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxMessageBox(dialog.GetValue(), wxT("Got string"), wxOK | wxICON_INFORMATION, this);
|
|
}
|
|
}
|
|
|
|
void MyFrame::TextEntry(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxTextEntryDialog dialog(this, "You can enter a multiline string here.",
|
|
"Please enter some text",
|
|
"First line\nSecond one\nAnd another one too",
|
|
wxOK | wxCANCEL | wxTE_MULTILINE);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxMessageBox(dialog.GetValue(), wxT("Got text"), wxOK | wxICON_INFORMATION, this);
|
|
}
|
|
}
|
|
#endif // wxUSE_TEXTDLG
|
|
|
|
#if wxUSE_CHOICEDLG
|
|
void MyFrame::SingleChoice(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
const wxString choices[] = { wxT("One"), wxT("Two"), wxT("Three"), wxT("Four"), wxT("Five") } ;
|
|
|
|
wxSingleChoiceDialog dialog(this,
|
|
wxT("This is a small sample\n")
|
|
wxT("A single-choice convenience dialog"),
|
|
wxT("Please select a value"),
|
|
WXSIZEOF(choices), choices);
|
|
|
|
dialog.SetSelection(2);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxMessageDialog dialog2(this, dialog.GetStringSelection(), wxT("Got string"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
|
|
void MyFrame::MultiChoice(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
const wxString choices[] =
|
|
{
|
|
wxT("One"), wxT("Two"), wxT("Three"), wxT("Four"), wxT("Five"),
|
|
wxT("Six"), wxT("Seven"), wxT("Eight"), wxT("Nine"), wxT("Ten"),
|
|
wxT("Eleven"), wxT("Twelve"), wxT("Seventeen"),
|
|
};
|
|
|
|
wxArrayInt selections;
|
|
const int count = wxGetSelectedChoices(selections,
|
|
wxT("This is a small sample\n")
|
|
wxT("A multi-choice convenience dialog"),
|
|
wxT("Please select a value"),
|
|
WXSIZEOF(choices), choices,
|
|
this);
|
|
if ( count >= 0 )
|
|
{
|
|
wxString msg;
|
|
if ( count == 0 )
|
|
{
|
|
msg = wxT("You did not select any items");
|
|
}
|
|
else
|
|
{
|
|
msg.Printf(wxT("You selected %u items:\n"), (unsigned)count);
|
|
for ( int n = 0; n < count; n++ )
|
|
{
|
|
msg += wxString::Format(wxT("\t%u: %u (%s)\n"),
|
|
(unsigned)n, (unsigned)selections[n],
|
|
choices[selections[n]].c_str());
|
|
}
|
|
}
|
|
wxLogMessage(msg);
|
|
}
|
|
//else: cancelled
|
|
}
|
|
#endif // wxUSE_CHOICEDLG
|
|
|
|
#if wxUSE_REARRANGECTRL
|
|
// custom rearrange dialog: it adds the possibility to rename an item to the
|
|
// base class functionality
|
|
class MyRearrangeDialog : public wxRearrangeDialog
|
|
{
|
|
public:
|
|
MyRearrangeDialog(wxWindow *parent,
|
|
wxArrayInt& order,
|
|
wxArrayString& labels,
|
|
wxArrayString& labelsOrig)
|
|
: wxRearrangeDialog
|
|
(
|
|
parent,
|
|
"Configure the columns shown:",
|
|
"wxRearrangeDialog example",
|
|
order,
|
|
labels
|
|
),
|
|
m_order(order),
|
|
m_labels(labels),
|
|
m_labelsOrig(labelsOrig)
|
|
{
|
|
m_sel = wxNOT_FOUND;
|
|
|
|
wxPanel * const panel = new wxPanel(this);
|
|
wxSizer * const sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
|
|
m_labelOrig = new wxStaticText(panel, wxID_ANY, "");
|
|
sizer->Add(m_labelOrig, wxSizerFlags().Centre().Border(wxRIGHT));
|
|
|
|
m_text = new wxTextCtrl(panel, wxID_ANY, "",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxTE_PROCESS_ENTER);
|
|
sizer->Add(m_text, wxSizerFlags().Centre().Border(wxRIGHT));
|
|
|
|
sizer->Add(new wxButton(panel, wxID_APPLY, "&Rename"),
|
|
wxSizerFlags().Centre());
|
|
|
|
panel->SetSizer(sizer);
|
|
|
|
// call this first to ensure that the controls have a reasonable best
|
|
// size before they're added
|
|
DoUpdateExtraControls(GetList()->GetSelection());
|
|
|
|
AddExtraControls(panel);
|
|
|
|
|
|
// another customization not directly supported by the dialog: add a
|
|
// custom button
|
|
wxWindow * const btnOk = FindWindow(wxID_OK);
|
|
wxCHECK_RET( btnOk, "no Ok button?" );
|
|
|
|
wxSizer * const sizerBtns = btnOk->GetContainingSizer();
|
|
wxCHECK_RET( sizerBtns, "no buttons sizer?" );
|
|
|
|
sizerBtns->Add(new wxButton(this, wxID_RESET, "&Reset all"),
|
|
wxSizerFlags().Border(wxLEFT));
|
|
}
|
|
|
|
// call this instead of ShowModal() to update order and labels array in
|
|
// case the dialog was not cancelled
|
|
bool Rearrange()
|
|
{
|
|
switch ( ShowModal() )
|
|
{
|
|
case wxID_CANCEL:
|
|
return false;
|
|
|
|
case wxID_OK:
|
|
m_order = GetOrder();
|
|
break;
|
|
|
|
case wxID_RESET:
|
|
// order already reset
|
|
break;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
private:
|
|
void OnSelChange(wxCommandEvent& event)
|
|
{
|
|
DoUpdateExtraControls(event.GetInt());
|
|
}
|
|
|
|
void OnUpdateUIRename(wxUpdateUIEvent& event)
|
|
{
|
|
event.Enable( CanRename() );
|
|
}
|
|
|
|
void OnRename(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
if ( !CanRename() )
|
|
return;
|
|
|
|
m_labels[m_sel] = m_text->GetValue();
|
|
GetList()->SetString(m_sel, m_labels[m_sel]);
|
|
}
|
|
|
|
void OnReset(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
// in a real program we should probably ask if the user really wants to
|
|
// do this but here we just go ahead and reset all columns labels and
|
|
// their order without confirmation
|
|
const unsigned count = m_order.size();
|
|
for ( unsigned n = 0; n < count; n++ )
|
|
{
|
|
m_order[n] = n;
|
|
m_labels[n] = m_labelsOrig[n];
|
|
}
|
|
|
|
EndModal(wxID_RESET);
|
|
}
|
|
|
|
bool CanRename() const
|
|
{
|
|
// only allow renaming if the user modified the currently selected item
|
|
// text (which presupposes that we do have a current item)
|
|
return m_sel != wxNOT_FOUND && m_text->GetValue() != m_labels[m_sel];
|
|
}
|
|
|
|
void DoUpdateExtraControls(int sel)
|
|
{
|
|
m_sel = sel;
|
|
|
|
if ( m_sel == wxNOT_FOUND )
|
|
{
|
|
m_labelOrig->SetLabel("<no selection>");
|
|
m_text->Clear();
|
|
m_text->Disable();
|
|
}
|
|
else // have valid item
|
|
{
|
|
m_labelOrig->SetLabelText(m_labelsOrig[m_sel]);
|
|
m_text->Enable();
|
|
m_text->SetValue(m_labels[m_sel]);
|
|
}
|
|
}
|
|
|
|
wxArrayInt& m_order;
|
|
wxArrayString& m_labels,
|
|
m_labelsOrig;
|
|
|
|
int m_sel;
|
|
wxStaticText *m_labelOrig;
|
|
wxTextCtrl *m_text;
|
|
|
|
wxDECLARE_EVENT_TABLE();
|
|
wxDECLARE_NO_COPY_CLASS(MyRearrangeDialog);
|
|
};
|
|
|
|
wxBEGIN_EVENT_TABLE(MyRearrangeDialog, wxRearrangeDialog)
|
|
EVT_LISTBOX(wxID_ANY, MyRearrangeDialog::OnSelChange)
|
|
|
|
EVT_UPDATE_UI(wxID_APPLY, MyRearrangeDialog::OnUpdateUIRename)
|
|
|
|
EVT_TEXT_ENTER(wxID_ANY, MyRearrangeDialog::OnRename)
|
|
EVT_BUTTON(wxID_APPLY, MyRearrangeDialog::OnRename)
|
|
EVT_BUTTON(wxID_RESET, MyRearrangeDialog::OnReset)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
void MyFrame::Rearrange(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
// the arrays are static so that we preserve the items order between calls
|
|
// to this function
|
|
static wxArrayInt s_order;
|
|
static wxArrayString s_labels,
|
|
s_labelsOrig;
|
|
|
|
// initialize them on the first call
|
|
if ( s_labelsOrig.empty() )
|
|
{
|
|
static const struct ItemInfo
|
|
{
|
|
const char *label;
|
|
const char *labelOrig;
|
|
int order;
|
|
} items[] =
|
|
{
|
|
{ "File name", "Name", 0 },
|
|
{ "File type", "Ext", 1 },
|
|
{ "Size", "Size", 2 },
|
|
{ "Creation time", "Ctime", ~3 }, // negated so hidden
|
|
{ "Last accessed", "Atime", ~4 },
|
|
{ "Last modified", "Mtime", 5 },
|
|
};
|
|
|
|
s_order.reserve(WXSIZEOF(items));
|
|
s_labels.reserve(WXSIZEOF(items));
|
|
s_labelsOrig.reserve(WXSIZEOF(items));
|
|
for ( unsigned n = 0; n < WXSIZEOF(items); n++ )
|
|
{
|
|
const ItemInfo& item = items[n];
|
|
s_order.push_back(item.order);
|
|
s_labels.push_back(item.label);
|
|
s_labelsOrig.push_back(item.labelOrig);
|
|
}
|
|
}
|
|
|
|
MyRearrangeDialog dlg(this, s_order, s_labels, s_labelsOrig);
|
|
if ( !dlg.Rearrange() )
|
|
return;
|
|
|
|
wxString columns;
|
|
for ( unsigned n = 0; n < s_order.size(); n++ )
|
|
{
|
|
columns += wxString::Format("\n %u: ", n);
|
|
int idx = s_order[n];
|
|
if ( idx < 0 )
|
|
{
|
|
columns += "[hidden] ";
|
|
idx = ~idx;
|
|
}
|
|
|
|
columns += s_labels[idx];
|
|
if ( s_labels[idx] != s_labelsOrig[idx] )
|
|
{
|
|
columns += wxString::Format(" (original label: \"%s\")",
|
|
s_labelsOrig[idx]);
|
|
}
|
|
}
|
|
|
|
wxLogMessage("The columns order now is:%s", columns);
|
|
}
|
|
#endif // wxUSE_REARRANGECTRL
|
|
|
|
#if wxUSE_ADDREMOVECTRL
|
|
|
|
void MyFrame::AddRemove(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxDialog dlg(this, wxID_ANY, "wxAddRemoveCtrl test",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER);
|
|
|
|
wxAddRemoveCtrl* const ctrl = new wxAddRemoveCtrl(&dlg);
|
|
ctrl->SetInitialSize(wxSize(-1, 12*GetCharHeight()));
|
|
|
|
const wxString items[] =
|
|
{
|
|
"some", "items", "for", "testing", "wxAddRemoveCtrl",
|
|
};
|
|
wxListBox* const lbox = new wxListBox(ctrl, wxID_ANY,
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(items), items);
|
|
|
|
// Test adaptor class connecting wxAddRemoveCtrl with wxListBox we use
|
|
// inside it.
|
|
class ListBoxAdaptor : public wxAddRemoveAdaptor
|
|
{
|
|
public:
|
|
wxEXPLICIT ListBoxAdaptor(wxListBox* lbox)
|
|
: m_lbox(lbox)
|
|
{
|
|
}
|
|
|
|
wxWindow* GetItemsCtrl() const wxOVERRIDE
|
|
{
|
|
return m_lbox;
|
|
}
|
|
|
|
bool CanAdd() const wxOVERRIDE
|
|
{
|
|
// Restrict the maximal number of items to 10 just for testing.
|
|
return m_lbox->GetCount() <= 10;
|
|
}
|
|
|
|
bool CanRemove() const wxOVERRIDE
|
|
{
|
|
// We must have a selected item in order to be able to delete it.
|
|
return m_lbox->GetSelection() != wxNOT_FOUND;
|
|
}
|
|
|
|
void OnAdd() wxOVERRIDE
|
|
{
|
|
// A real program would use a wxDataViewCtrl or wxListCtrl and
|
|
// allow editing the newly edited item in place, here we just use a
|
|
// hardcoded item value instead.
|
|
static int s_item = 0;
|
|
m_lbox->Append(wxString::Format("new item #%d", ++s_item));
|
|
}
|
|
|
|
void OnRemove() wxOVERRIDE
|
|
{
|
|
// Notice that we don't need to check if we have a valid selection,
|
|
// we can be only called if CanRemove(), which already checks for
|
|
// this, had returned true.
|
|
const unsigned pos = m_lbox->GetSelection();
|
|
|
|
m_lbox->Delete(pos);
|
|
m_lbox->SetSelection(pos == m_lbox->GetCount() ? pos - 1 : pos);
|
|
}
|
|
|
|
private:
|
|
wxListBox* const m_lbox;
|
|
};
|
|
|
|
ctrl->SetAdaptor(new ListBoxAdaptor(lbox));
|
|
|
|
ctrl->SetButtonsToolTips("Add up to 10 items", "Remove current item");
|
|
|
|
wxSizer* const sizerTop = new wxBoxSizer(wxVERTICAL);
|
|
sizerTop->Add(ctrl, wxSizerFlags(1).Expand().Border());
|
|
sizerTop->Add(dlg.CreateStdDialogButtonSizer(wxOK | wxCANCEL),
|
|
wxSizerFlags().Expand().Border());
|
|
dlg.SetSizerAndFit(sizerTop);
|
|
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
#endif // wxUSE_ADDREMOVECTRL
|
|
|
|
#if wxUSE_FILEDLG
|
|
|
|
// panel with custom controls for file dialog
|
|
class MyExtraPanel : public wxPanel
|
|
{
|
|
public:
|
|
MyExtraPanel(wxWindow *parent);
|
|
wxString GetInfo() const
|
|
{
|
|
return wxString::Format("checkbox=%d, text=\"%s\"", m_checked, m_str);
|
|
}
|
|
|
|
private:
|
|
void OnCheckBox(wxCommandEvent& event)
|
|
{
|
|
m_checked = event.IsChecked();
|
|
m_btn->Enable(m_checked);
|
|
}
|
|
|
|
void OnText(wxCommandEvent& event)
|
|
{
|
|
m_str = event.GetString();
|
|
}
|
|
|
|
void OnUpdateLabelUI(wxUpdateUIEvent& event)
|
|
{
|
|
wxFileDialog* const dialog = wxStaticCast(GetParent(), wxFileDialog);
|
|
const wxString fn = dialog->GetCurrentlySelectedFilename();
|
|
|
|
wxString msg;
|
|
if ( fn.empty() )
|
|
msg = "Nothing";
|
|
else if ( wxFileName::FileExists(fn) )
|
|
msg = "File";
|
|
else if ( wxFileName::DirExists(fn) )
|
|
msg = "Directory";
|
|
else
|
|
msg = "Something else";
|
|
|
|
event.SetText(msg + " selected");
|
|
}
|
|
|
|
wxString m_str;
|
|
bool m_checked;
|
|
|
|
wxButton *m_btn;
|
|
wxCheckBox *m_cb;
|
|
wxStaticText *m_label;
|
|
wxTextCtrl *m_text;
|
|
};
|
|
|
|
MyExtraPanel::MyExtraPanel(wxWindow *parent)
|
|
: wxPanel(parent),
|
|
m_str("extra text"),
|
|
m_checked(false)
|
|
{
|
|
m_btn = new wxButton(this, -1, wxT("Custom Button"));
|
|
m_btn->Enable(false);
|
|
m_cb = new wxCheckBox(this, -1, wxT("Enable Custom Button"));
|
|
m_cb->Connect(wxEVT_CHECKBOX,
|
|
wxCommandEventHandler(MyExtraPanel::OnCheckBox), NULL, this);
|
|
m_label = new wxStaticText(this, wxID_ANY, "Nothing selected");
|
|
m_label->Connect(wxEVT_UPDATE_UI,
|
|
wxUpdateUIEventHandler(MyExtraPanel::OnUpdateLabelUI),
|
|
NULL, this);
|
|
|
|
m_text = new wxTextCtrl(this, -1, m_str,
|
|
wxDefaultPosition, wxSize(40*GetCharWidth(), -1));
|
|
m_text->Bind(wxEVT_TEXT, &MyExtraPanel::OnText, this);
|
|
|
|
wxBoxSizer *sizerTop = new wxBoxSizer(wxHORIZONTAL);
|
|
sizerTop->Add(new wxStaticText(this, wxID_ANY, "Just some extra text:"),
|
|
wxSizerFlags().Centre().Border());
|
|
sizerTop->Add(m_text, wxSizerFlags(1).Centre().Border());
|
|
sizerTop->AddSpacer(10);
|
|
sizerTop->Add(m_cb, wxSizerFlags().Centre().Border());
|
|
sizerTop->AddSpacer(5);
|
|
sizerTop->Add(m_btn, wxSizerFlags().Centre().Border());
|
|
sizerTop->AddSpacer(5);
|
|
sizerTop->Add(m_label, wxSizerFlags().Centre().Border());
|
|
|
|
SetSizerAndFit(sizerTop);
|
|
}
|
|
|
|
// a static method can be used instead of a function with most of compilers
|
|
static wxWindow* createMyExtraPanel(wxWindow *parent)
|
|
{
|
|
return new MyExtraPanel(parent);
|
|
}
|
|
|
|
void MyFrame::FileOpen(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxFileDialog dialog
|
|
(
|
|
this,
|
|
wxT("Testing open file dialog"),
|
|
wxEmptyString,
|
|
wxEmptyString,
|
|
#ifdef __WXMOTIF__
|
|
wxT("C++ files (*.cpp)|*.cpp")
|
|
#else
|
|
wxT("C++ files (*.cpp;*.h)|*.cpp;*.h")
|
|
#endif
|
|
);
|
|
|
|
dialog.SetExtraControlCreator(&createMyExtraPanel);
|
|
dialog.CentreOnParent();
|
|
dialog.SetDirectory(wxGetHomeDir());
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxString info;
|
|
wxWindow * const extra = dialog.GetExtraControl();
|
|
info.Printf(wxT("Full file name: %s\n")
|
|
wxT("Path: %s\n")
|
|
wxT("Name: %s\n")
|
|
wxT("Custom window: %s"),
|
|
dialog.GetPath().c_str(),
|
|
dialog.GetDirectory().c_str(),
|
|
dialog.GetFilename().c_str(),
|
|
extra ? static_cast<MyExtraPanel*>(extra)->GetInfo()
|
|
: wxString("None"));
|
|
wxMessageDialog dialog2(this, info, wxT("Selected file"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
|
|
// this shows how to take advantage of specifying a default extension in the
|
|
// call to wxFileSelector: it is remembered after each new call and the next
|
|
// one will use it by default
|
|
void MyFrame::FileOpen2(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
static wxString s_extDef;
|
|
wxString path = wxFileSelector(
|
|
wxT("Select the file to load"),
|
|
wxEmptyString, wxEmptyString,
|
|
s_extDef,
|
|
wxString::Format
|
|
(
|
|
wxT("Waveform (*.wav)|*.wav|Plain text (*.txt)|*.txt|All files (%s)|%s"),
|
|
wxFileSelectorDefaultWildcardStr,
|
|
wxFileSelectorDefaultWildcardStr
|
|
),
|
|
wxFD_OPEN|wxFD_CHANGE_DIR|wxFD_PREVIEW|wxFD_NO_FOLLOW,
|
|
this
|
|
);
|
|
|
|
if ( !path )
|
|
return;
|
|
|
|
// it is just a sample, would use wxSplitPath in real program
|
|
s_extDef = path.AfterLast(wxT('.'));
|
|
|
|
wxLogMessage(wxT("You selected the file '%s', remembered extension '%s'"),
|
|
path, s_extDef);
|
|
}
|
|
|
|
void MyFrame::FilesOpen(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxString wildcards =
|
|
#ifdef __WXMOTIF__
|
|
wxT("C++ files (*.cpp)|*.cpp");
|
|
#else
|
|
wxString::Format
|
|
(
|
|
wxT("All files (%s)|%s|C++ files (*.cpp;*.h)|*.cpp;*.h"),
|
|
wxFileSelectorDefaultWildcardStr,
|
|
wxFileSelectorDefaultWildcardStr
|
|
);
|
|
#endif
|
|
wxFileDialog dialog(this, wxT("Testing open multiple file dialog"),
|
|
wxEmptyString, wxEmptyString, wildcards,
|
|
wxFD_OPEN|wxFD_MULTIPLE);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxArrayString paths, filenames;
|
|
|
|
dialog.GetPaths(paths);
|
|
dialog.GetFilenames(filenames);
|
|
|
|
wxString msg, s;
|
|
size_t count = paths.GetCount();
|
|
for ( size_t n = 0; n < count; n++ )
|
|
{
|
|
s.Printf(wxT("File %d: %s (%s)\n"),
|
|
(int)n, paths[n].c_str(), filenames[n].c_str());
|
|
|
|
msg += s;
|
|
}
|
|
s.Printf(wxT("Filter index: %d"), dialog.GetFilterIndex());
|
|
msg += s;
|
|
|
|
wxMessageDialog dialog2(this, msg, wxT("Selected files"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
|
|
void MyFrame::FileSave(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxFileDialog dialog(this,
|
|
wxT("Testing save file dialog"),
|
|
wxEmptyString,
|
|
wxT("myletter.doc"),
|
|
wxT("Text files (*.txt)|*.txt|Document files (*.doc;*.ods)|*.doc;*.ods"),
|
|
wxFD_SAVE|wxFD_OVERWRITE_PROMPT);
|
|
|
|
dialog.SetFilterIndex(1);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxLogMessage(wxT("%s, filter %d"),
|
|
dialog.GetPath().c_str(), dialog.GetFilterIndex());
|
|
}
|
|
}
|
|
#endif // wxUSE_FILEDLG
|
|
|
|
#if USE_FILEDLG_GENERIC
|
|
void MyFrame::FileOpenGeneric(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxGenericFileDialog dialog
|
|
(
|
|
this,
|
|
wxT("Testing open file dialog"),
|
|
wxEmptyString,
|
|
wxEmptyString,
|
|
wxT("C++ files (*.cpp;*.h)|*.cpp;*.h")
|
|
);
|
|
|
|
dialog.SetExtraControlCreator(&createMyExtraPanel);
|
|
dialog.SetDirectory(wxGetHomeDir());
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxString info;
|
|
info.Printf(wxT("Full file name: %s\n")
|
|
wxT("Path: %s\n")
|
|
wxT("Name: %s"),
|
|
dialog.GetPath().c_str(),
|
|
dialog.GetDirectory().c_str(),
|
|
dialog.GetFilename().c_str());
|
|
wxMessageDialog dialog2(this, info, wxT("Selected file"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
|
|
void MyFrame::FilesOpenGeneric(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxString wildcards = wxT("All files (*.*)|*.*|C++ files (*.cpp;*.h)|*.cpp;*.h");
|
|
wxGenericFileDialog dialog(this, wxT("Testing open multiple file dialog"),
|
|
wxEmptyString, wxEmptyString, wildcards,
|
|
wxFD_MULTIPLE);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxArrayString paths, filenames;
|
|
|
|
dialog.GetPaths(paths);
|
|
dialog.GetFilenames(filenames);
|
|
|
|
wxString msg, s;
|
|
size_t count = paths.GetCount();
|
|
for ( size_t n = 0; n < count; n++ )
|
|
{
|
|
s.Printf(wxT("File %d: %s (%s)\n"),
|
|
(int)n, paths[n].c_str(), filenames[n].c_str());
|
|
|
|
msg += s;
|
|
}
|
|
s.Printf(wxT("Filter index: %d"), dialog.GetFilterIndex());
|
|
msg += s;
|
|
|
|
wxMessageDialog dialog2(this, msg, wxT("Selected files"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
|
|
void MyFrame::FileSaveGeneric(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxGenericFileDialog dialog(this,
|
|
wxT("Testing save file dialog"),
|
|
wxEmptyString,
|
|
wxT("myletter.doc"),
|
|
wxT("Text files (*.txt)|*.txt|Document files (*.doc;*.ods)|*.doc;*.ods"),
|
|
wxFD_SAVE|wxFD_OVERWRITE_PROMPT);
|
|
|
|
dialog.SetFilterIndex(1);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxLogMessage(wxT("%s, filter %d"),
|
|
dialog.GetPath().c_str(), dialog.GetFilterIndex());
|
|
}
|
|
}
|
|
#endif // USE_FILEDLG_GENERIC
|
|
|
|
#if wxUSE_DIRDLG
|
|
void MyFrame::DoDirChoose(int style)
|
|
{
|
|
// pass some initial dir to wxDirDialog
|
|
wxString dirHome;
|
|
wxGetHomeDir(&dirHome);
|
|
|
|
wxDirDialog dialog(this, wxT("Testing directory picker"), dirHome, style);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxLogMessage(wxT("Selected path: %s"), dialog.GetPath().c_str());
|
|
}
|
|
}
|
|
|
|
void MyFrame::DirChoose(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
DoDirChoose(wxDD_DEFAULT_STYLE | wxDD_DIR_MUST_EXIST);
|
|
}
|
|
|
|
void MyFrame::DirChooseNew(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
DoDirChoose(wxDD_DEFAULT_STYLE & ~wxDD_DIR_MUST_EXIST);
|
|
}
|
|
#endif // wxUSE_DIRDLG
|
|
|
|
#if USE_DIRDLG_GENERIC
|
|
void MyFrame::GenericDirChoose(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
// pass some initial dir to wxDirDialog
|
|
wxString dirHome;
|
|
wxGetHomeDir(&dirHome);
|
|
|
|
wxGenericDirDialog dialog(this, wxT("Testing generic directory picker"), dirHome);
|
|
|
|
if (dialog.ShowModal() == wxID_OK)
|
|
{
|
|
wxMessageDialog dialog2(this, dialog.GetPath(), wxT("Selected path"));
|
|
dialog2.ShowModal();
|
|
}
|
|
}
|
|
#endif // USE_DIRDLG_GENERIC
|
|
|
|
#if USE_MODAL_PRESENTATION
|
|
void MyFrame::ModalDlg(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
MyModalDialog dlg(this);
|
|
dlg.ShowModal();
|
|
}
|
|
#endif // USE_MODAL_PRESENTATION
|
|
|
|
void MyFrame::ModelessDlg(wxCommandEvent& event)
|
|
{
|
|
bool show = GetMenuBar()->IsChecked(event.GetId());
|
|
|
|
if ( show )
|
|
{
|
|
if ( !m_dialog )
|
|
{
|
|
m_dialog = new MyModelessDialog(this);
|
|
}
|
|
|
|
m_dialog->Show(true);
|
|
}
|
|
else // hide
|
|
{
|
|
// If m_dialog is NULL, then possibly the system
|
|
// didn't report the checked menu item status correctly.
|
|
// It should be true just after the menu item was selected,
|
|
// if there was no modeless dialog yet.
|
|
|
|
wxASSERT( m_dialog != NULL );
|
|
if (m_dialog)
|
|
m_dialog->Hide();
|
|
}
|
|
}
|
|
|
|
void MyFrame::DlgCenteredScreen(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxDialog dlg(this, wxID_ANY, wxT("Dialog centered on screen"),
|
|
wxDefaultPosition, wxSize(200, 100));
|
|
(new wxButton(&dlg, wxID_OK, wxT("Close")))->Centre();
|
|
dlg.CentreOnScreen();
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
void MyFrame::DlgCenteredParent(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxDialog dlg(this, wxID_ANY, wxT("Dialog centered on parent"),
|
|
wxDefaultPosition, wxSize(200, 100));
|
|
(new wxButton(&dlg, wxID_OK, wxT("Close")))->Centre();
|
|
dlg.CentreOnParent();
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
#if wxUSE_MINIFRAME
|
|
void MyFrame::MiniFrame(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxFrame *frame = new wxMiniFrame(this, wxID_ANY, wxT("Mini frame"),
|
|
wxDefaultPosition, wxSize(300, 100),
|
|
wxCAPTION | wxCLOSE_BOX);
|
|
new wxStaticText(frame,
|
|
wxID_ANY,
|
|
wxT("Mini frames have slightly different appearance"),
|
|
wxPoint(5, 5));
|
|
new wxStaticText(frame,
|
|
wxID_ANY,
|
|
wxT("from the normal frames but that's the only difference."),
|
|
wxPoint(5, 25));
|
|
|
|
frame->CentreOnParent();
|
|
frame->Show();
|
|
}
|
|
#endif // wxUSE_MINIFRAME
|
|
|
|
void MyFrame::DlgOnTop(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxDialog dlg(this, wxID_ANY, wxT("Dialog staying on top of other windows"),
|
|
wxDefaultPosition, wxSize(300, 100),
|
|
wxDEFAULT_DIALOG_STYLE | wxSTAY_ON_TOP);
|
|
(new wxButton(&dlg, wxID_OK, wxT("Close")))->Centre();
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
#if wxUSE_STARTUP_TIPS
|
|
void MyFrame::ShowTip(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
static size_t s_index = (size_t)-1;
|
|
|
|
if ( s_index == (size_t)-1 )
|
|
{
|
|
srand(time(NULL));
|
|
|
|
// this is completely bogus, we don't know how many lines are there
|
|
// in the file, but who cares, it's a demo only...
|
|
s_index = rand() % 5;
|
|
}
|
|
|
|
wxTipProvider *tipProvider = wxCreateFileTipProvider(wxT("tips.txt"), s_index);
|
|
|
|
bool showAtStartup = wxShowTip(this, tipProvider);
|
|
|
|
if ( showAtStartup )
|
|
{
|
|
wxMessageBox(wxT("Will show tips on startup"), wxT("Tips dialog"),
|
|
wxOK | wxICON_INFORMATION, this);
|
|
}
|
|
|
|
s_index = tipProvider->GetCurrentTip();
|
|
delete tipProvider;
|
|
}
|
|
#endif // wxUSE_STARTUP_TIPS
|
|
|
|
#if USE_SETTINGS_DIALOG
|
|
void MyFrame::OnPropertySheet(wxCommandEvent& event)
|
|
{
|
|
SettingsDialog dialog(this, event.GetId());
|
|
dialog.ShowModal();
|
|
}
|
|
#endif // USE_SETTINGS_DIALOG
|
|
|
|
void MyFrame::OnRequestUserAttention(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxLogStatus(wxT("Sleeping for 3 seconds to allow you to switch to another window"));
|
|
|
|
wxSleep(3);
|
|
|
|
RequestUserAttention(wxUSER_ATTENTION_ERROR);
|
|
}
|
|
|
|
#if wxUSE_NOTIFICATION_MESSAGE
|
|
|
|
void MyFrame::OnNotifMsgAuto(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
// Notice that the notification remains shown even after the
|
|
// wxNotificationMessage object itself is destroyed so we can show simple
|
|
// notifications using temporary objects.
|
|
if ( !wxNotificationMessage
|
|
(
|
|
"Automatic Notification",
|
|
"Nothing important has happened\n"
|
|
"this notification will disappear soon."
|
|
).Show() )
|
|
{
|
|
wxLogStatus("Failed to show notification message");
|
|
}
|
|
|
|
// But it doesn't have to be a temporary, of course.
|
|
wxNotificationMessage n("Dummy Warning", "Example of a warning notification.");
|
|
n.SetFlags(wxICON_ERROR);
|
|
n.Show(5); // Just for testing, use 5 second delay.
|
|
}
|
|
|
|
void MyFrame::OnNotifMsgShow(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
if ( !m_notifMsg )
|
|
{
|
|
m_notifMsg = new wxNotificationMessage
|
|
(
|
|
"wxWidgets Manual Notification",
|
|
"You can hide this notification from the menu",
|
|
this
|
|
);
|
|
}
|
|
|
|
if ( !m_notifMsg->Show(wxNotificationMessage::Timeout_Never) )
|
|
{
|
|
wxLogStatus("Failed to show manual notification message");
|
|
}
|
|
}
|
|
|
|
void MyFrame::OnNotifMsgHide(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
if ( m_notifMsg && !m_notifMsg->Close() )
|
|
{
|
|
wxLogStatus("Failed to hide manual notification message");
|
|
}
|
|
}
|
|
|
|
#endif // wxUSE_NOTIFICATION_MESSAGE
|
|
|
|
#if wxUSE_RICHTOOLTIP
|
|
|
|
#include "wx/richtooltip.h"
|
|
|
|
#include "tip.xpm"
|
|
|
|
class RichTipDialog : public wxDialog
|
|
{
|
|
public:
|
|
RichTipDialog(wxWindow* parent)
|
|
: wxDialog(parent, wxID_ANY, "wxRichToolTip Test",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
|
|
{
|
|
// Create the controls.
|
|
m_textTitle = new wxTextCtrl(this, wxID_ANY, "Tooltip title");
|
|
m_textBody = new wxTextCtrl(this, wxID_ANY, "Main tooltip text\n"
|
|
"possibly on several\n"
|
|
"lines.",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxTE_MULTILINE);
|
|
wxButton* btnShowText = new wxButton(this, wxID_ANY, "Show for &text");
|
|
wxButton* btnShowBtn = new wxButton(this, wxID_ANY, "Show for &button");
|
|
|
|
const wxString icons[] =
|
|
{
|
|
"&None",
|
|
"&Information",
|
|
"&Warning",
|
|
"&Error",
|
|
"&Custom"
|
|
};
|
|
wxCOMPILE_TIME_ASSERT( WXSIZEOF(icons) == Icon_Max, IconMismatch );
|
|
m_icons = new wxRadioBox(this, wxID_ANY, "&Icon choice:",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(icons), icons,
|
|
1, wxRA_SPECIFY_ROWS);
|
|
m_icons->SetSelection(Icon_Info);
|
|
|
|
const wxString tipKinds[] =
|
|
{
|
|
"&None", "Top left", "Top", "Top right",
|
|
"Bottom left", "Bottom", "Bottom right", "&Auto"
|
|
};
|
|
m_tipKinds = new wxRadioBox(this, wxID_ANY, "Tip &kind:",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(tipKinds), tipKinds,
|
|
4, wxRA_SPECIFY_COLS);
|
|
m_tipKinds->SetSelection(wxTipKind_Auto);
|
|
|
|
const wxString bgStyles[] =
|
|
{
|
|
"&Default", "&Solid", "&Gradient",
|
|
};
|
|
wxCOMPILE_TIME_ASSERT( WXSIZEOF(bgStyles) == Bg_Max, BgMismatch );
|
|
m_bgStyles = new wxRadioBox(this, wxID_ANY, "Background style:",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(bgStyles), bgStyles,
|
|
1, wxRA_SPECIFY_ROWS);
|
|
|
|
const wxString timeouts[] = { "&None", "&Default (no delay)", "&3 seconds" };
|
|
wxCOMPILE_TIME_ASSERT( WXSIZEOF(timeouts) == Timeout_Max, TmMismatch );
|
|
m_timeouts = new wxRadioBox(this, wxID_ANY, "Timeout:",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(timeouts), timeouts,
|
|
1, wxRA_SPECIFY_ROWS);
|
|
m_timeouts->SetSelection(Timeout_Default);
|
|
m_timeDelay = new wxCheckBox(this, wxID_ANY, "Delay show" );
|
|
|
|
// Lay them out.
|
|
m_textBody->SetMinSize(wxSize(300, 200));
|
|
|
|
wxBoxSizer* const sizer = new wxBoxSizer(wxVERTICAL);
|
|
sizer->Add(m_textTitle, wxSizerFlags().Expand().Border());
|
|
sizer->Add(m_textBody, wxSizerFlags(1).Expand().Border());
|
|
sizer->Add(m_icons, wxSizerFlags().Expand().Border());
|
|
sizer->Add(m_tipKinds, wxSizerFlags().Centre().Border());
|
|
sizer->Add(m_bgStyles, wxSizerFlags().Centre().Border());
|
|
sizer->Add(m_timeouts, wxSizerFlags().Centre().Border());
|
|
sizer->Add(m_timeDelay, wxSizerFlags().Centre().Border());
|
|
wxBoxSizer* const sizerBtns = new wxBoxSizer(wxHORIZONTAL);
|
|
sizerBtns->Add(btnShowText, wxSizerFlags().Border(wxRIGHT));
|
|
sizerBtns->Add(btnShowBtn, wxSizerFlags().Border(wxLEFT));
|
|
sizer->Add(sizerBtns, wxSizerFlags().Centre().Border());
|
|
sizer->Add(CreateStdDialogButtonSizer(wxOK),
|
|
wxSizerFlags().Expand().Border());
|
|
SetSizerAndFit(sizer);
|
|
|
|
|
|
// And connect the event handlers.
|
|
btnShowText->Connect
|
|
(
|
|
wxEVT_BUTTON,
|
|
wxCommandEventHandler(RichTipDialog::OnShowTipForText),
|
|
NULL,
|
|
this
|
|
);
|
|
|
|
btnShowBtn->Connect
|
|
(
|
|
wxEVT_BUTTON,
|
|
wxCommandEventHandler(RichTipDialog::OnShowTipForBtn),
|
|
NULL,
|
|
this
|
|
);
|
|
}
|
|
|
|
private:
|
|
enum
|
|
{
|
|
Icon_None,
|
|
Icon_Info,
|
|
Icon_Warning,
|
|
Icon_Error,
|
|
Icon_Custom,
|
|
Icon_Max
|
|
};
|
|
|
|
enum
|
|
{
|
|
Bg_Default,
|
|
Bg_Solid,
|
|
Bg_Gradient,
|
|
Bg_Max
|
|
};
|
|
|
|
enum
|
|
{
|
|
Timeout_None,
|
|
Timeout_Default,
|
|
Timeout_3sec,
|
|
Timeout_Max
|
|
};
|
|
|
|
|
|
void OnShowTipForText(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
DoShowTip(m_textTitle);
|
|
}
|
|
|
|
void OnShowTipForBtn(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
DoShowTip(FindWindow(wxID_OK));
|
|
}
|
|
|
|
void DoShowTip(wxWindow* win)
|
|
{
|
|
wxRichToolTip tip(m_textTitle->GetValue(), m_textBody->GetValue());
|
|
const int iconSel = m_icons->GetSelection();
|
|
if ( iconSel == Icon_Custom )
|
|
{
|
|
tip.SetIcon(tip_xpm);
|
|
}
|
|
else // Use a standard icon.
|
|
{
|
|
static const int stdIcons[] =
|
|
{
|
|
wxICON_NONE,
|
|
wxICON_INFORMATION,
|
|
wxICON_WARNING,
|
|
wxICON_ERROR,
|
|
};
|
|
|
|
tip.SetIcon(stdIcons[iconSel]);
|
|
}
|
|
|
|
switch ( m_bgStyles->GetSelection() )
|
|
{
|
|
case Bg_Default:
|
|
break;
|
|
|
|
case Bg_Solid:
|
|
tip.SetBackgroundColour(*wxLIGHT_GREY);
|
|
break;
|
|
|
|
case Bg_Gradient:
|
|
tip.SetBackgroundColour(*wxWHITE, wxColour(0xe4, 0xe5, 0xf0));
|
|
break;
|
|
}
|
|
|
|
int delay = m_timeDelay->IsChecked() ? 500 : 0;
|
|
|
|
switch ( m_timeouts->GetSelection() )
|
|
{
|
|
case Timeout_None:
|
|
// Don't call SetTimeout unnecessarily
|
|
// or msw will show generic impl
|
|
if ( delay )
|
|
tip.SetTimeout(0, delay);
|
|
break;
|
|
|
|
case Timeout_Default:
|
|
break;
|
|
|
|
case Timeout_3sec:
|
|
tip.SetTimeout(3000, delay);
|
|
break;
|
|
}
|
|
|
|
tip.SetTipKind(static_cast<wxTipKind>(m_tipKinds->GetSelection()));
|
|
|
|
tip.ShowFor(win);
|
|
}
|
|
|
|
wxTextCtrl* m_textTitle;
|
|
wxTextCtrl* m_textBody;
|
|
wxRadioBox* m_icons;
|
|
wxRadioBox* m_tipKinds;
|
|
wxRadioBox* m_bgStyles;
|
|
wxRadioBox* m_timeouts;
|
|
wxCheckBox* m_timeDelay;
|
|
};
|
|
|
|
void MyFrame::OnRichTipDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
RichTipDialog dialog(this);
|
|
dialog.ShowModal();
|
|
}
|
|
|
|
#endif // wxUSE_RICHTOOLTIP
|
|
|
|
void MyFrame::OnStandardButtonsSizerDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
StdButtonSizerDialog dialog(this);
|
|
dialog.ShowModal();
|
|
}
|
|
|
|
// TestDefaultAction
|
|
|
|
#define ID_CATCH_LISTBOX_DCLICK 100
|
|
#define ID_LISTBOX 101
|
|
#define ID_DISABLE_OK 102
|
|
#define ID_DISABLE_CANCEL 103
|
|
|
|
wxBEGIN_EVENT_TABLE(TestDefaultActionDialog, wxDialog)
|
|
EVT_CHECKBOX(ID_CATCH_LISTBOX_DCLICK, TestDefaultActionDialog::OnCatchListBoxDClick)
|
|
EVT_CHECKBOX(ID_DISABLE_OK, TestDefaultActionDialog::OnDisableOK)
|
|
EVT_CHECKBOX(ID_DISABLE_CANCEL, TestDefaultActionDialog::OnDisableCancel)
|
|
EVT_LISTBOX_DCLICK(ID_LISTBOX, TestDefaultActionDialog::OnListBoxDClick)
|
|
EVT_TEXT_ENTER(wxID_ANY, TestDefaultActionDialog::OnTextEnter)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
TestDefaultActionDialog::TestDefaultActionDialog( wxWindow *parent ) :
|
|
wxDialog( parent, -1, "Test default action" )
|
|
{
|
|
m_catchListBoxDClick = false;
|
|
|
|
wxBoxSizer *main_sizer = new wxBoxSizer( wxVERTICAL );
|
|
|
|
wxFlexGridSizer *grid_sizer = new wxFlexGridSizer( 2, 5, 5 );
|
|
|
|
#if wxUSE_LISTBOX
|
|
wxListBox *listbox = new wxListBox( this, ID_LISTBOX );
|
|
listbox->Append( "String 1" );
|
|
listbox->Append( "String 2" );
|
|
listbox->Append( "String 3" );
|
|
listbox->Append( "String 4" );
|
|
grid_sizer->Add( listbox );
|
|
#endif // wxUSE_LISTBOX
|
|
|
|
grid_sizer->Add( new wxCheckBox( this, ID_CATCH_LISTBOX_DCLICK, "Catch DoubleClick from wxListBox" ), 0, wxALIGN_CENTRE_VERTICAL );
|
|
|
|
grid_sizer->Add( new wxTextCtrl( this, -1, "", wxDefaultPosition, wxSize(80,-1), 0 ), 0, wxALIGN_CENTRE_VERTICAL );
|
|
grid_sizer->Add( new wxStaticText( this, -1, "wxTextCtrl without wxTE_PROCESS_ENTER" ), 0, wxALIGN_CENTRE_VERTICAL );
|
|
|
|
grid_sizer->Add( new wxTextCtrl( this, -1, "", wxDefaultPosition, wxSize(80,-1), wxTE_PROCESS_ENTER ), 0, wxALIGN_CENTRE_VERTICAL );
|
|
grid_sizer->Add( new wxStaticText( this, -1, "wxTextCtrl with wxTE_PROCESS_ENTER" ), 0, wxALIGN_CENTRE_VERTICAL );
|
|
|
|
grid_sizer->Add( new wxCheckBox(this, ID_DISABLE_OK, "Disable \"OK\""), 0, wxALIGN_CENTRE_VERTICAL );
|
|
grid_sizer->Add( new wxCheckBox(this, ID_DISABLE_CANCEL, "Disable \"Cancel\""), 0, wxALIGN_CENTRE_VERTICAL );
|
|
|
|
main_sizer->Add( grid_sizer, 0, wxALL, 10 );
|
|
|
|
wxSizer *button_sizer = CreateSeparatedButtonSizer( wxOK|wxCANCEL );
|
|
if (button_sizer)
|
|
main_sizer->Add( button_sizer, 0, wxALL|wxGROW, 5 );
|
|
|
|
SetSizerAndFit( main_sizer );
|
|
}
|
|
|
|
void TestDefaultActionDialog::OnDisableOK(wxCommandEvent& event)
|
|
{
|
|
FindWindow(wxID_OK)->Enable(!event.IsChecked());
|
|
}
|
|
|
|
void TestDefaultActionDialog::OnDisableCancel(wxCommandEvent& event)
|
|
{
|
|
FindWindow(wxID_CANCEL)->Enable(!event.IsChecked());
|
|
}
|
|
|
|
void TestDefaultActionDialog::OnListBoxDClick(wxCommandEvent& event)
|
|
{
|
|
event.Skip( !m_catchListBoxDClick );
|
|
}
|
|
|
|
void TestDefaultActionDialog::OnCatchListBoxDClick(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
m_catchListBoxDClick = !m_catchListBoxDClick;
|
|
}
|
|
|
|
void TestDefaultActionDialog::OnTextEnter(wxCommandEvent& event)
|
|
{
|
|
wxLogMessage("Text \"%s\" entered.", event.GetString());
|
|
}
|
|
|
|
void MyFrame::OnTestDefaultActionDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
TestDefaultActionDialog dialog( this );
|
|
dialog.ShowModal();
|
|
}
|
|
|
|
void MyFrame::OnModalHook(wxCommandEvent& event)
|
|
{
|
|
class TestModalHook : public wxModalDialogHook
|
|
{
|
|
protected:
|
|
virtual int Enter(wxDialog* dialog) wxOVERRIDE
|
|
{
|
|
wxLogStatus("Showing %s modal dialog",
|
|
dialog->GetClassInfo()->GetClassName());
|
|
return wxID_NONE;
|
|
}
|
|
|
|
virtual void Exit(wxDialog* dialog) wxOVERRIDE
|
|
{
|
|
wxLogStatus("Leaving %s modal dialog",
|
|
dialog->GetClassInfo()->GetClassName());
|
|
}
|
|
};
|
|
|
|
static TestModalHook s_hook;
|
|
if ( event.IsChecked() )
|
|
s_hook.Register();
|
|
else
|
|
s_hook.Unregister();
|
|
}
|
|
|
|
void MyFrame::OnExit(wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
Close(true);
|
|
}
|
|
|
|
#if wxUSE_PROGRESSDLG
|
|
|
|
void MyFrame::ShowProgress( wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
static const int max = 100;
|
|
|
|
wxProgressDialog dialog("Progress dialog example",
|
|
// "Reserve" enough space for the multiline
|
|
// messages below, we'll change it anyhow
|
|
// immediately in the loop below
|
|
wxString(' ', 100) + "\n\n\n\n",
|
|
max, // range
|
|
this, // parent
|
|
wxPD_CAN_ABORT |
|
|
wxPD_CAN_SKIP |
|
|
wxPD_APP_MODAL |
|
|
//wxPD_AUTO_HIDE | // -- try this as well
|
|
wxPD_ELAPSED_TIME |
|
|
wxPD_ESTIMATED_TIME |
|
|
wxPD_REMAINING_TIME |
|
|
wxPD_SMOOTH // - makes indeterminate mode bar on WinXP very small
|
|
);
|
|
|
|
bool cont = true;
|
|
for ( int i = 0; i <= max; i++ )
|
|
{
|
|
wxString msg;
|
|
|
|
// test both modes of wxProgressDialog behaviour: start in
|
|
// indeterminate mode but switch to the determinate one later
|
|
const bool determinate = i > max/2;
|
|
|
|
if ( i == max )
|
|
{
|
|
msg = "That's all, folks!\n"
|
|
"\n"
|
|
"Nothing to see here any more.";
|
|
}
|
|
else if ( !determinate )
|
|
{
|
|
msg = "Testing indeterminate mode\n"
|
|
"\n"
|
|
"This mode allows you to show to the user\n"
|
|
"that something is going on even if you don't know\n"
|
|
"when exactly will you finish.";
|
|
}
|
|
else if ( determinate )
|
|
{
|
|
msg = "Now in standard determinate mode\n"
|
|
"\n"
|
|
"This is the standard usage mode in which you\n"
|
|
"update the dialog after performing each new step of work.\n"
|
|
"It requires knowing the total number of steps in advance.";
|
|
}
|
|
|
|
// will be set to true if "Skip" button was pressed
|
|
bool skip = false;
|
|
if ( determinate )
|
|
{
|
|
cont = dialog.Update(i, msg, &skip);
|
|
}
|
|
else
|
|
{
|
|
cont = dialog.Pulse(msg, &skip);
|
|
}
|
|
|
|
// each skip will move progress about quarter forward
|
|
if ( skip )
|
|
{
|
|
i += max/4;
|
|
|
|
if ( i >= 100 )
|
|
i = 99;
|
|
}
|
|
|
|
if ( !cont )
|
|
{
|
|
if ( wxMessageBox(wxT("Do you really want to cancel?"),
|
|
wxT("Progress dialog question"), // caption
|
|
wxYES_NO | wxICON_QUESTION) == wxYES )
|
|
break;
|
|
|
|
cont = true;
|
|
dialog.Resume();
|
|
}
|
|
|
|
wxMilliSleep(200);
|
|
}
|
|
|
|
if ( !cont )
|
|
{
|
|
wxLogStatus(wxT("Progress dialog aborted!"));
|
|
}
|
|
else
|
|
{
|
|
wxLogStatus(wxT("Countdown from %d finished"), max);
|
|
}
|
|
}
|
|
|
|
#endif // wxUSE_PROGRESSDLG
|
|
|
|
void MyFrame::ShowAppProgress( wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
wxAppProgressIndicator progress(this);
|
|
if ( !progress.IsAvailable() )
|
|
{
|
|
wxLogStatus("Progress indicator not available under this platform.");
|
|
return;
|
|
}
|
|
|
|
wxLogStatus("Using application progress indicator...");
|
|
|
|
const int range = 10;
|
|
progress.SetRange(range);
|
|
for ( int i = 0; i < range; i++ )
|
|
{
|
|
progress.SetValue(i);
|
|
|
|
wxMilliSleep(500);
|
|
}
|
|
|
|
wxLogStatus("Progress finished");
|
|
}
|
|
|
|
#if wxUSE_ABOUTDLG
|
|
|
|
static void InitAboutInfoMinimal(wxAboutDialogInfo& info)
|
|
{
|
|
info.SetName(wxT("Dialogs Sample"));
|
|
info.SetVersion(wxVERSION_NUM_DOT_STRING,
|
|
wxString::Format
|
|
(
|
|
"%s version %s",
|
|
wxMINOR_VERSION % 2 ? "Development" : "Stable",
|
|
wxVERSION_NUM_DOT_STRING
|
|
));
|
|
info.SetDescription(wxT("This sample shows different wxWidgets dialogs"));
|
|
info.SetCopyright(wxT("(C) 1998-2006 wxWidgets dev team"));
|
|
info.AddDeveloper(wxT("Vadim Zeitlin"));
|
|
}
|
|
|
|
static void InitAboutInfoWebsite(wxAboutDialogInfo& info)
|
|
{
|
|
InitAboutInfoMinimal(info);
|
|
|
|
info.SetWebSite(wxT("http://www.wxwidgets.org/"), wxT("wxWidgets web site"));
|
|
}
|
|
|
|
static void InitAboutInfoAll(wxAboutDialogInfo& info)
|
|
{
|
|
InitAboutInfoWebsite(info);
|
|
|
|
// we can add a second developer
|
|
info.AddDeveloper(wxT("A.N. Other"));
|
|
|
|
// or we can add several persons at once like this
|
|
static const wxChar *docwriters[] =
|
|
{
|
|
wxT("First D. Writer"),
|
|
wxT("Second One"),
|
|
};
|
|
|
|
info.SetDocWriters(wxArrayString(WXSIZEOF(docwriters), docwriters));
|
|
info.SetLicence(wxString::FromAscii(
|
|
" wxWindows Library Licence, Version 3.1\n"
|
|
" ======================================\n"
|
|
"\n"
|
|
" Copyright (c) 1998-2005 Julian Smart, Robert Roebling et al\n"
|
|
"\n"
|
|
" Everyone is permitted to copy and distribute verbatim copies\n"
|
|
" of this licence document, but changing it is not allowed.\n"
|
|
"\n"
|
|
" WXWINDOWS LIBRARY LICENCE\n"
|
|
" TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION\n"
|
|
"\n"
|
|
" ...and so on and so forth...\n"
|
|
));
|
|
|
|
info.AddTranslator(wxT("Wun Ngo Wen (Martian)"));
|
|
}
|
|
|
|
void MyFrame::ShowSimpleAboutDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxAboutDialogInfo info;
|
|
InitAboutInfoMinimal(info);
|
|
|
|
wxAboutBox(info, this);
|
|
}
|
|
|
|
void MyFrame::ShowFancyAboutDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxAboutDialogInfo info;
|
|
InitAboutInfoWebsite(info);
|
|
|
|
wxAboutBox(info, this);
|
|
}
|
|
|
|
void MyFrame::ShowFullAboutDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxAboutDialogInfo info;
|
|
InitAboutInfoAll(info);
|
|
|
|
wxAboutBox(info, this);
|
|
}
|
|
|
|
// a trivial example of a custom dialog class
|
|
class MyAboutDialog : public wxGenericAboutDialog
|
|
{
|
|
public:
|
|
MyAboutDialog(const wxAboutDialogInfo& info, wxWindow* parent)
|
|
{
|
|
Create(info, parent);
|
|
}
|
|
|
|
// add some custom controls
|
|
virtual void DoAddCustomControls() wxOVERRIDE
|
|
{
|
|
AddControl(new wxStaticLine(this), wxSizerFlags().Expand());
|
|
AddText(wxT("Some custom text"));
|
|
AddControl(new wxStaticLine(this), wxSizerFlags().Expand());
|
|
}
|
|
};
|
|
|
|
void MyFrame::ShowCustomAboutDialog(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxAboutDialogInfo info;
|
|
InitAboutInfoAll(info);
|
|
|
|
MyAboutDialog dlg(info, this);
|
|
dlg.ShowModal();
|
|
}
|
|
|
|
#endif // wxUSE_ABOUTDLG
|
|
|
|
#if wxUSE_BUSYINFO
|
|
|
|
void MyFrame::ShowBusyInfo(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxWindowDisabler disableAll;
|
|
|
|
wxBusyInfo info(wxT("Working, please wait..."), this);
|
|
|
|
for ( int i = 0; i < 18; i++ )
|
|
{
|
|
wxMilliSleep(100);
|
|
wxTheApp->Yield();
|
|
}
|
|
|
|
wxSleep(2);
|
|
}
|
|
|
|
void MyFrame::ShowRichBusyInfo(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxWindowDisabler disableAll;
|
|
|
|
// This is just an example and not an encouragement for printing
|
|
// synchronously from the main thread.
|
|
wxBusyInfo info
|
|
(
|
|
wxBusyInfoFlags()
|
|
.Parent(this)
|
|
.Icon(wxArtProvider::GetIcon(wxART_PRINT,
|
|
wxART_OTHER, wxSize(128, 128)))
|
|
.Title("<b>Printing your document</b>")
|
|
.Text("Please wait...")
|
|
.Foreground(*wxWHITE)
|
|
.Background(*wxBLACK)
|
|
.Transparency(4*wxALPHA_OPAQUE/5)
|
|
);
|
|
|
|
wxSleep(5);
|
|
}
|
|
|
|
#endif // wxUSE_BUSYINFO
|
|
|
|
#if wxUSE_FINDREPLDLG
|
|
|
|
void MyFrame::ShowReplaceDialog( wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
if ( m_dlgReplace )
|
|
{
|
|
wxDELETE(m_dlgReplace);
|
|
}
|
|
else
|
|
{
|
|
m_dlgReplace = new wxFindReplaceDialog
|
|
(
|
|
this,
|
|
&m_findData,
|
|
wxT("Find and replace dialog"),
|
|
wxFR_REPLACEDIALOG
|
|
);
|
|
|
|
m_dlgReplace->Show(true);
|
|
}
|
|
}
|
|
|
|
void MyFrame::ShowFindDialog( wxCommandEvent& WXUNUSED(event) )
|
|
{
|
|
if ( m_dlgFind )
|
|
{
|
|
wxDELETE(m_dlgFind);
|
|
}
|
|
else
|
|
{
|
|
m_dlgFind = new wxFindReplaceDialog
|
|
(
|
|
this,
|
|
&m_findData,
|
|
wxT("Find dialog"),
|
|
// just for testing
|
|
wxFR_NOWHOLEWORD
|
|
);
|
|
|
|
m_dlgFind->Show(true);
|
|
}
|
|
}
|
|
|
|
static wxString DecodeFindDialogEventFlags(int flags)
|
|
{
|
|
wxString str;
|
|
str << (flags & wxFR_DOWN ? wxT("down") : wxT("up")) << wxT(", ")
|
|
<< (flags & wxFR_WHOLEWORD ? wxT("whole words only, ") : wxT(""))
|
|
<< (flags & wxFR_MATCHCASE ? wxT("") : wxT("not "))
|
|
<< wxT("case sensitive");
|
|
|
|
return str;
|
|
}
|
|
|
|
void MyFrame::OnFindDialog(wxFindDialogEvent& event)
|
|
{
|
|
wxEventType type = event.GetEventType();
|
|
|
|
if ( type == wxEVT_FIND || type == wxEVT_FIND_NEXT )
|
|
{
|
|
wxLogMessage(wxT("Find %s'%s' (flags: %s)"),
|
|
type == wxEVT_FIND_NEXT ? wxT("next ") : wxT(""),
|
|
event.GetFindString().c_str(),
|
|
DecodeFindDialogEventFlags(event.GetFlags()).c_str());
|
|
}
|
|
else if ( type == wxEVT_FIND_REPLACE ||
|
|
type == wxEVT_FIND_REPLACE_ALL )
|
|
{
|
|
wxLogMessage(wxT("Replace %s'%s' with '%s' (flags: %s)"),
|
|
type == wxEVT_FIND_REPLACE_ALL ? wxT("all ") : wxT(""),
|
|
event.GetFindString().c_str(),
|
|
event.GetReplaceString().c_str(),
|
|
DecodeFindDialogEventFlags(event.GetFlags()).c_str());
|
|
}
|
|
else if ( type == wxEVT_FIND_CLOSE )
|
|
{
|
|
wxFindReplaceDialog *dlg = event.GetDialog();
|
|
|
|
int idMenu;
|
|
const wxChar *txt;
|
|
if ( dlg == m_dlgFind )
|
|
{
|
|
txt = wxT("Find");
|
|
idMenu = DIALOGS_FIND;
|
|
m_dlgFind = NULL;
|
|
}
|
|
else if ( dlg == m_dlgReplace )
|
|
{
|
|
txt = wxT("Replace");
|
|
idMenu = DIALOGS_REPLACE;
|
|
m_dlgReplace = NULL;
|
|
}
|
|
else
|
|
{
|
|
txt = wxT("Unknown");
|
|
idMenu = wxID_ANY;
|
|
|
|
wxFAIL_MSG( wxT("unexpected event") );
|
|
}
|
|
|
|
wxLogMessage(wxT("%s dialog is being closed."), txt);
|
|
|
|
if ( idMenu != wxID_ANY )
|
|
{
|
|
GetMenuBar()->Check(idMenu, false);
|
|
}
|
|
|
|
dlg->Destroy();
|
|
}
|
|
else
|
|
{
|
|
wxLogError(wxT("Unknown find dialog event!"));
|
|
}
|
|
}
|
|
|
|
#endif // wxUSE_FINDREPLDLG
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// MyCanvas
|
|
// ----------------------------------------------------------------------------
|
|
|
|
void MyCanvas::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
|
{
|
|
wxPaintDC dc(this);
|
|
dc.SetBackgroundMode(wxTRANSPARENT);
|
|
dc.DrawText(
|
|
wxT("wxWidgets common dialogs")
|
|
wxT(" test application")
|
|
, 10, 10);
|
|
}
|
|
|
|
#if USE_MODAL_PRESENTATION
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// MyModelessDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
MyModelessDialog::MyModelessDialog(wxWindow *parent)
|
|
: wxDialog(parent, wxID_ANY, wxString(wxT("Modeless dialog")))
|
|
{
|
|
wxBoxSizer *sizerTop = new wxBoxSizer(wxVERTICAL);
|
|
|
|
wxButton *btn = new wxButton(this, DIALOGS_MODELESS_BTN, wxT("Press me"));
|
|
wxCheckBox *check = new wxCheckBox(this, wxID_ANY, wxT("Should be disabled"));
|
|
check->Disable();
|
|
|
|
sizerTop->Add(btn, 1, wxEXPAND | wxALL, 5);
|
|
sizerTop->Add(check, 1, wxEXPAND | wxALL, 5);
|
|
|
|
SetSizerAndFit(sizerTop);
|
|
}
|
|
|
|
void MyModelessDialog::OnButton(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxMessageBox(wxT("Button pressed in modeless dialog"), wxT("Info"),
|
|
wxOK | wxICON_INFORMATION, this);
|
|
}
|
|
|
|
void MyModelessDialog::OnClose(wxCloseEvent& event)
|
|
{
|
|
if ( event.CanVeto() )
|
|
{
|
|
wxMessageBox(wxT("Use the menu item to close this dialog"),
|
|
wxT("Modeless dialog"),
|
|
wxOK | wxICON_INFORMATION, this);
|
|
|
|
event.Veto();
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// MyModalDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
MyModalDialog::MyModalDialog(wxWindow *parent)
|
|
: wxDialog(parent, wxID_ANY, wxString(wxT("Modal dialog")))
|
|
{
|
|
wxBoxSizer *sizerTop = new wxBoxSizer(wxHORIZONTAL);
|
|
|
|
m_btnModal = new wxButton(this, wxID_ANY, wxT("&Modal dialog..."));
|
|
m_btnModeless = new wxButton(this, wxID_ANY, wxT("Mode&less dialog"));
|
|
m_btnDelete = new wxButton(this, wxID_ANY, wxT("&Delete button"));
|
|
|
|
sizerTop->Add(m_btnModal, 0, wxALIGN_CENTER | wxALL, 5);
|
|
sizerTop->Add(m_btnModeless, 0, wxALIGN_CENTER | wxALL, 5);
|
|
sizerTop->Add(m_btnDelete, 0, wxALIGN_CENTER | wxALL, 5);
|
|
sizerTop->Add(new wxButton(this, wxID_CLOSE), 0, wxALIGN_CENTER | wxALL, 5);
|
|
|
|
SetSizerAndFit(sizerTop);
|
|
|
|
SetEscapeId(wxID_CLOSE);
|
|
|
|
m_btnModal->SetFocus();
|
|
m_btnModal->SetDefault();
|
|
}
|
|
|
|
void MyModalDialog::OnButton(wxCommandEvent& event)
|
|
{
|
|
if ( event.GetEventObject() == m_btnDelete )
|
|
{
|
|
wxDELETE(m_btnModal);
|
|
m_btnDelete->Disable();
|
|
}
|
|
else if ( event.GetEventObject() == m_btnModal )
|
|
{
|
|
#if wxUSE_TEXTDLG
|
|
wxGetTextFromUser(wxT("Dummy prompt"),
|
|
wxT("Modal dialog called from dialog"),
|
|
wxEmptyString, this);
|
|
#else
|
|
wxMessageBox(wxT("Modal dialog called from dialog"));
|
|
#endif // wxUSE_TEXTDLG
|
|
}
|
|
else if ( event.GetEventObject() == m_btnModeless )
|
|
{
|
|
(new MyModelessDialog(this))->Show();
|
|
}
|
|
else
|
|
{
|
|
event.Skip();
|
|
}
|
|
}
|
|
|
|
#endif // USE_MODAL_PRESENTATION
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// StdButtonSizerDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
StdButtonSizerDialog::StdButtonSizerDialog(wxWindow *parent)
|
|
: wxDialog(parent, wxID_ANY, wxString(wxT("StdButtonSizer dialog")),
|
|
wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER),
|
|
m_buttonsSizer(NULL)
|
|
{
|
|
wxBoxSizer *const sizerTop = new wxBoxSizer(wxVERTICAL);
|
|
|
|
wxBoxSizer *const sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
wxBoxSizer *const sizerInside1 = new wxBoxSizer(wxVERTICAL);
|
|
|
|
m_chkboxAffirmativeButton = new wxCheckBox(this, wxID_ANY, _("Enable Affirmative Button"));
|
|
|
|
wxStaticBoxSizer *const sizer1 = new wxStaticBoxSizer(wxVERTICAL, this, wxT("Affirmative Button"));
|
|
|
|
m_radiobtnOk = new wxRadioButton(this, wxID_ANY, _("Ok"), wxDefaultPosition, wxDefaultSize, wxRB_GROUP);
|
|
m_radiobtnYes = new wxRadioButton(this, wxID_ANY, _("Yes"));
|
|
|
|
wxBoxSizer *const sizerInside2 = new wxBoxSizer(wxVERTICAL);
|
|
|
|
m_chkboxDismissButton = new wxCheckBox(this, wxID_ANY, _("Enable Dismiss Button"));
|
|
|
|
wxStaticBoxSizer *const sizer2 = new wxStaticBoxSizer(wxVERTICAL, this, wxT("Dismiss Button"));
|
|
|
|
m_radiobtnCancel = new wxRadioButton(this, wxID_ANY, _("Cancel"), wxDefaultPosition, wxDefaultSize, wxRB_GROUP);
|
|
m_radiobtnClose = new wxRadioButton(this, wxID_ANY, _("Close"));
|
|
|
|
wxBoxSizer *const sizer3 = new wxBoxSizer(wxHORIZONTAL);
|
|
|
|
m_chkboxNo = new wxCheckBox(this, wxID_ANY, _("No"));
|
|
m_chkboxHelp = new wxCheckBox(this, wxID_ANY, _("Help"));
|
|
m_chkboxApply = new wxCheckBox(this, wxID_ANY, _("Apply"));
|
|
|
|
m_chkboxNoDefault = new wxCheckBox(this, wxID_ANY, wxT("No Default"));
|
|
|
|
sizer1->Add(m_radiobtnOk, 0, wxALL, 5);
|
|
sizer1->Add(m_radiobtnYes, 0, wxALL, 5);
|
|
|
|
sizer->Add(sizerInside1, 0, 0, 0);
|
|
sizerInside1->Add(m_chkboxAffirmativeButton, 0, wxALL, 5);
|
|
sizerInside1->Add(sizer1, 0, wxALL, 5);
|
|
sizerInside1->SetItemMinSize(sizer1, sizer1->GetStaticBox()->GetBestSize()); // to prevent wrapping of static box label
|
|
|
|
sizer2->Add(m_radiobtnCancel, 0, wxALL, 5);
|
|
sizer2->Add(m_radiobtnClose, 0, wxALL, 5);
|
|
|
|
sizer->Add(sizerInside2, 0, 0, 0);
|
|
sizerInside2->Add(m_chkboxDismissButton, 0, wxALL, 5);
|
|
sizerInside2->Add(sizer2, 0, wxALL, 5);
|
|
sizerInside2->SetItemMinSize(sizer2, sizer2->GetStaticBox()->GetBestSize()); // to prevent wrapping of static box label
|
|
|
|
sizerTop->Add(sizer, 0, wxALL, 5);
|
|
|
|
sizer3->Add(m_chkboxNo, 0, wxALL, 5);
|
|
sizer3->Add(m_chkboxHelp, 0, wxALL, 5);
|
|
sizer3->Add(m_chkboxApply, 0, wxALL, 5);
|
|
|
|
sizerTop->Add(sizer3, 0, wxALL, 5);
|
|
|
|
sizerTop->Add(m_chkboxNoDefault, 0, wxLEFT|wxRIGHT, 10);
|
|
|
|
EnableDisableControls();
|
|
|
|
SetSizerAndFit(sizerTop);
|
|
|
|
wxCommandEvent ev;
|
|
OnEvent(ev);
|
|
}
|
|
|
|
void StdButtonSizerDialog::OnEvent(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
if (m_buttonsSizer)
|
|
{
|
|
m_buttonsSizer->DeleteWindows();
|
|
GetSizer()->Remove(m_buttonsSizer);
|
|
}
|
|
|
|
EnableDisableControls();
|
|
|
|
long flags = 0;
|
|
unsigned long numButtons = 0;
|
|
|
|
if (m_chkboxAffirmativeButton->IsChecked())
|
|
{
|
|
if (m_radiobtnOk->GetValue())
|
|
{
|
|
flags |= wxOK;
|
|
numButtons ++;
|
|
}
|
|
else if (m_radiobtnYes->GetValue())
|
|
{
|
|
flags |= wxYES;
|
|
numButtons ++;
|
|
}
|
|
}
|
|
|
|
if (m_chkboxDismissButton->IsChecked())
|
|
{
|
|
if (m_radiobtnCancel->GetValue())
|
|
{
|
|
flags |= wxCANCEL;
|
|
numButtons ++;
|
|
}
|
|
|
|
else if (m_radiobtnClose->GetValue())
|
|
{
|
|
flags |= wxCLOSE;
|
|
numButtons ++;
|
|
}
|
|
|
|
}
|
|
|
|
if (m_chkboxApply->IsChecked())
|
|
{
|
|
flags |= wxAPPLY;
|
|
numButtons ++;
|
|
}
|
|
|
|
if (m_chkboxNo->IsChecked())
|
|
{
|
|
flags |= wxNO;
|
|
numButtons ++;
|
|
}
|
|
|
|
if (m_chkboxHelp->IsChecked())
|
|
{
|
|
flags |= wxHELP;
|
|
numButtons ++;
|
|
}
|
|
|
|
if (m_chkboxNoDefault->IsChecked())
|
|
{
|
|
flags |= wxNO_DEFAULT;
|
|
}
|
|
|
|
m_buttonsSizer = CreateStdDialogButtonSizer(flags);
|
|
GetSizer()->Add(m_buttonsSizer, 0, wxGROW|wxALL, 5);
|
|
|
|
Layout();
|
|
GetSizer()->SetSizeHints(this);
|
|
}
|
|
|
|
void StdButtonSizerDialog::EnableDisableControls()
|
|
{
|
|
const bool affButtonEnabled = m_chkboxAffirmativeButton->IsChecked();
|
|
|
|
m_radiobtnOk->Enable(affButtonEnabled);
|
|
m_radiobtnYes->Enable(affButtonEnabled);
|
|
|
|
const bool dismissButtonEnabled = m_chkboxDismissButton->IsChecked();
|
|
|
|
m_radiobtnCancel->Enable(dismissButtonEnabled);
|
|
m_radiobtnClose->Enable(dismissButtonEnabled);
|
|
}
|
|
|
|
#if USE_SETTINGS_DIALOG
|
|
// ----------------------------------------------------------------------------
|
|
// SettingsDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
wxIMPLEMENT_CLASS(SettingsDialog, wxPropertySheetDialog);
|
|
|
|
wxBEGIN_EVENT_TABLE(SettingsDialog, wxPropertySheetDialog)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
SettingsDialog::SettingsDialog(wxWindow* win, int dialogType)
|
|
{
|
|
SetExtraStyle(wxDIALOG_EX_CONTEXTHELP|wxWS_EX_VALIDATE_RECURSIVELY);
|
|
|
|
int tabImage1 = -1;
|
|
int tabImage2 = -1;
|
|
|
|
bool useToolBook = (dialogType == DIALOGS_PROPERTY_SHEET_TOOLBOOK || dialogType == DIALOGS_PROPERTY_SHEET_BUTTONTOOLBOOK);
|
|
int resizeBorder = wxRESIZE_BORDER;
|
|
|
|
if (useToolBook)
|
|
{
|
|
resizeBorder = 0;
|
|
tabImage1 = 0;
|
|
tabImage2 = 1;
|
|
|
|
int sheetStyle = wxPROPSHEET_SHRINKTOFIT;
|
|
if (dialogType == DIALOGS_PROPERTY_SHEET_BUTTONTOOLBOOK)
|
|
sheetStyle |= wxPROPSHEET_BUTTONTOOLBOOK;
|
|
else
|
|
sheetStyle |= wxPROPSHEET_TOOLBOOK;
|
|
|
|
SetSheetStyle(sheetStyle);
|
|
SetSheetInnerBorder(0);
|
|
SetSheetOuterBorder(0);
|
|
|
|
// create a dummy image list with a few icons
|
|
const wxSize imageSize(32, 32);
|
|
|
|
m_imageList = new wxImageList(imageSize.GetWidth(), imageSize.GetHeight());
|
|
m_imageList->
|
|
Add(wxArtProvider::GetIcon(wxART_INFORMATION, wxART_OTHER, imageSize));
|
|
m_imageList->
|
|
Add(wxArtProvider::GetIcon(wxART_QUESTION, wxART_OTHER, imageSize));
|
|
m_imageList->
|
|
Add(wxArtProvider::GetIcon(wxART_WARNING, wxART_OTHER, imageSize));
|
|
m_imageList->
|
|
Add(wxArtProvider::GetIcon(wxART_ERROR, wxART_OTHER, imageSize));
|
|
}
|
|
else
|
|
m_imageList = NULL;
|
|
|
|
Create(win, wxID_ANY, _("Preferences"), wxDefaultPosition, wxDefaultSize,
|
|
wxDEFAULT_DIALOG_STYLE| (int)wxPlatform::IfNot(wxOS_WINDOWS_CE, resizeBorder)
|
|
);
|
|
|
|
// If using a toolbook, also follow Mac style and don't create buttons
|
|
if (!useToolBook)
|
|
CreateButtons(wxOK | wxCANCEL |
|
|
(int)wxPlatform::IfNot(wxOS_WINDOWS_CE, wxHELP)
|
|
);
|
|
|
|
wxBookCtrlBase* notebook = GetBookCtrl();
|
|
notebook->SetImageList(m_imageList);
|
|
|
|
wxPanel* generalSettings = CreateGeneralSettingsPage(notebook);
|
|
wxPanel* aestheticSettings = CreateAestheticSettingsPage(notebook);
|
|
|
|
notebook->AddPage(generalSettings, _("General"), true, tabImage1);
|
|
notebook->AddPage(aestheticSettings, _("Aesthetics"), false, tabImage2);
|
|
|
|
LayoutDialog();
|
|
}
|
|
|
|
SettingsDialog::~SettingsDialog()
|
|
{
|
|
delete m_imageList;
|
|
}
|
|
|
|
wxPanel* SettingsDialog::CreateGeneralSettingsPage(wxWindow* parent)
|
|
{
|
|
wxPanel* panel = new wxPanel(parent, wxID_ANY);
|
|
|
|
wxBoxSizer *topSizer = new wxBoxSizer( wxVERTICAL );
|
|
wxBoxSizer *item0 = new wxBoxSizer( wxVERTICAL );
|
|
|
|
//// LOAD LAST FILE
|
|
|
|
wxBoxSizer* itemSizer3 = new wxBoxSizer( wxHORIZONTAL );
|
|
wxCheckBox* checkBox3 = new wxCheckBox(panel, ID_LOAD_LAST_PROJECT, _("&Load last project on startup"), wxDefaultPosition, wxDefaultSize);
|
|
itemSizer3->Add(checkBox3, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
item0->Add(itemSizer3, 0, wxGROW|wxALL, 0);
|
|
|
|
//// AUTOSAVE
|
|
|
|
wxString autoSaveLabel = _("&Auto-save every");
|
|
wxString minsLabel = _("mins");
|
|
|
|
wxBoxSizer* itemSizer12 = new wxBoxSizer( wxHORIZONTAL );
|
|
wxCheckBox* checkBox12 = new wxCheckBox(panel, ID_AUTO_SAVE, autoSaveLabel, wxDefaultPosition, wxDefaultSize);
|
|
|
|
#if wxUSE_SPINCTRL
|
|
wxSpinCtrl* spinCtrl12 = new wxSpinCtrl(panel, ID_AUTO_SAVE_MINS, wxEmptyString,
|
|
wxDefaultPosition, wxSize(40, wxDefaultCoord), wxSP_ARROW_KEYS, 1, 60, 1);
|
|
#endif
|
|
|
|
itemSizer12->Add(checkBox12, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
#if wxUSE_SPINCTRL
|
|
itemSizer12->Add(spinCtrl12, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
#endif
|
|
itemSizer12->Add(new wxStaticText(panel, wxID_STATIC, minsLabel), 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
item0->Add(itemSizer12, 0, wxGROW|wxALL, 0);
|
|
|
|
//// TOOLTIPS
|
|
|
|
wxBoxSizer* itemSizer8 = new wxBoxSizer( wxHORIZONTAL );
|
|
wxCheckBox* checkBox6 = new wxCheckBox(panel, ID_SHOW_TOOLTIPS, _("Show &tooltips"), wxDefaultPosition, wxDefaultSize);
|
|
itemSizer8->Add(checkBox6, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
item0->Add(itemSizer8, 0, wxGROW|wxALL, 0);
|
|
|
|
topSizer->Add( item0, wxSizerFlags(1).Expand().Border(wxALL, 5) );
|
|
|
|
panel->SetSizerAndFit(topSizer);
|
|
|
|
return panel;
|
|
}
|
|
|
|
wxPanel* SettingsDialog::CreateAestheticSettingsPage(wxWindow* parent)
|
|
{
|
|
wxPanel* panel = new wxPanel(parent, wxID_ANY);
|
|
|
|
wxBoxSizer *topSizer = new wxBoxSizer( wxVERTICAL );
|
|
wxBoxSizer *item0 = new wxBoxSizer( wxVERTICAL );
|
|
|
|
//// PROJECT OR GLOBAL
|
|
wxString globalOrProjectChoices[2];
|
|
globalOrProjectChoices[0] = _("&New projects");
|
|
globalOrProjectChoices[1] = _("&This project");
|
|
|
|
wxRadioBox* projectOrGlobal = new wxRadioBox(panel, ID_APPLY_SETTINGS_TO, _("&Apply settings to:"),
|
|
wxDefaultPosition, wxDefaultSize, 2, globalOrProjectChoices);
|
|
item0->Add(projectOrGlobal, 0, wxGROW|wxALL, 5);
|
|
|
|
projectOrGlobal->SetSelection(0);
|
|
|
|
//// BACKGROUND STYLE
|
|
wxArrayString backgroundStyleChoices;
|
|
backgroundStyleChoices.Add(wxT("Colour"));
|
|
backgroundStyleChoices.Add(wxT("Image"));
|
|
wxStaticBox* staticBox3 = new wxStaticBox(panel, wxID_ANY, _("Background style:"));
|
|
|
|
wxBoxSizer* styleSizer = new wxStaticBoxSizer( staticBox3, wxVERTICAL );
|
|
item0->Add(styleSizer, 0, wxGROW|wxALL, 5);
|
|
|
|
wxBoxSizer* itemSizer2 = new wxBoxSizer( wxHORIZONTAL );
|
|
|
|
wxChoice* choice2 = new wxChoice(panel, ID_BACKGROUND_STYLE, wxDefaultPosition, wxDefaultSize, backgroundStyleChoices);
|
|
|
|
itemSizer2->Add(new wxStaticText(panel, wxID_ANY, _("&Window:")), 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
itemSizer2->Add(5, 5, 1, wxALL, 0);
|
|
itemSizer2->Add(choice2, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
|
|
|
|
styleSizer->Add(itemSizer2, 0, wxGROW|wxALL, 5);
|
|
|
|
#if wxUSE_SPINCTRL
|
|
//// FONT SIZE SELECTION
|
|
|
|
wxStaticBox* staticBox1 = new wxStaticBox(panel, wxID_ANY, _("Tile font size:"));
|
|
wxBoxSizer* itemSizer5 = new wxStaticBoxSizer( staticBox1, wxHORIZONTAL );
|
|
|
|
wxSpinCtrl* spinCtrl = new wxSpinCtrl(panel, ID_FONT_SIZE, wxEmptyString, wxDefaultPosition,
|
|
wxSize(80, wxDefaultCoord));
|
|
itemSizer5->Add(spinCtrl, 0, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5);
|
|
|
|
item0->Add(itemSizer5, 0, wxGROW|wxLEFT|wxRIGHT, 5);
|
|
#endif
|
|
|
|
topSizer->Add( item0, wxSizerFlags(1).Expand().Border(wxALL, 5) );
|
|
topSizer->AddSpacer(5);
|
|
|
|
panel->SetSizerAndFit(topSizer);
|
|
|
|
return panel;
|
|
}
|
|
|
|
#endif // USE_SETTINGS_DIALOG
|
|
|
|
#if wxUSE_MSGDLG
|
|
// ----------------------------------------------------------------------------
|
|
// TestMessageBoxDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/* static */
|
|
const TestMessageBoxDialog::BtnInfo TestMessageBoxDialog::ms_btnInfo[] =
|
|
{
|
|
{ wxYES, "&Yes" },
|
|
{ wxNO, "&No" },
|
|
{ wxOK, "&Ok" },
|
|
{ wxCANCEL, "&Cancel" },
|
|
{ wxHELP, "&Help" },
|
|
};
|
|
|
|
wxBEGIN_EVENT_TABLE(TestMessageBoxDialog, wxDialog)
|
|
EVT_BUTTON(wxID_APPLY, TestMessageBoxDialog::OnApply)
|
|
EVT_BUTTON(wxID_CLOSE, TestMessageBoxDialog::OnClose)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
TestMessageBoxDialog::TestMessageBoxDialog(wxWindow *parent)
|
|
: wxDialog(parent, wxID_ANY, "Message Box Test Dialog",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
|
|
{
|
|
}
|
|
|
|
bool TestMessageBoxDialog::Create()
|
|
{
|
|
wxSizer * const sizerTop = new wxBoxSizer(wxVERTICAL);
|
|
|
|
// this sizer allows to configure the messages shown in the message box
|
|
wxSizer * const
|
|
sizerMsgs = new wxStaticBoxSizer(wxVERTICAL, this, "&Messages");
|
|
sizerMsgs->Add(new wxStaticText(this, wxID_ANY, "&Title:"));
|
|
m_textTitle = new wxTextCtrl(this, wxID_ANY, "Test Message Box");
|
|
sizerMsgs->Add(m_textTitle, wxSizerFlags().Expand().Border(wxBOTTOM));
|
|
|
|
sizerMsgs->Add(new wxStaticText(this, wxID_ANY, "&Main message:"));
|
|
m_textMsg = new wxTextCtrl(this, wxID_ANY, "Hello from a box!",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxTE_MULTILINE);
|
|
sizerMsgs->Add(m_textMsg, wxSizerFlags(1).Expand().Border(wxBOTTOM));
|
|
|
|
sizerMsgs->Add(new wxStaticText(this, wxID_ANY, "&Extended message:"));
|
|
m_textExtMsg = new wxTextCtrl(this, wxID_ANY, "",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxTE_MULTILINE);
|
|
sizerMsgs->Add(m_textExtMsg, wxSizerFlags().Expand());
|
|
|
|
sizerTop->Add(sizerMsgs, wxSizerFlags(1).Expand().Border());
|
|
|
|
// if a derived class provides more message configurations, add these.
|
|
AddAdditionalTextOptions(sizerTop);
|
|
|
|
// this one is for configuring the buttons
|
|
wxSizer * const
|
|
sizerBtnsBox = new wxStaticBoxSizer(wxVERTICAL, this, "&Buttons");
|
|
|
|
wxFlexGridSizer * const sizerBtns = new wxFlexGridSizer(2, 5, 5);
|
|
sizerBtns->AddGrowableCol(1);
|
|
|
|
sizerBtns->Add(new wxStaticText(this, wxID_ANY, "Button(s)"));
|
|
sizerBtns->Add(new wxStaticText(this, wxID_ANY, "Custom label"));
|
|
|
|
for ( int n = 0; n < Btn_Max; n++ )
|
|
{
|
|
m_buttons[n] = new wxCheckBox(this, wxID_ANY, ms_btnInfo[n].name);
|
|
sizerBtns->Add(m_buttons[n], wxSizerFlags().Centre().Left());
|
|
|
|
m_labels[n] = new wxTextCtrl(this, wxID_ANY);
|
|
sizerBtns->Add(m_labels[n], wxSizerFlags().Expand());
|
|
|
|
m_labels[n]->Connect(wxEVT_UPDATE_UI,
|
|
wxUpdateUIEventHandler(
|
|
TestMessageBoxDialog::OnUpdateLabelUI),
|
|
NULL,
|
|
this);
|
|
}
|
|
|
|
sizerBtnsBox->Add(sizerBtns, wxSizerFlags().Expand());
|
|
sizerTop->Add(sizerBtnsBox, wxSizerFlags().Expand().Border());
|
|
|
|
|
|
// icon choice
|
|
const wxString icons[] =
|
|
{
|
|
"&Not specified",
|
|
"E&xplicitly none",
|
|
"&Information icon",
|
|
"&Question icon",
|
|
"&Warning icon",
|
|
"&Error icon",
|
|
"A&uth needed icon"
|
|
};
|
|
|
|
wxCOMPILE_TIME_ASSERT( WXSIZEOF(icons) == MsgDlgIcon_Max, IconMismatch );
|
|
|
|
m_icons = new wxRadioBox(this, wxID_ANY, "&Icon style",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
WXSIZEOF(icons), icons,
|
|
2, wxRA_SPECIFY_ROWS);
|
|
// Make the 'Information' icon the default one:
|
|
m_icons->SetSelection(MsgDlgIcon_Info);
|
|
sizerTop->Add(m_icons, wxSizerFlags().Expand().Border());
|
|
|
|
|
|
// miscellaneous other stuff
|
|
wxSizer * const
|
|
sizerFlags = new wxStaticBoxSizer(wxHORIZONTAL, this, "&Other flags");
|
|
|
|
m_chkNoDefault = new wxCheckBox(this, wxID_ANY, "Make \"No\" &default");
|
|
m_chkNoDefault->Connect(wxEVT_UPDATE_UI,
|
|
wxUpdateUIEventHandler(
|
|
TestMessageBoxDialog::OnUpdateNoDefaultUI),
|
|
NULL,
|
|
this);
|
|
sizerFlags->Add(m_chkNoDefault, wxSizerFlags().Border());
|
|
|
|
m_chkCentre = new wxCheckBox(this, wxID_ANY, "Centre on &parent");
|
|
sizerFlags->Add(m_chkCentre, wxSizerFlags().Border());
|
|
|
|
// add any additional flag from subclasses
|
|
AddAdditionalFlags(sizerFlags);
|
|
|
|
sizerTop->Add(sizerFlags, wxSizerFlags().Expand().Border());
|
|
|
|
// add the currently unused zone for displaying the dialog result
|
|
m_labelResult = new wxStaticText(this, wxID_ANY, "",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxST_NO_AUTORESIZE | wxALIGN_CENTRE);
|
|
m_labelResult->SetForegroundColour(*wxBLUE);
|
|
sizerTop->Add(m_labelResult, wxSizerFlags().Expand().DoubleBorder());
|
|
|
|
// finally buttons to show the resulting message box and close this dialog
|
|
sizerTop->Add(CreateStdDialogButtonSizer(wxAPPLY | wxCLOSE),
|
|
wxSizerFlags().Right().Border());
|
|
|
|
SetSizerAndFit(sizerTop);
|
|
|
|
m_buttons[Btn_Ok]->SetValue(true);
|
|
|
|
CentreOnScreen();
|
|
|
|
return true;
|
|
}
|
|
|
|
void TestMessageBoxDialog::OnUpdateLabelUI(wxUpdateUIEvent& event)
|
|
{
|
|
for ( int n = 0; n < Btn_Max; n++ )
|
|
{
|
|
if ( event.GetEventObject() == m_labels[n] )
|
|
{
|
|
event.Enable( m_buttons[n]->IsChecked() );
|
|
return;
|
|
}
|
|
}
|
|
|
|
wxFAIL_MSG( "called for unknown label" );
|
|
}
|
|
|
|
void TestMessageBoxDialog::OnUpdateNoDefaultUI(wxUpdateUIEvent& event)
|
|
{
|
|
event.Enable( m_buttons[Btn_No]->IsChecked() );
|
|
}
|
|
|
|
long TestMessageBoxDialog::GetStyle()
|
|
{
|
|
long style = 0;
|
|
|
|
for ( int n = 0; n < Btn_Max; n++ )
|
|
{
|
|
if ( m_buttons[n]->IsChecked() )
|
|
style |= ms_btnInfo[n].flag;
|
|
}
|
|
|
|
switch ( m_icons->GetSelection() )
|
|
{
|
|
case MsgDlgIcon_Max:
|
|
wxFAIL_MSG( "unexpected selection" );
|
|
|
|
case MsgDlgIcon_No:
|
|
break;
|
|
|
|
case MsgDlgIcon_None:
|
|
style |= wxICON_NONE;
|
|
break;
|
|
|
|
case MsgDlgIcon_Info:
|
|
style |= wxICON_INFORMATION;
|
|
break;
|
|
|
|
case MsgDlgIcon_Question:
|
|
style |= wxICON_QUESTION;
|
|
break;
|
|
|
|
case MsgDlgIcon_Warning:
|
|
style |= wxICON_WARNING;
|
|
break;
|
|
|
|
case MsgDlgIcon_Error:
|
|
style |= wxICON_ERROR;
|
|
break;
|
|
|
|
case MsgDlgIcon_AuthNeeded:
|
|
style |= wxICON_AUTH_NEEDED;
|
|
break;
|
|
}
|
|
|
|
if ( m_chkCentre->IsChecked() )
|
|
style |= wxCENTRE;
|
|
|
|
if ( m_chkNoDefault->IsEnabled() && m_chkNoDefault->IsChecked() )
|
|
style |= wxNO_DEFAULT;
|
|
|
|
return style;
|
|
}
|
|
|
|
void TestMessageBoxDialog::PrepareMessageDialog(wxMessageDialogBase &dlg)
|
|
{
|
|
long style = dlg.GetMessageDialogStyle();
|
|
|
|
if ( !m_textExtMsg->IsEmpty() )
|
|
dlg.SetExtendedMessage(m_textExtMsg->GetValue());
|
|
|
|
if ( style & wxYES_NO )
|
|
{
|
|
if ( style & wxCANCEL )
|
|
{
|
|
dlg.SetYesNoCancelLabels(m_labels[Btn_Yes]->GetValue(),
|
|
m_labels[Btn_No]->GetValue(),
|
|
m_labels[Btn_Cancel]->GetValue());
|
|
}
|
|
else
|
|
{
|
|
dlg.SetYesNoLabels(m_labels[Btn_Yes]->GetValue(),
|
|
m_labels[Btn_No]->GetValue());
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if ( style & wxCANCEL )
|
|
{
|
|
dlg.SetOKCancelLabels(m_labels[Btn_Ok]->GetValue(),
|
|
m_labels[Btn_Cancel]->GetValue());
|
|
}
|
|
else
|
|
{
|
|
dlg.SetOKLabel(m_labels[Btn_Ok]->GetValue());
|
|
}
|
|
}
|
|
|
|
if ( style & wxHELP )
|
|
{
|
|
dlg.SetHelpLabel(m_labels[Btn_Help]->GetValue());
|
|
}
|
|
}
|
|
|
|
void TestMessageBoxDialog::OnApply(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxMessageDialog dlg(this, GetMessage(), GetBoxTitle(), GetStyle());
|
|
PrepareMessageDialog(dlg);
|
|
|
|
ShowResult(dlg.ShowModal());
|
|
}
|
|
|
|
void TestMessageBoxDialog::ShowResult(int res)
|
|
{
|
|
wxString btnName;
|
|
switch ( res )
|
|
{
|
|
case wxID_OK:
|
|
btnName = "OK";
|
|
break;
|
|
|
|
case wxID_CANCEL:
|
|
btnName = "Cancel";
|
|
break;
|
|
|
|
case wxID_YES:
|
|
btnName = "Yes";
|
|
break;
|
|
|
|
case wxID_NO:
|
|
btnName = "No";
|
|
break;
|
|
|
|
case wxID_HELP:
|
|
btnName = "Help";
|
|
break;
|
|
|
|
default:
|
|
btnName = "Unknown";
|
|
}
|
|
|
|
m_labelResult->SetLabel(
|
|
wxString::Format("Dialog was closed with the \"%s\" button.", btnName)
|
|
);
|
|
}
|
|
|
|
void TestMessageBoxDialog::OnClose(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
EndModal(wxID_CANCEL);
|
|
}
|
|
#endif // wxUSE_MSGDLG
|
|
|
|
#if wxUSE_RICHMSGDLG
|
|
// ----------------------------------------------------------------------------
|
|
// TestRichMessageDialog
|
|
// ----------------------------------------------------------------------------
|
|
|
|
wxBEGIN_EVENT_TABLE(TestRichMessageDialog, TestMessageBoxDialog)
|
|
EVT_BUTTON(wxID_APPLY, TestRichMessageDialog::OnApply)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
TestRichMessageDialog::TestRichMessageDialog(wxWindow *parent)
|
|
: TestMessageBoxDialog(parent)
|
|
{
|
|
SetTitle("Rich Message Dialog Test Dialog");
|
|
}
|
|
|
|
void TestRichMessageDialog::AddAdditionalTextOptions(wxSizer *sizer)
|
|
{
|
|
wxSizer * const sizerMsgs = new wxStaticBoxSizer(wxVERTICAL, this,
|
|
"&Additional Elements");
|
|
|
|
// add a option to show a check box.
|
|
wxSizer * const sizerCheckBox = new wxBoxSizer(wxHORIZONTAL);
|
|
sizerCheckBox->Add(new wxStaticText(this, wxID_ANY, "&Check box:"),
|
|
wxSizerFlags().Centre().Border(wxRIGHT));
|
|
m_textCheckBox = new wxTextCtrl(this, wxID_ANY);
|
|
sizerCheckBox->Add(m_textCheckBox, wxSizerFlags(1).Centre());
|
|
sizerMsgs->Add(sizerCheckBox, wxSizerFlags().Expand().Border(wxBOTTOM));
|
|
|
|
// add option to show a detailed text.
|
|
sizerMsgs->Add(new wxStaticText(this, wxID_ANY, "&Detailed message:"));
|
|
m_textDetailed = new wxTextCtrl(this, wxID_ANY, "",
|
|
wxDefaultPosition, wxDefaultSize,
|
|
wxTE_MULTILINE);
|
|
sizerMsgs->Add(m_textDetailed, wxSizerFlags().Expand());
|
|
|
|
sizer->Add(sizerMsgs, wxSizerFlags().Expand().Border());
|
|
}
|
|
|
|
void TestRichMessageDialog::AddAdditionalFlags(wxSizer *sizer)
|
|
{
|
|
// add checkbox to set the initial state for the checkbox shown
|
|
// in the dialog.
|
|
m_initialValueCheckBox =
|
|
new wxCheckBox(this, wxID_ANY, "Checkbox initially checked");
|
|
sizer->Add(m_initialValueCheckBox, wxSizerFlags().Border());
|
|
}
|
|
|
|
void TestRichMessageDialog::OnApply(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
wxRichMessageDialog dlg(this, GetMessage(), GetBoxTitle(), GetStyle());
|
|
PrepareMessageDialog(dlg);
|
|
|
|
dlg.ShowCheckBox(m_textCheckBox->GetValue(),
|
|
m_initialValueCheckBox->GetValue());
|
|
dlg.ShowDetailedText(m_textDetailed->GetValue());
|
|
|
|
ShowResult(dlg.ShowModal());
|
|
}
|
|
|
|
#endif // wxUSE_RICHMSGDLG
|
|
|
|
#if wxUSE_LOG
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// custom log target
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class MyLogGui : public wxLogGui
|
|
{
|
|
private:
|
|
virtual void DoShowSingleLogMessage(const wxString& message,
|
|
const wxString& title,
|
|
int style) wxOVERRIDE
|
|
{
|
|
wxMessageDialog dlg(NULL, message, title,
|
|
wxOK | wxCANCEL | wxCANCEL_DEFAULT | style);
|
|
dlg.SetOKCancelLabels(wxID_COPY, wxID_OK);
|
|
dlg.SetExtendedMessage("Note that this is a custom log dialog.");
|
|
dlg.ShowModal();
|
|
}
|
|
};
|
|
|
|
wxLog *MyAppTraits::CreateLogTarget()
|
|
{
|
|
return new MyLogGui;
|
|
}
|
|
|
|
#endif // wxUSE_LOG
|