MyScrolledWindow( wxWindow *parent, wxWindowID id, const wxPoint &pos, const wxSize &size );
~MyScrolledWindow(){};
void OnPaint( wxPaintEvent &event );
-
+ void OnSize( wxSizeEvent &event );
private:
MyCanvas *m_canvas;
IMPLEMENT_DYNAMIC_CLASS(MyScrolledWindow, wxScrolledWindow)
BEGIN_EVENT_TABLE(MyScrolledWindow, wxScrolledWindow)
- EVT_PAINT( MyScrolledWindow::OnPaint)
+ EVT_PAINT( MyScrolledWindow::OnPaint)
+ EVT_SIZE( MyScrolledWindow::OnSize)
END_EVENT_TABLE()
MyScrolledWindow::MyScrolledWindow( wxWindow *parent, wxWindowID id,
mainsizer->Add( middlesizer, 1, wxEXPAND );
- SetAutoLayout( true );
SetSizer( mainsizer );
}
+void MyScrolledWindow::OnSize( wxSizeEvent &WXUNUSED(event) )
+{
+ // We need to override OnSize so that our scrolled
+ // window a) does call Layout() to use sizers for
+ // positioning the controls but b) does not query
+ // the sizer for their size and use that for setting
+ // the scrollable area as set that ourselves by
+ // calling SetScrollbar() further down.
+
+ Layout();
+
+ AdjustScrollbars();
+}
+
void MyScrolledWindow::OnPaint( wxPaintEvent &WXUNUSED(event) )
{
wxPaintDC dc( this );
// MyFrame
-const int ID_QUIT = 108;
+const int ID_QUIT = wxID_EXIT;
const int ID_FULL = 109;
-const int ID_ABOUT = 110;
+const int ID_ABOUT = wxID_ABOUT;
IMPLEMENT_DYNAMIC_CLASS( MyFrame, wxFrame )
topsizer->Add( m_log, 0, wxEXPAND );
#endif // wxUSE_LOG
- SetAutoLayout( true );
SetSizer( topsizer );
}
bool MyApp::OnInit()
{
+ if ( !wxApp::OnInit() )
+ return false;
+
wxFrame *frame = new MyFrame();
frame->Show( true );