public:
MyTopLabels() {}
MyTopLabels( wxScrolledWindow *parent, wxWindowID id, const wxPoint &pos, const wxSize &size );
-
+
void OnPaint( wxPaintEvent &event );
-
+
private:
wxScrolledWindow *m_owner;
-
+
DECLARE_DYNAMIC_CLASS(MyTopLabels)
DECLARE_EVENT_TABLE()
};
public:
MyRightLabels() {}
MyRightLabels( wxScrolledWindow *parent, wxWindowID id, const wxPoint &pos, const wxSize &size );
-
+
void OnPaint( wxPaintEvent &event );
-
+
private:
wxScrolledWindow *m_owner;
-
+
DECLARE_DYNAMIC_CLASS(MyRightLabels)
DECLARE_EVENT_TABLE()
};
MyScrolledWindow::MyScrolledWindow( wxWindow *parent, wxWindowID id,
const wxPoint &pos, const wxSize &size )
- : wxScrolledWindow( parent, id, pos, size, wxSUNKEN_BORDER, "test canvas" )
+ : wxScrolledWindow( parent, id, pos, size, wxSUNKEN_BORDER, _T("test canvas") )
{
MyTopLabels *top = new MyTopLabels( this, -1, wxDefaultPosition, wxSize(-1,25) );
MyRightLabels *right = new MyRightLabels( this, -1, wxDefaultPosition, wxSize(60,-1) );
m_canvas = new MyCanvas( this, top, right, -1, wxDefaultPosition, wxDefaultSize );
-
+
SetTargetWindow( m_canvas );
- SetBackgroundColour( "WHEAT" );
-
+ SetBackgroundColour( wxT("WHEAT") );
+
SetCursor( wxCursor( wxCURSOR_HAND ) );
-
+
wxBoxSizer *mainsizer = new wxBoxSizer( wxVERTICAL );
-
+
wxBoxSizer *topsizer = new wxBoxSizer( wxHORIZONTAL );
topsizer->Add( 60,25 );
- topsizer->Add( top, 1 );
-
+ topsizer->Add( top, 1, wxEXPAND );
+
mainsizer->Add( topsizer, 0, wxEXPAND );
-
+
wxBoxSizer *middlesizer = new wxBoxSizer( wxHORIZONTAL );
middlesizer->Add( right, 0, wxEXPAND );
middlesizer->Add( m_canvas, 1, wxEXPAND );
-
+
mainsizer->Add( middlesizer, 1, wxEXPAND );
SetAutoLayout( TRUE );
/*
wxSize size( GetClientSize() );
-
+
long w,h;
dc.GetTextExtent( wxT("Headline"), &w, &h );
void MyTopLabels::OnPaint( wxPaintEvent &event )
{
wxPaintDC dc(this);
- m_owner->PrepareDC( dc );
- dc.DrawText( "Column 1", 5, 5 );
- dc.DrawText( "Column 2", 105, 5 );
- dc.DrawText( "Column 3", 205, 5 );
+
+ // This is wrong.. it will translate both x and y if the
+ // window is scrolled, the label windows are active in one
+ // direction only. Do the action below instead -- RL.
+ //m_owner->PrepareDC( dc );
+
+ int xScrollUnits, xOrigin;
+
+ m_owner->GetViewStart( &xOrigin, 0 );
+ m_owner->GetScrollPixelsPerUnit( &xScrollUnits, 0 );
+ dc.SetDeviceOrigin( -xOrigin * xScrollUnits, 0 );
+
+ dc.DrawText( _T("Column 1"), 5, 5 );
+ dc.DrawText( _T("Column 2"), 105, 5 );
+ dc.DrawText( _T("Column 3"), 205, 5 );
}
// MyRightLabels
void MyRightLabels::OnPaint( wxPaintEvent &event )
{
wxPaintDC dc(this);
- m_owner->PrepareDC( dc );
- dc.DrawText( "Row 1", 5, 5 );
- dc.DrawText( "Row 2", 5, 30 );
- dc.DrawText( "Row 3", 5, 55 );
- dc.DrawText( "Row 4", 5, 80 );
- dc.DrawText( "Row 5", 5, 105 );
- dc.DrawText( "Row 6", 5, 130 );
+
+ // This is wrong.. it will translate both x and y if the
+ // window is scrolled, the label windows are active in one
+ // direction only. Do the action below instead -- RL.
+ //m_owner->PrepareDC( dc );
+
+ int yScrollUnits, yOrigin;
+
+ m_owner->GetViewStart( 0, &yOrigin );
+ m_owner->GetScrollPixelsPerUnit( 0, &yScrollUnits );
+ dc.SetDeviceOrigin( 0, -yOrigin * yScrollUnits );
+
+ dc.DrawText( _T("Row 1"), 5, 5 );
+ dc.DrawText( _T("Row 2"), 5, 30 );
+ dc.DrawText( _T("Row 3"), 5, 55 );
+ dc.DrawText( _T("Row 4"), 5, 80 );
+ dc.DrawText( _T("Row 5"), 5, 105 );
+ dc.DrawText( _T("Row 6"), 5, 130 );
}
// MyCanvas
MyCanvas::MyCanvas( wxScrolledWindow *parent, MyTopLabels *top, MyRightLabels *right,
wxWindowID id, const wxPoint &pos, const wxSize &size )
- : wxPanel( parent, id, pos, size, wxSUNKEN_BORDER, "test canvas" )
+ : wxPanel( parent, id, pos, size, wxSUNKEN_BORDER, _T("test canvas") )
{
m_owner = parent;
m_topLabels = top;
m_rightLabels = right;
-
- (void)new wxButton( this, -1, "Hallo I", wxPoint(0,50), wxSize(100,25) );
- (void)new wxButton( this, -1, "Hallo II", wxPoint(200,50), wxSize(100,25) );
-
- (void)new wxTextCtrl( this, -1, "Text I", wxPoint(0,100), wxSize(100,25) );
- (void)new wxTextCtrl( this, -1, "Text II", wxPoint(200,100), wxSize(100,25) );
-
- SetBackgroundColour( "WHEAT" );
-
+
+ (void)new wxButton( this, -1, _T("Hallo I"), wxPoint(0,50), wxSize(100,25) );
+ (void)new wxButton( this, -1, _T("Hallo II"), wxPoint(200,50), wxSize(100,25) );
+
+ (void)new wxTextCtrl( this, -1, _T("Text I"), wxPoint(0,100), wxSize(100,25) );
+ (void)new wxTextCtrl( this, -1, _T("Text II"), wxPoint(200,100), wxSize(100,25) );
+
+ (void)new wxComboBox( this, -1, _T("ComboBox I"), wxPoint(0,150), wxSize(100,25), 0, NULL );
+ (void)new wxComboBox( this, -1, _T("ComboBox II"), wxPoint(200,150), wxSize(100,25), 0, NULL );
+
+ SetBackgroundColour( wxT("WHEAT") );
+
SetCursor( wxCursor( wxCURSOR_IBEAM ) );
}
m_owner->PrepareDC( dc );
dc.SetPen( *wxBLACK_PEN );
-
+
// OK, let's assume we are a grid control and we have two
// grid cells. Here in OnPaint we want to know which cell
// to redraw so that we prevent redrawing cells that don't
// need to get redrawn. We have one cell at (0,0) and one
// more at (200,0), both having a size of (100,25).
-
- // We can query how much the window has been scrolled
+
+ // We can query how much the window has been scrolled
// by calling CalcUnscrolledPosition()
-
+
int scroll_x = 0;
int scroll_y = 0;
m_owner->CalcUnscrolledPosition( scroll_x, scroll_y, &scroll_x, &scroll_y );
-
+
// We also need to know the size of the window to see which
// cells are completely hidden and not get redrawn
-
+
int size_x = 0;
int size_y = 0;
GetClientSize( &size_x, &size_y );
-
+
// First cell: (0,0)(100,25)
// It it on screen?
if ((0+100-scroll_x > 0) && (0+25-scroll_y > 0) &&
(0-scroll_x < size_x) && (0-scroll_y < size_y))
{
// Has the region on screen been exposed?
- if (IsExposed(0,0,100,25))
- {
- wxLogMessage( "Redraw first cell" );
+ if (IsExposed(0,0,100,25))
+ {
+ wxLogMessage( wxT("Redraw first cell") );
dc.DrawRectangle( 0, 0, 100, 25 );
- dc.DrawText( "First Cell", 5, 5 );
- }
+ dc.DrawText( _T("First Cell"), 5, 5 );
+ }
}
-
-
+
+
// Second cell: (0,200)(100,25)
// It it on screen?
if ((200+100-scroll_x > 0) && (0+25-scroll_y > 0) &&
(200-scroll_x < size_x) && (0-scroll_y < size_y))
{
// Has the region on screen been exposed?
- if (IsExposed(200,0,100,25))
- {
- wxLogMessage( "Redraw second cell" );
+ if (IsExposed(200,0,100,25))
+ {
+ wxLogMessage( wxT("Redraw second cell") );
dc.DrawRectangle( 200, 0, 100, 25 );
- dc.DrawText( "Second Cell", 205, 5 );
- }
+ dc.DrawText( _T("Second Cell"), 205, 5 );
+ }
}
-
+
}
void MyCanvas::ScrollWindow( int dx, int dy, const wxRect *rect )
END_EVENT_TABLE()
MyFrame::MyFrame()
- : wxFrame( (wxFrame *)NULL, -1, "wxScrolledWindow sample",
+ : wxFrame( (wxFrame *)NULL, -1, _T("wxScrolledWindow sample"),
wxPoint(20,20), wxSize(470,500) )
{
wxMenu *file_menu = new wxMenu();
- file_menu->Append( ID_ABOUT, "&About...");
- file_menu->Append( ID_FULL, "&Full screen on/off");
- file_menu->Append( ID_QUIT, "E&xit\tAlt-X");
+ file_menu->Append( ID_ABOUT, _T("&About..."));
+ file_menu->Append( ID_FULL, _T("&Full screen on/off"));
+ file_menu->Append( ID_QUIT, _T("E&xit\tAlt-X"));
wxMenuBar *menu_bar = new wxMenuBar();
- menu_bar->Append(file_menu, "&File");
+ menu_bar->Append(file_menu, _T("&File"));
SetMenuBar( menu_bar );
m_scrolled = new MyScrolledWindow( this, -1, wxDefaultPosition, wxSize(100,100) );
m_scrolled->SetScrollbars( 10, 10, 50, 100 );
-
- m_log = new wxTextCtrl( this, -1, "This is the log window.\n", wxPoint(0,0), wxSize(100,100), wxTE_MULTILINE );
+
+ m_log = new wxTextCtrl( this, -1, _T("This is the log window.\n"), wxPoint(0,0), wxSize(100,100), wxTE_MULTILINE );
wxLog *old_log = wxLog::SetActiveTarget( new wxLogTextCtrl( m_log ) );
delete old_log;
-
+
wxBoxSizer *topsizer = new wxBoxSizer( wxVERTICAL );
topsizer->Add( m_scrolled, 1, wxEXPAND );
topsizer->Add( m_log, 0, wxEXPAND );
void MyFrame::OnAbout( wxCommandEvent &WXUNUSED(event) )
{
- (void)wxMessageBox( "wxScroll demo II\n"
- "Robert Roebling (c) 1998",
- "About wxScroll II Demo", wxICON_INFORMATION | wxOK );
+ (void)wxMessageBox( _T("wxScroll demo II\n")
+ _T("Robert Roebling (c) 1998"),
+ _T("About wxScroll II Demo"), wxICON_INFORMATION | wxOK );
}
//-----------------------------------------------------------------------------