{
GridFrame *frame = new GridFrame;
frame->Show( TRUE );
-
+
return TRUE;
}
BEGIN_EVENT_TABLE( GridFrame, wxFrame )
EVT_MENU( ID_TOGGLEROWLABELS, GridFrame::ToggleRowLabels )
- EVT_MENU( ID_TOGGLECOLLABELS, GridFrame::ToggleColLabels )
+ EVT_MENU( ID_TOGGLECOLLABELS, GridFrame::ToggleColLabels )
EVT_MENU( ID_TOGGLEEDIT, GridFrame::ToggleEditing )
- EVT_MENU( ID_SETLABELCOLOUR, GridFrame::SetLabelColour )
- EVT_MENU( ID_SETLABELTEXTCOLOUR, GridFrame::SetLabelTextColour )
- EVT_MENU( ID_ROWLABELHORIZALIGN, GridFrame::SetRowLabelHorizAlignment )
- EVT_MENU( ID_ROWLABELVERTALIGN, GridFrame::SetRowLabelVertAlignment )
- EVT_MENU( ID_COLLABELHORIZALIGN, GridFrame::SetColLabelHorizAlignment )
- EVT_MENU( ID_COLLABELVERTALIGN, GridFrame::SetColLabelVertAlignment )
+ EVT_MENU( ID_SETLABELCOLOUR, GridFrame::SetLabelColour )
+ EVT_MENU( ID_SETLABELTEXTCOLOUR, GridFrame::SetLabelTextColour )
+ EVT_MENU( ID_ROWLABELHORIZALIGN, GridFrame::SetRowLabelHorizAlignment )
+ EVT_MENU( ID_ROWLABELVERTALIGN, GridFrame::SetRowLabelVertAlignment )
+ EVT_MENU( ID_COLLABELHORIZALIGN, GridFrame::SetColLabelHorizAlignment )
+ EVT_MENU( ID_COLLABELVERTALIGN, GridFrame::SetColLabelVertAlignment )
EVT_MENU( ID_GRIDLINECOLOUR, GridFrame::SetGridLineColour )
EVT_MENU( ID_INSERTROW, GridFrame::InsertRow )
EVT_MENU( ID_INSERTCOL, GridFrame::InsertCol )
EVT_MENU( ID_DELETEROW, GridFrame::DeleteSelectedRows )
EVT_MENU( ID_DELETECOL, GridFrame::DeleteSelectedCols )
EVT_MENU( ID_CLEARGRID, GridFrame::ClearGrid )
-
+
EVT_MENU( ID_ABOUT, GridFrame::About )
EVT_MENU( wxID_EXIT, GridFrame::OnQuit )
EVT_GRID_SELECT_CELL( GridFrame::OnSelectCell )
EVT_GRID_RANGE_SELECT( GridFrame::OnRangeSelected )
EVT_GRID_CELL_CHANGE( GridFrame::OnCellValueChanged )
-
+
END_EVENT_TABLE()
-
+
GridFrame::GridFrame()
: wxFrame( (wxFrame *)NULL, -1, "wxWindows grid class demo",
wxDefaultPosition,
{
int gridW = 600, gridH = 300;
int logW = gridW, logH = 80;
-
+
wxMenu *fileMenu = new wxMenu;
- fileMenu->Append( wxID_EXIT, "E&xit" );
-
+ fileMenu->Append( wxID_EXIT, "E&xit\tAlt-X" );
+
wxMenu *viewMenu = new wxMenu;
viewMenu->Append( ID_TOGGLEROWLABELS, "&Row labels", "", TRUE );
viewMenu->Append( ID_TOGGLECOLLABELS, "&Col labels", "", TRUE );
viewMenu->Append( ID_TOGGLEEDIT, "&Editable", "", TRUE );
viewMenu->Append( ID_SETLABELCOLOUR, "Set &label colour" );
viewMenu->Append( ID_SETLABELTEXTCOLOUR, "Set label &text colour" );
-
+
wxMenu *rowLabelMenu = new wxMenu;
viewMenu->Append( ID_ROWLABELALIGN, "R&ow label alignment",
"Change alignment of row labels" );
rowLabelMenu->Append( ID_ROWLABELHORIZALIGN, "&Horizontal" );
- rowLabelMenu->Append( ID_ROWLABELVERTALIGN, "&Vertical" );
-
+ rowLabelMenu->Append( ID_ROWLABELVERTALIGN, "&Vertical" );
+
wxMenu *colLabelMenu = new wxMenu;
viewMenu->Append( ID_COLLABELALIGN, "Col l&abel alignment",
editMenu->Append( ID_DELETEROW, "Delete selected ro&ws" );
editMenu->Append( ID_DELETECOL, "Delete selected co&ls" );
editMenu->Append( ID_CLEARGRID, "Cl&ear grid cell contents" );
-
+
wxMenu *helpMenu = new wxMenu;
helpMenu->Append( ID_ABOUT, "&About wxGrid demo" );
-
+
wxMenuBar *menuBar = new wxMenuBar;
menuBar->Append( fileMenu, "&File" );
menuBar->Append( viewMenu, "&View" );
-1,
wxPoint( 0, 0 ),
wxSize( 400, 300 ) );
-
+
logWin = new wxTextCtrl( this,
-1,
wxEmptyString,
wxPoint( 0, gridH + 20 ),
wxSize( logW, logH ),
wxTE_MULTILINE );
-
+
logger = new wxLogTextCtrl( logWin );
logger->SetActiveTarget( logger );
logger->SetTimestamp( NULL );
grid->SetRowSize( 0, 60 );
grid->SetCellValue( 0, 0, "Ctrl+Home\nwill go to\nthis cell" );
-
+
grid->SetCellValue( 0, 1, "Blah" );
grid->SetCellValue( 0, 2, "Blah" );
topSizer->Add( grid,
1,
wxEXPAND );
-
+
topSizer->Add( logWin,
- 0,
+ 0,
wxEXPAND );
-
+
SetAutoLayout( TRUE );
SetSizer( topSizer );
-
+
topSizer->Fit( this );
topSizer->SetSizeHints( this );
-
+
Centre();
SetDefaults();
}
{
int horiz, vert;
grid->GetRowLabelAlignment( &horiz, &vert );
-
+
switch ( horiz )
{
case wxLEFT:
horiz = wxCENTRE;
break;
-
+
case wxCENTRE:
horiz = wxRIGHT;
break;
{
int horiz, vert;
grid->GetRowLabelAlignment( &horiz, &vert );
-
+
switch ( vert )
{
case wxTOP:
vert = wxCENTRE;
break;
-
+
case wxCENTRE:
vert = wxBOTTOM;
break;
{
int horiz, vert;
grid->GetColLabelAlignment( &horiz, &vert );
-
+
switch ( horiz )
{
case wxLEFT:
horiz = wxCENTRE;
break;
-
+
case wxCENTRE:
horiz = wxRIGHT;
break;
{
int horiz, vert;
grid->GetColLabelAlignment( &horiz, &vert );
-
+
switch ( vert )
{
case wxTOP:
vert = wxCENTRE;
break;
-
+
case wxCENTRE:
vert = wxBOTTOM;
break;
if ( ev.ShiftDown() ) logBuf << " (shift down)";
wxLogMessage( "%s", logBuf.c_str() );
-
+
// you must call event skip if you want default grid processing
//
ev.Skip();
logBuf = "";
logBuf << "Resized row " << ev.GetRowOrCol();
wxLogMessage( "%s", logBuf.c_str() );
-
+
ev.Skip();
}
logBuf = "";
logBuf << "Resized col " << ev.GetRowOrCol();
wxLogMessage( "%s", logBuf.c_str() );
-
+
ev.Skip();
}
logBuf << "Selected cell at row " << ev.GetRow()
<< " col " << ev.GetCol();
wxLogMessage( "%s", logBuf.c_str() );
-
+
// you must call Skip() if you want the default processing
// to occur in wxGrid
ev.Skip();
<< " col " << ev.GetLeftCol()
<< " to row " << ev.GetBottomRow()
<< " col " << ev.GetRightCol();
-
+
wxLogMessage( "%s", logBuf.c_str() );
-
+
ev.Skip();
}
{
logBuf = "";
logBuf << "Value changed for cell at"
- << " row " << ev.GetRow()
+ << " row " << ev.GetRow()
<< " col " << ev.GetCol();
-
+
wxLogMessage( "%s", logBuf.c_str() );
-
+
ev.Skip();
}
#include "wx/generic/grid.h"
-
//////////////////////////////////////////////////////////////////////
wxGridCellCoords wxGridNoCellCoords( -1, -1 );
WX_DEFINE_OBJARRAY(wxGridCellCoordsArray)
+// scroll line size
+// TODO: fixed so far - make configurable later (and also different for x/y)
+static const size_t GRID_SCROLL_LINE = 10;
//////////////////////////////////////////////////////////////////////
//
unsigned int i, n;
for ( n = 1; ; n++ )
{
- s += ('A' + (char)( col%26 ));
+ s += (_T('A') + (wxChar)( col%26 ));
col = col/26 - 1;
if ( col < 0 ) break;
}
// the other ports can handle a Return key press
//
event.Skip();
-#endif
+#endif
}
}
break;
void wxGridTextCtrl::SetStartValue( const wxString& s )
{
startValue = s;
- wxTextCtrl::SetValue( s.c_str() );
+ wxTextCtrl::SetValue(s);
}
//
void wxGrid::Create()
-{
+{
int colLblH = WXGRID_DEFAULT_COL_LABEL_HEIGHT;
int rowLblW = WXGRID_DEFAULT_ROW_LABEL_WIDTH;
//
int x, y;
GetViewStart( &x, &y );
- SetScrollbars( 10, 10,
- right/10, bottom/10,
+ SetScrollbars( GRID_SCROLL_LINE, GRID_SCROLL_LINE,
+ right/GRID_SCROLL_LINE, bottom/GRID_SCROLL_LINE,
x, y );
}
}
m_isDragging = TRUE;
if ( m_cursorMode == WXGRID_CURSOR_SELECT_CELL )
{
- // Hide the edit control, so it
- // won't interfer with drag-shrinking.
- if ( IsCellEditControlEnabled() )
- HideCellEditControl();
+ // Hide the edit control, so it
+ // won't interfer with drag-shrinking.
+ if ( IsCellEditControlEnabled() )
+ HideCellEditControl();
if ( coords != wxGridNoCellCoords )
{
if ( !IsSelection() )
}
else
{
- SelectBlock( m_currentCellCoords, coords );
+ SelectBlock( m_currentCellCoords, coords );
}
}
}
}
}
- // Show the edit control, if it has
- // been hidden for drag-shrinking.
- if ( IsCellEditControlEnabled() )
- ShowCellEditControl();
+ // Show the edit control, if it has
+ // been hidden for drag-shrinking.
+ if ( IsCellEditControlEnabled() )
+ ShowCellEditControl();
m_dragLastPos = -1;
}
rect.SetRight( rect.GetRight() + 2*extra );
rect.SetBottom( rect.GetBottom() + 2*extra );
-
+
m_cellEditCtrl->SetSize( rect );
m_cellEditCtrl->Show( TRUE );
h += m_rowHeights[i];
ypos -= m_rowHeights[i];
}
+
+ // we divide it later by GRID_SCROLL_LINE, make sure that we don't
+ // have rounding errors (this is important, because if we do, we
+ // might not scroll at all and some cells won't be redrawn)
+ ypos += GRID_SCROLL_LINE / 2;
}
if ( left < 0 )
w += m_colWidths[i];
xpos -= m_colWidths[i];
}
+
+ // see comment for ypos above
+ xpos += GRID_SCROLL_LINE / 2;
}
if ( xpos != -1 || ypos != -1 )
{
- if ( xpos != -1 ) xpos = xpos/10;
- if ( ypos != -1 ) ypos = ypos/10;
+ if ( xpos != -1 ) xpos /= GRID_SCROLL_LINE;
+ if ( ypos != -1 ) ypos /= GRID_SCROLL_LINE;
Scroll( xpos, ypos );
AdjustScrollbars();
}
leftCol = rightCol;
rightCol = temp;
}
-
+
updateTopLeft = m_selectedTopLeft;
if (m_selectedTopLeft != wxGridCellCoords( topRow, leftCol ) )
{
m_selectedTopLeft = wxGridCellCoords( topRow, leftCol );
- if (updateTopLeft == wxGridNoCellCoords)
- {
- updateTopLeft = m_selectedTopLeft;
- }
- else
- {
- if(updateTopLeft.GetRow() > topRow)
- updateTopLeft.SetRow(topRow);
- if (updateTopLeft.GetCol() > leftCol)
- updateTopLeft.SetCol(leftCol);
- }
- changed = true;
+ if (updateTopLeft == wxGridNoCellCoords)
+ {
+ updateTopLeft = m_selectedTopLeft;
+ }
+ else
+ {
+ if(updateTopLeft.GetRow() > topRow)
+ updateTopLeft.SetRow(topRow);
+ if (updateTopLeft.GetCol() > leftCol)
+ updateTopLeft.SetCol(leftCol);
+ }
+ changed = true;
}
updateBottomRight = m_selectedBottomRight;
if (m_selectedBottomRight != wxGridCellCoords( bottomRow, rightCol ) )
{
m_selectedBottomRight = wxGridCellCoords( bottomRow, rightCol );
- if (updateBottomRight == wxGridNoCellCoords)
- {
- updateBottomRight = m_selectedBottomRight;
- }
- else
- {
- if (updateBottomRight.GetRow() < bottomRow)
- updateBottomRight.SetRow(bottomRow);
- if (updateBottomRight.GetCol() < rightCol)
- updateBottomRight.SetCol(rightCol);
- }
- changed = true;
+ if (updateBottomRight == wxGridNoCellCoords)
+ {
+ updateBottomRight = m_selectedBottomRight;
+ }
+ else
+ {
+ if (updateBottomRight.GetRow() < bottomRow)
+ updateBottomRight.SetRow(bottomRow);
+ if (updateBottomRight.GetCol() < rightCol)
+ updateBottomRight.SetCol(rightCol);
+ }
+ changed = true;
}
if (changed)