X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/03206f17a616c02f7c5349c066917809b64106ea..ed177375b27f8b80231a42638314c9809e6e945d:/contrib/samples/fl/fl_demo2.cpp?ds=sidebyside diff --git a/contrib/samples/fl/fl_demo2.cpp b/contrib/samples/fl/fl_demo2.cpp index ba978cc231..3941e3581b 100644 --- a/contrib/samples/fl/fl_demo2.cpp +++ b/contrib/samples/fl/fl_demo2.cpp @@ -9,10 +9,6 @@ // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "fl_demo2.h" -#endif - // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" @@ -24,10 +20,10 @@ #include "wx/wx.h" #endif -// wxWindows headers. +// wxWidgets headers. #include "wx/treectrl.h" #include "wx/imaglist.h" -#include "wx/notebook.h" +#include "wx/notebook.h" // fl headers. #include "wx/fl/controlbar.h" @@ -55,75 +51,77 @@ IMPLEMENT_APP (MyApp) bool MyApp::OnInit(void) { // Create the main frame window - MyFrame *frame = new MyFrame(NULL, "wxWindows 2.0 wxFrameLayout demo", 50, 50, 650, 540); - + MyFrame *frame = new MyFrame(NULL, _("wxWidgets 2.0 wxFrameLayout demo"), 50, 50, 650, 540); + // Give it an icon #ifdef __WINDOWS__ - frame->SetIcon(wxIcon("mondrian")); + frame->SetIcon(wxIcon(wxT("mondrian"))); #endif #ifdef __X__ - frame->SetIcon(wxIcon("aiai.xbm")); + frame->SetIcon(wxIcon(wxT("aiai.xbm"))); #endif - + // Make a menubar wxMenu *file_menu = new wxMenu; wxMenu *active_menu = new wxMenu; - - file_menu->Append( ID_LOAD, "&Load layouts" ); - file_menu->Append( ID_STORE, "&Store layouts" ); + + file_menu->Append( ID_LOAD, _("&Load layouts") ); + file_menu->Append( ID_STORE, _("&Store layouts") ); file_menu->AppendSeparator(); - - file_menu->Append( ID_AUTOSAVE, "&Auto Save Layouts", "save layouts on exit", TRUE ); + + file_menu->Append( ID_AUTOSAVE, _("&Auto Save Layouts"), _("save layouts on exit"), wxITEM_CHECK ); file_menu->AppendSeparator(); - - file_menu->Append(MINIMAL_ABOUT, "A&bout !"); - file_menu->Append(MINIMAL_QUIT, "E&xit\tTab"); - - //active_menu->Append( ID_SETTINGS, "&Settings...\tCtrl" ); + + file_menu->Append(MINIMAL_ABOUT, _("A&bout !")); + file_menu->Append(MINIMAL_QUIT, _("E&xit\tTab")); + + //active_menu->Append( ID_SETTINGS, _("&Settings...\tCtrl") ); //active_menu->AppendSeparator(); - - active_menu->Append( ID_REMOVE, "&Remove Active" ); - active_menu->Append( ID_REMOVEALL, "Remove &All" ); - active_menu->Append( ID_RECREATE, "Re&create" ); + + active_menu->Append( ID_REMOVE, _("&Remove Active") ); + active_menu->Append( ID_REMOVEALL, _("Remove &All") ); + active_menu->Append( ID_RECREATE, _("Re&create") ); active_menu->AppendSeparator(); - - active_menu->Append( ID_FIRST, "Activate f&irst layout \tF1", "activate it", TRUE ); - active_menu->Append( ID_SECOND, "Activate &second layout\tF2","activate it", TRUE ); - active_menu->Append( ID_THIRD, "Activate &third layout\tF3","activate it", TRUE ); - + + active_menu->Append( ID_FIRST, _("Activate f&irst layout \tF1"), _("activate it"), wxITEM_CHECK ); + active_menu->Append( ID_SECOND, _("Activate &second layout\tF2"), _("activate it"), wxITEM_CHECK ); + active_menu->Append( ID_THIRD, _("Activate &third layout\tF3"), _("activate it"), wxITEM_CHECK ); + wxMenuBar *menu_bar = new wxMenuBar; - - menu_bar->Append(file_menu, "&File"); - menu_bar->Append(active_menu, "Active &Layout"); - + + menu_bar->Append(file_menu, _("&File")); + menu_bar->Append(active_menu, _("Active &Layout")); + +#if wxUSE_STATUSBAR frame->CreateStatusBar(3); - +#endif // wxUSE_STATUSBAR + frame->SetMenuBar(menu_bar); - + frame->SyncMenuBarItems(); - + // Show the frame - frame->Show(TRUE); - + frame->Show(true); + SetTopWindow(frame); - - return TRUE; + + return true; } MyFrame::~MyFrame() { // frame-layouts is not a windows (objects), thus should // be cleaned up manually - + for( int i = 0; i != MAX_LAYOUTS; ++i ) { - if ( mLayouts[i] ) + if ( mLayouts[i] ) delete mLayouts[i]; } - - if ( mpNestedLayout ) + + if ( mpNestedLayout ) delete mpNestedLayout; - if ( mpAboutBoxLayout ) + if ( mpAboutBoxLayout ) delete mpAboutBoxLayout; } @@ -154,55 +152,56 @@ END_EVENT_TABLE() // My frame constructor -MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h) - : wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h)), +MyFrame::MyFrame(wxFrame *frame, const wxChar *title, int x, int y, int w, int h) + : wxFrame(frame, wxID_ANY, title, wxPoint(x, y), wxSize(w, h)), mpNestedLayout( NULL ), mpAboutBoxLayout( NULL ), mActiveLayoutNo( FIRST_LAYOUT ), - mAutoSave( TRUE ), - mSavedAlready( FALSE ), + mAutoSave( true ), + mSavedAlready( false ), mpClntWindow( NULL ), - mImageList( 16,16, FALSE, 2 ) + mImageList( 16,16, false, 2 ) { + int i; + mpInternalFrm = (wxPanel*)this; - - mAboutBox.Create( this, -1, "About box in wxWindows style...", + + mAboutBox.Create( this, wxID_ANY, _T("About box in wxWidgets style..."), wxDefaultPosition, wxSize( 385,220), - wxDIALOG_MODAL | wxDEFAULT_DIALOG_STYLE | wxTAB_TRAVERSAL ); - - int i = 0; - for( i = 0; i != MAX_LAYOUTS; ++i ) + wxDEFAULT_DIALOG_STYLE | wxTAB_TRAVERSAL ); + + for( i = 0; i != MAX_LAYOUTS; ++i ) mLayouts[i] = NULL; - + // image-list is one of the few objects which - // currently cannot be serialized, create it first + // currently cannot be serialized, create it first // and use it as initial reference (IR) - + wxBitmap bmp1,bmp2; - - if ( wxFileExists( BMP_DIR "folder_icon.bmp" ) ) - bmp1.LoadFile( BMP_DIR "folder_icon.bmp", wxBITMAP_TYPE_BMP ); - - if ( wxFileExists( BMP_DIR "class_icon1.bmp" ) ) - bmp2.LoadFile( BMP_DIR "class_icon1.bmp", wxBITMAP_TYPE_BMP ); - + + if ( wxFileExists( wxString(wxT(BMP_DIR)) + wxT("folder_icon.bmp") ) ) + bmp1.LoadFile( wxString(wxT(BMP_DIR)) + wxT("folder_icon.bmp"), wxBITMAP_TYPE_BMP ); + + if ( wxFileExists( wxString(wxT(BMP_DIR)) + wxT("class_icon1.bmp") ) ) + bmp2.LoadFile( wxString(wxT(BMP_DIR)) + wxT("class_icon1.bmp"), wxBITMAP_TYPE_BMP ); + mImageList.Add( bmp1 ); mImageList.Add( bmp2 ); - + InitAboutBox(); - + // create multiple layouts - + mpNestedLayout = 0; - - mpClntWindow = CreateTxtCtrl("client window"); - + + mpClntWindow = CreateTxtCtrl(wxT("client window")); + // Create all layouts for( i = 0; i != MAX_LAYOUTS; ++i ) - { + { CreateLayout( i ); } // hide others @@ -210,8 +209,8 @@ MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h) { mLayouts[i]->HideBarWindows(); } - - // activate first one + + // activate first one mLayouts[FIRST_LAYOUT]->Activate(); mActiveLayoutNo = FIRST_LAYOUT; } @@ -220,57 +219,57 @@ MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h) bool MyFrame::OnClose(void) { - // USEFUL TRICK:: avoids flickering of application's frame + // USEFUL TRICK:: avoids flickering of application's frame // when closing NN windows on exit: - - this->Show(FALSE); - + + Show(false); + if ( (mAutoSave && mSavedAlready) || !mAutoSave ) { } else { wxCommandEvent evt; - this->OnStore(evt); + OnStore(evt); } - + mAboutBox.Destroy(); - this->Destroy(); - - return TRUE; + Destroy(); + + return true; } -void MyFrame::OnLoad( wxCommandEvent& event ) +void MyFrame::OnLoad( wxCommandEvent& WXUNUSED(event) ) { - wxMessageBox("Hey - you found a BIG question-mark !!"); + wxMessageBox(_("Hey - you found a BIG question-mark !!")); } -void MyFrame::OnStore( wxCommandEvent& event ) +void MyFrame::OnStore( wxCommandEvent& WXUNUSED(event) ) { - wxMessageBox("Hey - you found another BIG question-mark !!"); + wxMessageBox(_("Hey - you found another BIG question-mark !!")); } -void MyFrame::OnAutoSave( wxCommandEvent& event ) +void MyFrame::OnAutoSave( wxCommandEvent& WXUNUSED(event) ) { mAutoSave = !mAutoSave; - + wxCommandEvent evt; - this->OnStore(evt); - + OnStore(evt); + SyncMenuBarItems(); } -void MyFrame::OnRemove( wxCommandEvent& event ) +void MyFrame::OnRemove( wxCommandEvent& WXUNUSED(event) ) { RemoveLayout( mActiveLayoutNo ); - + Refresh(); } -void MyFrame::OnRemoveAll( wxCommandEvent& event ) +void MyFrame::OnRemoveAll( wxCommandEvent& WXUNUSED(event) ) { for( int i = 0; i != MAX_LAYOUTS; ++i ) - { + { RemoveLayout( i ); } @@ -281,111 +280,111 @@ void MyFrame::OnRemoveAll( wxCommandEvent& event ) void MyFrame::OnRecreate( wxCommandEvent& event ) { OnRemove( event ); // first destroy active layout - + CreateLayout( mActiveLayoutNo ); - + mLayouts[mActiveLayoutNo]->Activate(); } -void MyFrame::OnFirst( wxCommandEvent& event ) +void MyFrame::OnFirst( wxCommandEvent& WXUNUSED(event) ) { ActivateLayout( FIRST_LAYOUT ); } -void MyFrame::OnSecond( wxCommandEvent& event ) +void MyFrame::OnSecond( wxCommandEvent& WXUNUSED(event) ) { ActivateLayout( SECOND_LAYOUT ); } -void MyFrame::OnThird( wxCommandEvent& event ) +void MyFrame::OnThird( wxCommandEvent& WXUNUSED(event) ) { ActivateLayout( THIRD_LAYOUT ); } -void MyFrame::OnQuit( wxCommandEvent& event ) +void MyFrame::OnQuit( wxCommandEvent& WXUNUSED(event) ) { - // USEFUL TRICK:: avoids flickering of application's frame + // USEFUL TRICK:: avoids flickering of application's frame // when closing NN windows on exit: - - this->Show(FALSE); - + + Show(false); + if ( (mAutoSave && mSavedAlready) || !mAutoSave ) { } else { wxCommandEvent evt; - this->OnStore(evt); + OnStore(evt); } - + Destroy(); } -void MyFrame::OnAbout( wxCommandEvent& event ) +void MyFrame::OnAbout( wxCommandEvent& WXUNUSED(event) ) { wxFont font; #ifdef __WXMSW__ - font.SetFaceName("MS Sans Serif"); + font.SetFaceName(wxT("MS Sans Serif")); #else font.SetFamily( wxSWISS ); #endif - + font.SetStyle( wxSLANT ); font.SetWeight( wxNORMAL ); font.SetPointSize( 8 ); - + #ifdef __WXMSW__ font.RealizeResource(); #endif - + mAboutBox.Center( wxBOTH ); - mAboutBox.Show(TRUE); - + mAboutBox.Show(true); + } void MyFrame::OnChar( wxKeyEvent& event ) { wxCommandEvent evt; - + if ( event.m_keyCode == WXK_F1 ) { - this->OnFirst( evt ); + OnFirst( evt ); } else { if ( event.m_keyCode == WXK_F2 ) { - this->OnSecond( evt ); + OnSecond( evt ); } else { if ( event.m_keyCode == WXK_F3 ) - { - this->OnThird( evt ); + { + OnThird( evt ); } if ( event.m_keyCode == WXK_F4 && !event.AltDown() ) - { + { // "AI" :-) - wxMessageBox("There are only 3 layouts in this demo :-("); + wxMessageBox(_("There are only 3 layouts in this demo :-(")); } else { if ( event.m_keyCode == WXK_TAB ) { - // USEFUL TRICK:: avoids flickering of application's frame + // USEFUL TRICK:: avoids flickering of application's frame // when closing NN windows on exit: - - this->Show(FALSE); - + + Show(false); + if ( (mAutoSave && mSavedAlready) || !mAutoSave ) { } else { wxCommandEvent evt; - this->OnStore(evt); + OnStore(evt); } - + Destroy(); } else @@ -397,24 +396,24 @@ void MyFrame::OnChar( wxKeyEvent& event ) } } -void MyFrame::OnSayItsOk( wxCommandEvent& event ) +void MyFrame::OnSayItsOk( wxCommandEvent& WXUNUSED(event) ) { - wxMessageBox("It's OK :-)\n\n now click on the border around the button\n and try dragging it!" ); + wxMessageBox(_("It's OK :-)\n\n now click on the border around the button\n and try dragging it!") ); } -void MyFrame::OnBtnYes( wxCommandEvent& event ) +void MyFrame::OnBtnYes( wxCommandEvent& WXUNUSED(event) ) { - mAboutBox.Show(FALSE); + mAboutBox.Show(false); } -void MyFrame::OnBtnNo( wxCommandEvent& event ) +void MyFrame::OnBtnNo( wxCommandEvent& WXUNUSED(event) ) { - mAboutBox.Show(FALSE); + mAboutBox.Show(false); } -void MyFrame::OnBtnEsc( wxCommandEvent& event ) +void MyFrame::OnBtnEsc( wxCommandEvent& WXUNUSED(event) ) { - mAboutBox.Show(FALSE); + mAboutBox.Show(false); } /*** helper methods ***/ @@ -422,355 +421,355 @@ void MyFrame::OnBtnEsc( wxCommandEvent& event ) void MyFrame::InitAboutBox() { wxPanel* pArea = new wxPanel(); - - pArea->Create( &mAboutBox, -1 ); - - new wxStaticText(pArea, -1, "This is wxFrameLayout contribution demo.", + + pArea->Create( &mAboutBox, wxID_ANY ); + + new wxStaticText(pArea, wxID_ANY, _("This is wxFrameLayout contribution demo."), wxPoint(10, 10) ); - - new wxStaticText(pArea, -1, "Aleksandras Gluchovas (c) 1998", + + new wxStaticText(pArea, wxID_ANY, _("Aleksandras Gluchovas (c) 1998"), wxPoint(10, 30) ); - - new wxStaticText(pArea, -1, "", + + new wxStaticText(pArea, wxID_ANY, _(""), wxPoint(10, 50) ); - - mpAboutBoxLayout = new wxFrameLayout( &mAboutBox, pArea, TRUE ); - + + mpAboutBoxLayout = new wxFrameLayout( &mAboutBox, pArea, true ); + wxFrameLayout& layout = *mpAboutBoxLayout; - + cbDimInfo sizes( 90,40, // when docked horizontally 45,55, // when docked vertically 90,40, // when floated - TRUE, 4, 4 // true - bar is fixed-size - ); - - - wxButton* pYes = CreateButton("&Yes", &mAboutBox, ID_SAY_ITSOK ); - wxButton* pNo = CreateButton("&No", &mAboutBox, ID_BTN_NO ); - wxButton* pEsc = CreateButton("Cancel", &mAboutBox, ID_BTN_ESC ); - - layout.AddBar( pEsc, sizes, FL_ALIGN_BOTTOM, 0, 20, "cancel button"); - layout.AddBar( pNo, sizes, FL_ALIGN_BOTTOM, 0, 20, "no button"); - layout.AddBar( pYes, sizes, FL_ALIGN_BOTTOM, 0, 20, "yes button"); - + true, 4, 4 // true - bar is fixed-size + ); + + + wxButton* pYes = CreateButton(_("&Yes"), &mAboutBox, ID_SAY_ITSOK ); + wxButton* pNo = CreateButton(_("&No"), &mAboutBox, ID_BTN_NO ); + wxButton* pEsc = CreateButton(_("Cancel"), &mAboutBox, ID_BTN_ESC ); + + layout.AddBar( pEsc, sizes, FL_ALIGN_BOTTOM, 0, 20, _("cancel button")); + layout.AddBar( pNo, sizes, FL_ALIGN_BOTTOM, 0, 20, _("no button")); + layout.AddBar( pYes, sizes, FL_ALIGN_BOTTOM, 0, 20, _("yes button")); + layout.mBorderPen.SetColour( 192, 192, 192 ); layout.SetMargins( 15, 15, 15, 15, wxALL_PANES ); - + cbCommonPaneProperties props; - + layout.GetPaneProperties( props, FL_ALIGN_TOP ); - - props.mShow3DPaneBorderOn = FALSE; - + + props.mShow3DPaneBorderOn = false; + layout.SetPaneProperties( props, wxALL_PANES ); - + layout.Activate(); - + pYes->SetDefault(); pYes->SetFocus(); } -wxTextCtrl* MyFrame::CreateTxtCtrl( const wxString& txt, wxWindow* parent ) +wxTextCtrl* MyFrame::CreateTxtCtrl( const wxString& txt, wxWindow* parent ) { return new wxTextCtrl( (parent != NULL ) ? parent : mpInternalFrm, - -1, txt, wxDefaultPosition, wxDefaultSize, + wxID_ANY, txt, wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE ); } wxButton* MyFrame::CreateButton( const wxString& label, wxWindow* pParent, long id ) { - return new wxButton( (pParent)?pParent : mpInternalFrm, id, + return new wxButton( (pParent)?pParent : mpInternalFrm, id, label, wxPoint( 0,0 ), wxSize( 0,0 ) ); } wxTreeCtrl* MyFrame::CreateTreeCtrl( const wxString& label ) { - wxTreeCtrl* pTree = new wxTreeCtrl( mpInternalFrm, -1 ); - - int rootid = pTree->AppendItem( (long)0, label, 0); - - if ( label[0] != 'X' ) + wxTreeCtrl* pTree = new wxTreeCtrl( mpInternalFrm, wxID_ANY ); + + const wxTreeItemId rootid = pTree->AddRoot(label); + + if ( label.StartsWith(_T("X")) ) { - pTree->AppendItem(rootid, "Leaf1", 0); - pTree->AppendItem(rootid, "Leaf2", 0); + pTree->AppendItem(rootid, _("Scully")); + pTree->AppendItem(rootid, _("Mulder")); } else { - pTree->AppendItem(rootid, "Scully", 0); - pTree->AppendItem(rootid, "Mulder", 0); + pTree->AppendItem(rootid, _("Leaf1")); + pTree->AppendItem(rootid, _("Leaf2")); } - + return pTree; } wxChoice* MyFrame::CreateChoice( const wxString& txt ) { wxString choice_strings[5]; - + choice_strings[0] = txt; - choice_strings[1] = "Julian"; - choice_strings[2] = "Hattie"; - choice_strings[3] = "Ken"; - choice_strings[4] = "Dick"; - - wxChoice *choice = new wxChoice( mpInternalFrm, 301, wxDefaultPosition, + choice_strings[1] = _("Julian"); + choice_strings[2] = _("Hattie"); + choice_strings[3] = _("Ken"); + choice_strings[4] = _("Dick"); + + wxChoice *choice = new wxChoice( mpInternalFrm, 301, wxDefaultPosition, wxDefaultSize, 5, choice_strings); - + choice->SetSelection(0); - + return choice; } // helper -void MyFrame::AddSearchToolbars( wxFrameLayout& layout, wxWindow* pParent ) +void MyFrame::AddSearchToolbars( wxFrameLayout& layout, wxWindow* WXUNUSED(pParent) ) { - cbDimInfo sizes2( 275,38, // when docked horizontally - 45,275, // when docked vertically - 80,30, // when floated - TRUE, // the bar is fixed-size + cbDimInfo sizes2( 275,38, // when docked horizontally + 45,275, // when docked vertically + 80,30, // when floated + true, // the bar is fixed-size 4, // vertical gap (bar border) 4, // horizontal gap (bar border) new cbDynToolBarDimHandler() - ); - - cbDimInfo sizes3( 275,55, // when docked horizontally - 275,60, // when docked vertically - 45,130, // when floated - TRUE, // the bar is fixed-size + ); + + cbDimInfo sizes3( 275,55, // when docked horizontally + 275,60, // when docked vertically + 45,130, // when floated + true, // the bar is fixed-size 4, // vertical gap (bar border) 4, // horizontal gap (bar border) new cbDynToolBarDimHandler() - ); - - cbDimInfo sizes4( 430,35, // when docked horizontally - 44,375, // when docked vertically - 80,100, // when floated - TRUE, // the bar is fixed-size + ); + + cbDimInfo sizes4( 430,35, // when docked horizontally + 44,375, // when docked vertically + 80,100, // when floated + true, // the bar is fixed-size 4, // vertical gap (bar border) 4, // horizontal gap (bar border) new cbDynToolBarDimHandler() - ); - - wxDynamicToolBar* pTBar2 = new wxDynamicToolBar( mpInternalFrm, -1 ); - - wxChoice* pChoice = new wxChoice( pTBar2, -1, wxDefaultPosition, wxSize( 140,25 ) ); - + ); + + wxDynamicToolBar* pTBar2 = new wxDynamicToolBar( mpInternalFrm, wxID_ANY ); + + wxChoice* pChoice = new wxChoice( pTBar2, wxID_ANY, wxDefaultPosition, wxSize( 140,25 ) ); + pTBar2->AddTool( 1, pChoice ); - pTBar2->AddTool( 2, BMP_DIR "search.bmp" ); + pTBar2->AddTool( 2, wxString(wxT(BMP_DIR)) + wxT("search.bmp") ); //pTBar2->AddSeparator(); - pTBar2->AddTool( 3, BMP_DIR "bookmarks.bmp" ); - pTBar2->AddTool( 4, BMP_DIR "nextmark.bmp" ); - pTBar2->AddTool( 5, BMP_DIR "prevmark.bmp" ); - - wxDynamicToolBar* pTBar3 = new wxDynamicToolBar( mpInternalFrm, -1 ); - - pTBar3->AddTool( 1, BMP_DIR "open.bmp", wxBITMAP_TYPE_BMP, " Open " ); - pTBar3->AddTool( 2, BMP_DIR "save.bmp", wxBITMAP_TYPE_BMP, " Save " ); - pTBar3->AddTool( 3, BMP_DIR "saveall.bmp", wxBITMAP_TYPE_BMP, " Save All " ); + pTBar2->AddTool( 3, wxString(wxT(BMP_DIR)) + wxT("bookmarks.bmp") ); + pTBar2->AddTool( 4, wxString(wxT(BMP_DIR)) + wxT("nextmark.bmp") ); + pTBar2->AddTool( 5, wxString(wxT(BMP_DIR)) + wxT("prevmark.bmp") ); + + wxDynamicToolBar* pTBar3 = new wxDynamicToolBar( mpInternalFrm, wxID_ANY ); + + pTBar3->AddTool( 1, wxString(wxT(BMP_DIR)) + wxT("open.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Open ")) ); + pTBar3->AddTool( 2, wxString(wxT(BMP_DIR)) + wxT("save.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Save ")) ); + pTBar3->AddTool( 3, wxString(wxT(BMP_DIR)) + wxT("saveall.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Save All ")) ); //pTBar3->AddSeparator(); - pTBar3->AddTool( 4, BMP_DIR "cut.bmp", wxBITMAP_TYPE_BMP, " Open " ); - pTBar3->AddTool( 5, BMP_DIR "copy.bmp", wxBITMAP_TYPE_BMP, " Copy " ); - pTBar3->AddTool( 6, BMP_DIR "paste.bmp", wxBITMAP_TYPE_BMP, " Paste " ); - + pTBar3->AddTool( 4, wxString(wxT(BMP_DIR)) + wxT("cut.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Open ")) ); + pTBar3->AddTool( 5, wxString(wxT(BMP_DIR)) + wxT("copy.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Copy ")) ); + pTBar3->AddTool( 6, wxString(wxT(BMP_DIR)) + wxT("paste.bmp"), wxBITMAP_TYPE_BMP, wxString(_(" Paste ")) ); + #ifdef __WXMSW__ - pTBar3->EnableTool( 2, FALSE ); + pTBar3->EnableTool( 2, false ); #endif - - wxDynamicToolBar* pTBar4 = new wxDynamicToolBar( mpInternalFrm, -1 ); - - pTBar4->AddTool( 1, BMP_DIR "bookmarks.bmp", wxBITMAP_TYPE_BMP, "Bookmarks ", TRUE ); - pTBar4->AddTool( 2, BMP_DIR "nextmark.bmp", wxBITMAP_TYPE_BMP, "Next bookmark ", TRUE ); - pTBar4->AddTool( 3, BMP_DIR "prevmark.bmp", wxBITMAP_TYPE_BMP, "Prev bookmark ", TRUE ); + + wxDynamicToolBar* pTBar4 = new wxDynamicToolBar( mpInternalFrm, wxID_ANY ); + + pTBar4->AddTool( 1, wxString(wxT(BMP_DIR)) + wxT("bookmarks.bmp"), wxBITMAP_TYPE_BMP, wxString(_("Bookmarks ")), true ); + pTBar4->AddTool( 2, wxString(wxT(BMP_DIR)) + wxT("nextmark.bmp"), wxBITMAP_TYPE_BMP, wxString(_("Next bookmark ")), true ); + pTBar4->AddTool( 3, wxString(wxT(BMP_DIR)) + wxT("prevmark.bmp"), wxBITMAP_TYPE_BMP, wxString(_("Prev bookmark ")), true ); //pTBar4->AddSeparator(); - pTBar4->AddTool( 4, BMP_DIR "search.bmp", wxBITMAP_TYPE_BMP, "Search ", TRUE ); - + pTBar4->AddTool( 4, wxString(wxT(BMP_DIR)) + wxT("search.bmp"), wxBITMAP_TYPE_BMP, wxString(_("Search ")), true ); + #ifdef __WXMSW__ - pTBar4->EnableTool( 4, FALSE ); + pTBar4->EnableTool( 4, false ); #endif - - layout.AddBar( pTBar2, - sizes2, FL_ALIGN_TOP, - 0, - 0, - "Search", - TRUE + + layout.AddBar( pTBar2, + sizes2, FL_ALIGN_TOP, + 0, + 0, + wxT("Search"), + true ); - - layout.AddBar( pTBar3, - sizes3, FL_ALIGN_BOTTOM, - 0, - 0, - "Titled", - TRUE + + layout.AddBar( pTBar3, + sizes3, FL_ALIGN_BOTTOM, + 0, + 0, + wxT("Titled"), + true ); - - layout.AddBar( pTBar4, - sizes4, FL_ALIGN_BOTTOM, - 1, - 0, - "Bookmarks", - TRUE + + layout.AddBar( pTBar4, + sizes4, FL_ALIGN_BOTTOM, + 1, + 0, + wxT("Bookmarks"), + true ); } wxWindow* MyFrame::CreateDevLayout( wxFrameLayout& layout, wxWindow* pParent ) { bool isNested = (pParent != mpInternalFrm); - - // check if we're craeting nested layout + + // check if we're creating nested layout if ( isNested ) { layout.mBorderPen.SetColour( 128,255,128 ); - + // if so, than make border smaller for( int i = 0; i != MAX_PANES; ++i ) { cbDockPane& pane = *layout.GetPane( i ); - + pane.mTopMargin = 5; pane.mBottomMargin = 5; pane.mLeftMargin = 5; pane.mRightMargin = 5; } } - + int cbWidth = 200; int cbHeight = ( isNested ) ? 50 : 150; - + cbDimInfo sizes4( cbWidth,cbHeight, cbWidth,cbHeight, - cbWidth,cbHeight, FALSE ); - + cbWidth,cbHeight, false ); + cbWidth = 75; cbHeight = 31; - + cbDimInfo sizes5( cbWidth,cbHeight, 42,65, - cbWidth,cbHeight, TRUE, + cbWidth,cbHeight, true, 3, // vertical gap (bar border) 3 // horizontal gap (bar border) - ); - + ); + // create "workplace" window in the third layout // SEB: originally here was a wxpp (wxWorkshop) class demotrated // wxTabbedWindow* pMiniTabArea = new wxTabbedWindow(); - // pMiniTabArea->Create( pParent, -1 ); - - - wxTreeCtrl* pClassView = new wxTreeCtrl( pParent, -1, + // pMiniTabArea->Create( pParent, wxID_ANY ); + + + wxTreeCtrl* pClassView = new wxTreeCtrl( pParent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTR_HAS_BUTTONS | wxTR_EDIT_LABELS ); - + pClassView->SetImageList( &mImageList ); - - wxTreeItemId rootId = pClassView->AddRoot( "wxWindows 2.0 classes", 0 ); - - pClassView->AppendItem( rootId, "wxWin Dynamic classes (grabbed at run-time)", 0 ); - pClassView->AppendItem( rootId, "serializer-classes (grabbed at run-time)", 0 ); - + + wxTreeItemId rootId = pClassView->AddRoot( wxT("wxWidgets 2.0 classes"), 0 ); + + pClassView->AppendItem( rootId, _("wxWin Dynamic classes (grabbed at run-time)"), 0 ); + pClassView->AppendItem( rootId, _("serializer-classes (grabbed at run-time)"), 0 ); + // now create "output" window - wxNotebook* pTabbedArea = new wxNotebook(pParent, -1); + wxNotebook* pTabbedArea = new wxNotebook(pParent, wxID_ANY); // SEB: originally here was a wxpp (wxWorkshop) class used // wxPaggedWindow* pTabbedArea = new wxPaggedWindow(); - // pTabbedArea->Create( pParent, -1 ); - + // pTabbedArea->Create( pParent, wxID_ANY ); + wxPanel* pSheet3 = new wxPanel(); - pSheet3->Create( pTabbedArea, -1 ); - pSheet3->Show(FALSE); - - pTabbedArea->AddPage( CreateTxtCtrl("build", pTabbedArea), "Build"); - pTabbedArea->AddPage( CreateTxtCtrl("debug", pTabbedArea), "Debug"); - pTabbedArea->AddPage( pSheet3, "is THIS recursive - or what !?"); - pTabbedArea->AddPage( CreateTxtCtrl("profile", pTabbedArea), "Profile"); - - layout.AddBar( new StartButton95(pParent), sizes5, FL_ALIGN_TOP, 0, 0, "Start..." ); - layout.AddBar( pClassView, sizes4, FL_ALIGN_LEFT, 0, 0, "Project Workplace" ); - layout.AddBar( pTabbedArea, sizes4, FL_ALIGN_BOTTOM, 0, 50, "Output" ); - + pSheet3->Create( pTabbedArea, wxID_ANY ); + pSheet3->Show(false); + + pTabbedArea->AddPage( CreateTxtCtrl(wxT("build"), pTabbedArea), wxT("Build")); + pTabbedArea->AddPage( CreateTxtCtrl(wxT("debug"), pTabbedArea), wxT("Debug")); + pTabbedArea->AddPage( pSheet3, wxT("is THIS recursive - or what !?")); + pTabbedArea->AddPage( CreateTxtCtrl(wxT("profile"), pTabbedArea), wxT("Profile")); + + layout.AddBar( new StartButton95(pParent), sizes5, FL_ALIGN_TOP, 0, 0, wxT("Start...") ); + layout.AddBar( pClassView, sizes4, FL_ALIGN_LEFT, 0, 0, wxT("Project Workplace") ); + layout.AddBar( pTabbedArea, sizes4, FL_ALIGN_BOTTOM, 0, 50, wxT("Output") ); + return pSheet3; } void MyFrame::DropInSomeBars( int layoutNo ) { /* create once... and forget! */ - + // setup dimension infos for various bar shapes - + int cbWidth = 90; int cbHeight = 30; - - if ( layoutNo == SECOND_LAYOUT ) + + if ( layoutNo == SECOND_LAYOUT ) cbHeight = 60; - + wxFrameLayout& layout = *mLayouts[layoutNo]; - + cbDimInfo sizes( cbWidth,cbHeight, // when docked horizontally cbWidth,cbHeight, // when docked vertically cbWidth,cbHeight, // when floated - TRUE // true - bar is fixed-size - ); - + true // true - bar is fixed-size + ); + cbWidth = 120; - + cbDimInfo sizes1( cbWidth,cbHeight, cbWidth,cbHeight, - cbWidth,cbHeight, FALSE ); // false - bar is "flexible" + cbWidth,cbHeight, false ); // false - bar is "flexible" cbWidth = 120; cbHeight = 40; - + cbDimInfo sizes3( cbWidth,cbHeight, cbWidth,cbHeight, - cbWidth,cbHeight, TRUE ); // -/- - + cbWidth,cbHeight, true ); // -/- + cbWidth = 200; cbHeight = 150; - + cbDimInfo sizes4( cbWidth,cbHeight, cbWidth,cbHeight, - cbWidth,cbHeight, FALSE ); // -/- - + cbWidth,cbHeight, false ); // -/- + cbWidth = 63; cbHeight = 31; - + cbDimInfo sizes5( cbWidth,cbHeight, cbHeight,cbWidth, - cbWidth,cbHeight, TRUE, + cbWidth,cbHeight, true, 3, // vertical gap (bar border) 3 // horizontal gap (bar border) ); // -/- - - + + if ( layoutNo == FIRST_LAYOUT ) { // add 4 fixed-size bars (`sizes' dim-info) and one "flexible" (with `sizes1' dim-info) - + wxWindow* pGreenOne = new MyTestPanel(mpInternalFrm); - + pGreenOne->SetBackgroundColour( wxColour(128,255,128) ); - - layout.AddBar( pGreenOne, sizes, FL_ALIGN_TOP, 0, 50, "Bar1", TRUE ); - layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_TOP, 2, 50, "Bar2", TRUE ); - layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_BOTTOM, 2, 50, "Bar3", TRUE ); - layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_LEFT, 2, 50, "Bar4", TRUE ); - layout.AddBar( new MyTestPanel(mpInternalFrm), sizes1, wxCBAR_HIDDEN, 2, 50, "Super-Bar", TRUE ); + + layout.AddBar( pGreenOne, sizes, FL_ALIGN_TOP, 0, 50, wxT("Bar1"), true ); + layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_TOP, 2, 50, wxT("Bar2"), true ); + layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_BOTTOM, 2, 50, wxT("Bar3"), true ); + layout.AddBar( new MyTestPanel(mpInternalFrm), sizes, FL_ALIGN_LEFT, 2, 50, wxT("Bar4"), true ); + layout.AddBar( new MyTestPanel(mpInternalFrm), sizes1, wxCBAR_HIDDEN, 2, 50, wxT("Super-Bar"), true ); } else { if ( layoutNo == SECOND_LAYOUT ) { // show off various wx-controls in the second layout - - layout.AddBar( CreateTxtCtrl(), sizes, FL_ALIGN_TOP, 0, 50, "Fixed text Area&0" ); - layout.AddBar( CreateButton("OK"), sizes, FL_ALIGN_TOP, 0, 100, "First Button" ); - layout.AddBar( CreateTxtCtrl(), sizes1, FL_ALIGN_BOTTOM, 0, 50, "First Tree" ); - layout.AddBar( CreateTreeCtrl("Root"), sizes1, FL_ALIGN_LEFT, 0, 0, "TreeCtrl Window" ); - layout.AddBar( CreateChoice("Choice 1"), sizes3, FL_ALIGN_TOP, 0, 0, "Choice 1 (buggy)", FALSE, wxCBAR_HIDDEN ); - layout.AddBar( CreateChoice("Choice 2"), sizes3, FL_ALIGN_TOP, 0, 0, "Choice 2 (buggy)", FALSE, wxCBAR_HIDDEN ); - layout.AddBar( CreateTreeCtrl("X-Files"), sizes1, FL_ALIGN_RIGHT, 0, 100, "X-Files" ); - layout.AddBar( CreateTxtCtrl("smaller1"), sizes3, FL_ALIGN_TOP, 0, 50, "smaller Area1" ); - layout.AddBar( CreateTxtCtrl("smaller2"), sizes3, FL_ALIGN_TOP, 0, 50, "sm&ller Area2" ); + + layout.AddBar( CreateTxtCtrl(), sizes, FL_ALIGN_TOP, 0, 50, wxT("Fixed text Area&0") ); + layout.AddBar( CreateButton(wxT("OK")), sizes, FL_ALIGN_TOP, 0, 100, wxT("First Button") ); + layout.AddBar( CreateTxtCtrl(), sizes1, FL_ALIGN_BOTTOM, 0, 50, wxT("First Tree") ); + layout.AddBar( CreateTreeCtrl(wxT("Root")), sizes1, FL_ALIGN_LEFT, 0, 0, wxT("TreeCtrl Window") ); + layout.AddBar( CreateChoice(wxT("Choice 1")), sizes3, FL_ALIGN_TOP, 0, 0, wxT("Choice 1 (buggy)"), false, wxCBAR_HIDDEN ); + layout.AddBar( CreateChoice(wxT("Choice 2")), sizes3, FL_ALIGN_TOP, 0, 0, wxT("Choice 2 (buggy)"), false, wxCBAR_HIDDEN ); + layout.AddBar( CreateTreeCtrl(wxT("X-Files")), sizes1, FL_ALIGN_RIGHT, 0, 100, wxT("X-Files") ); + layout.AddBar( CreateTxtCtrl(wxT("smaller1")), sizes3, FL_ALIGN_TOP, 0, 50, wxT("smaller Area1") ); + layout.AddBar( CreateTxtCtrl(wxT("smaller2")), sizes3, FL_ALIGN_TOP, 0, 50, wxT("sm&ller Area2") ); } else { @@ -779,113 +778,113 @@ void MyFrame::DropInSomeBars( int layoutNo ) #if defined(__WXGTK__) || defined(__WXX11__) cbCommonPaneProperties props; layout.GetPaneProperties( props ); - props.mRealTimeUpdatesOn = FALSE; // real-time OFF for gtk!!! + props.mRealTimeUpdatesOn = false; // real-time OFF for gtk!!! layout.SetPaneProperties( props, wxALL_PANES ); #endif - - layout.AddBar( CreateTxtCtrl("Tool1"), sizes3, FL_ALIGN_TOP, 0, 50, "Fixed text Area1" ); - layout.AddBar( CreateTxtCtrl("Tool2"), sizes3, FL_ALIGN_TOP, 0, 50, "Fixed text Area2" ); - layout.AddBar( CreateTxtCtrl("Tool3"), sizes3, FL_ALIGN_TOP, 0, 50, "Fixed text Area3" ); - layout.AddBar( CreateTxtCtrl("Tool4"), sizes3, FL_ALIGN_TOP, 1, 50, "Fixed text Area4" ); - layout.AddBar( CreateTxtCtrl("Tool5"), sizes3, FL_ALIGN_TOP, 1, 50, "Fixed text Area5" ); - layout.AddBar( CreateTxtCtrl("Tool6"), sizes3, FL_ALIGN_TOP, 1, 50, "Fixed text Area6" ); - layout.AddBar( CreateTxtCtrl("Tool7"), sizes3, FL_ALIGN_TOP, 2,250, "Fixed text Area7" ); - - cbDimInfo sizes10( 175,35, // when docked horizontally - 175,38, // when docked vertically - 170,35, // when floated - TRUE, // the bar is not fixed-size + + layout.AddBar( CreateTxtCtrl(wxT("Tool1")), sizes3, FL_ALIGN_TOP, 0, 50, wxT("Fixed text Area1") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool2")), sizes3, FL_ALIGN_TOP, 0, 50, wxT("Fixed text Area2") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool3")), sizes3, FL_ALIGN_TOP, 0, 50, wxT("Fixed text Area3") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool4")), sizes3, FL_ALIGN_TOP, 1, 50, wxT("Fixed text Area4") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool5")), sizes3, FL_ALIGN_TOP, 1, 50, wxT("Fixed text Area5") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool6")), sizes3, FL_ALIGN_TOP, 1, 50, wxT("Fixed text Area6") ); + layout.AddBar( CreateTxtCtrl(wxT("Tool7")), sizes3, FL_ALIGN_TOP, 2,250, wxT("Fixed text Area7") ); + + cbDimInfo sizes10( 175,35, // when docked horizontally + 175,38, // when docked vertically + 170,35, // when floated + true, // the bar is not fixed-size 4, // vertical gap (bar border) 4, // horizontal gap (bar border) new cbDynToolBarDimHandler() - ); - + ); + wxDynamicToolBar* pToolBar = new wxDynamicToolBar(); - - pToolBar->Create( mpInternalFrm, -1 ); - + + pToolBar->Create( mpInternalFrm, wxID_ANY ); + // 1001-1006 ids of command events fired by added tool-buttons - - pToolBar->AddTool( 1001, BMP_DIR "new.bmp" ); - pToolBar->AddTool( 1002, BMP_DIR "open.bmp" ); - pToolBar->AddTool( 1003, BMP_DIR "save.bmp" ); - - pToolBar->AddTool( 1004, BMP_DIR "cut.bmp" ); - pToolBar->AddTool( 1005, BMP_DIR "copy.bmp" ); - pToolBar->AddTool( 1006, BMP_DIR "paste.bmp" ); - + + pToolBar->AddTool( 1001, wxString(wxT(BMP_DIR)) + wxT("new.bmp") ); + pToolBar->AddTool( 1002, wxString(wxT(BMP_DIR)) + wxT("open.bmp") ); + pToolBar->AddTool( 1003, wxString(wxT(BMP_DIR)) + wxT("save.bmp") ); + + pToolBar->AddTool( 1004, wxString(wxT(BMP_DIR)) + wxT("cut.bmp") ); + pToolBar->AddTool( 1005, wxString(wxT(BMP_DIR)) + wxT("copy.bmp") ); + pToolBar->AddTool( 1006, wxString(wxT(BMP_DIR)) + wxT("paste.bmp") ); + layout.AddBar( pToolBar, // bar window (can be NULL) sizes10, FL_ALIGN_TOP, // alignment ( 0-top,1-bottom, etc) 0, // insert into 0th row (vert. position) 0, // offset from the start of row (in pixels) - "Real-Toolbar", // name to refere in customization pop-ups - FALSE + wxT("Real-Toolbar"), // name to refere in customization pop-ups + false ); - + // create first "developement" layout AddSearchToolbars( layout, mpInternalFrm); - + wxWindow* pSheet3 = CreateDevLayout( layout, mpInternalFrm); - + // create another ***secreat developement*** layout inside // the third sheet of the outter one's output bar - - mpNestedLayout = new wxFrameLayout( pSheet3, - CreateTxtCtrl("\"Mobils in Mobile\" --C.Nemo",pSheet3), FALSE ); - + + mpNestedLayout = new wxFrameLayout( pSheet3, + CreateTxtCtrl(wxT("\"Mobils in Mobile\" --C.Nemo"),pSheet3), false ); + CreateDevLayout( *mpNestedLayout, pSheet3 ); - + mpNestedLayout->Activate(); } } } -} +} void MyFrame::CreateLayout( int layoutNo ) { - wxFrameLayout* pLayout = new wxFrameLayout( mpInternalFrm, mpClntWindow, FALSE ); - + wxFrameLayout* pLayout = new wxFrameLayout( mpInternalFrm, mpClntWindow, false ); + if ( layoutNo == THIRD_LAYOUT ) { pLayout->PushDefaultPlugins(); pLayout->AddPlugin( CLASSINFO( cbBarHintsPlugin ) ); // facny "X"es and beveal for bars -#if defined(__WXGTK__) || defined(__WXX11__) +#if defined(__WXGTK__) || defined(__WXX11__) pLayout->AddPlugin( CLASSINFO( cbHintAnimationPlugin ) ); #endif - pLayout->AddPlugin( CLASSINFO( cbRowDragPlugin ) ); + pLayout->AddPlugin( CLASSINFO( cbRowDragPlugin ) ); } - + mLayouts[layoutNo] = pLayout; - + DropInSomeBars( layoutNo ); } void MyFrame::RemoveLayout( int layoutNo ) { wxFrameLayout* pLayout = mLayouts[layoutNo]; - - if ( !pLayout ) + + if ( !pLayout ) return; - + pLayout->HideBarWindows(); - + // destroy nested layout first - + if ( layoutNo == THIRD_LAYOUT ) { - if ( mpNestedLayout ) + if ( mpNestedLayout ) delete mpNestedLayout; mpNestedLayout = NULL; } - - // NOTE:: bar windows are NOT destroyed automatically by frame-layout - + + // NOTE:: bar windows are NOT destroyed automatically by frame-layout + pLayout->DestroyBarWindows(); - + delete pLayout; - + mLayouts[layoutNo] = NULL; - + Refresh(); } @@ -895,25 +894,25 @@ void MyFrame::SyncMenuBarItems() { GetMenuBar()->Check( ID_FIRST+i, mActiveLayoutNo == FIRST_LAYOUT+i ); } - + GetMenuBar()->Check( ID_AUTOSAVE, mAutoSave ); } void MyFrame::ActivateLayout( int layoutNo ) { - if ( layoutNo == mActiveLayoutNo ) + if ( layoutNo == mActiveLayoutNo ) return; - + if ( mLayouts[mActiveLayoutNo] ) mLayouts[mActiveLayoutNo]->Deactivate(); - + mActiveLayoutNo = layoutNo; - - if ( mLayouts[mActiveLayoutNo] ) + + if ( mLayouts[mActiveLayoutNo] ) mLayouts[mActiveLayoutNo]->Activate(); else Refresh(); - + SyncMenuBarItems(); } @@ -927,25 +926,24 @@ BEGIN_EVENT_TABLE( StartButton95, wxPanel ) EVT_PAINT ( StartButton95::OnPaint ) END_EVENT_TABLE() -void StartButton95::OnMouseDown( wxMouseEvent& event ) +void StartButton95::OnMouseDown( wxMouseEvent& WXUNUSED(event) ) { - m_bPressed = TRUE; + m_bPressed = true; Refresh(); CaptureMouse(); } -void StartButton95::OnMouseUp( wxMouseEvent& event ) +void StartButton95::OnMouseUp( wxMouseEvent& WXUNUSED(event) ) { // "this is not a bug" - + SetCursor( wxCURSOR_WAIT ); GetParent()->SetCursor( wxCURSOR_WAIT ); - ::wxSetCursor( wxCURSOR_WAIT ); + ::wxSetCursor( wxCURSOR_WAIT ); wxSleep(1); - - int i = 0; - for( i = 1; i != 6; ++i ) - { + + for( int i = 1; i != 6; ++i ) + { m_bPressed = (i % 2) != 0; Refresh(); wxSleep(1); @@ -954,33 +952,33 @@ void StartButton95::OnMouseUp( wxMouseEvent& event ) //*((char*)(i)-3) = 'X'; // Aleks what's the meaning of this??? } -void StartButton95::OnPaint( wxPaintEvent& event ) +void StartButton95::OnPaint( wxPaintEvent& WXUNUSED(event) ) { - wxBitmap* pBmp = 0; - + wxBitmap* pBmp; + if ( m_bPressed ) { - if ( !m_PBmp.Ok() && wxFileExists( BMP_DIR "start95_pr.bmp" ) ) - - m_PBmp.LoadFile( BMP_DIR "start95_pr.bmp", wxBITMAP_TYPE_BMP ); - + if ( !m_PBmp.Ok() && wxFileExists( wxString(wxT(BMP_DIR)) + wxT("start95_pr.bmp") ) ) + + m_PBmp.LoadFile( wxString(wxT(BMP_DIR)) + wxT("start95_pr.bmp"), wxBITMAP_TYPE_BMP ); + pBmp = &m_PBmp; } else { - if ( !m_DBmp.Ok() && wxFileExists( BMP_DIR "start95_dp.bmp" ) ) - - m_DBmp.LoadFile( BMP_DIR "start95_dp.bmp", wxBITMAP_TYPE_BMP ); - + if ( !m_DBmp.Ok() && wxFileExists( wxString(wxT(BMP_DIR)) + wxT("start95_dp.bmp") ) ) + + m_DBmp.LoadFile( wxString(wxT(BMP_DIR)) + wxT("start95_dp.bmp"), wxBITMAP_TYPE_BMP ); + pBmp = &m_DBmp; } - + if (!pBmp) return; wxMemoryDC mdc; wxPaintDC dc(this); mdc.SelectObject( *pBmp ); - + dc.Blit( 0,0, pBmp->GetWidth(), pBmp->GetHeight(), &mdc, 0,0, wxCOPY ); - + mdc.SelectObject( wxNullBitmap ); }