fixed refresh problem due to rounding errors
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5835 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -38,7 +38,7 @@ bool GridApp::OnInit()
|
|||||||
{
|
{
|
||||||
GridFrame *frame = new GridFrame;
|
GridFrame *frame = new GridFrame;
|
||||||
frame->Show( TRUE );
|
frame->Show( TRUE );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -46,21 +46,21 @@ bool GridApp::OnInit()
|
|||||||
|
|
||||||
BEGIN_EVENT_TABLE( GridFrame, wxFrame )
|
BEGIN_EVENT_TABLE( GridFrame, wxFrame )
|
||||||
EVT_MENU( ID_TOGGLEROWLABELS, GridFrame::ToggleRowLabels )
|
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_TOGGLEEDIT, GridFrame::ToggleEditing )
|
||||||
EVT_MENU( ID_SETLABELCOLOUR, GridFrame::SetLabelColour )
|
EVT_MENU( ID_SETLABELCOLOUR, GridFrame::SetLabelColour )
|
||||||
EVT_MENU( ID_SETLABELTEXTCOLOUR, GridFrame::SetLabelTextColour )
|
EVT_MENU( ID_SETLABELTEXTCOLOUR, GridFrame::SetLabelTextColour )
|
||||||
EVT_MENU( ID_ROWLABELHORIZALIGN, GridFrame::SetRowLabelHorizAlignment )
|
EVT_MENU( ID_ROWLABELHORIZALIGN, GridFrame::SetRowLabelHorizAlignment )
|
||||||
EVT_MENU( ID_ROWLABELVERTALIGN, GridFrame::SetRowLabelVertAlignment )
|
EVT_MENU( ID_ROWLABELVERTALIGN, GridFrame::SetRowLabelVertAlignment )
|
||||||
EVT_MENU( ID_COLLABELHORIZALIGN, GridFrame::SetColLabelHorizAlignment )
|
EVT_MENU( ID_COLLABELHORIZALIGN, GridFrame::SetColLabelHorizAlignment )
|
||||||
EVT_MENU( ID_COLLABELVERTALIGN, GridFrame::SetColLabelVertAlignment )
|
EVT_MENU( ID_COLLABELVERTALIGN, GridFrame::SetColLabelVertAlignment )
|
||||||
EVT_MENU( ID_GRIDLINECOLOUR, GridFrame::SetGridLineColour )
|
EVT_MENU( ID_GRIDLINECOLOUR, GridFrame::SetGridLineColour )
|
||||||
EVT_MENU( ID_INSERTROW, GridFrame::InsertRow )
|
EVT_MENU( ID_INSERTROW, GridFrame::InsertRow )
|
||||||
EVT_MENU( ID_INSERTCOL, GridFrame::InsertCol )
|
EVT_MENU( ID_INSERTCOL, GridFrame::InsertCol )
|
||||||
EVT_MENU( ID_DELETEROW, GridFrame::DeleteSelectedRows )
|
EVT_MENU( ID_DELETEROW, GridFrame::DeleteSelectedRows )
|
||||||
EVT_MENU( ID_DELETECOL, GridFrame::DeleteSelectedCols )
|
EVT_MENU( ID_DELETECOL, GridFrame::DeleteSelectedCols )
|
||||||
EVT_MENU( ID_CLEARGRID, GridFrame::ClearGrid )
|
EVT_MENU( ID_CLEARGRID, GridFrame::ClearGrid )
|
||||||
|
|
||||||
EVT_MENU( ID_ABOUT, GridFrame::About )
|
EVT_MENU( ID_ABOUT, GridFrame::About )
|
||||||
EVT_MENU( wxID_EXIT, GridFrame::OnQuit )
|
EVT_MENU( wxID_EXIT, GridFrame::OnQuit )
|
||||||
|
|
||||||
@@ -71,10 +71,10 @@ BEGIN_EVENT_TABLE( GridFrame, wxFrame )
|
|||||||
EVT_GRID_SELECT_CELL( GridFrame::OnSelectCell )
|
EVT_GRID_SELECT_CELL( GridFrame::OnSelectCell )
|
||||||
EVT_GRID_RANGE_SELECT( GridFrame::OnRangeSelected )
|
EVT_GRID_RANGE_SELECT( GridFrame::OnRangeSelected )
|
||||||
EVT_GRID_CELL_CHANGE( GridFrame::OnCellValueChanged )
|
EVT_GRID_CELL_CHANGE( GridFrame::OnCellValueChanged )
|
||||||
|
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
GridFrame::GridFrame()
|
GridFrame::GridFrame()
|
||||||
: wxFrame( (wxFrame *)NULL, -1, "wxWindows grid class demo",
|
: wxFrame( (wxFrame *)NULL, -1, "wxWindows grid class demo",
|
||||||
wxDefaultPosition,
|
wxDefaultPosition,
|
||||||
@@ -82,17 +82,17 @@ GridFrame::GridFrame()
|
|||||||
{
|
{
|
||||||
int gridW = 600, gridH = 300;
|
int gridW = 600, gridH = 300;
|
||||||
int logW = gridW, logH = 80;
|
int logW = gridW, logH = 80;
|
||||||
|
|
||||||
wxMenu *fileMenu = new wxMenu;
|
wxMenu *fileMenu = new wxMenu;
|
||||||
fileMenu->Append( wxID_EXIT, "E&xit" );
|
fileMenu->Append( wxID_EXIT, "E&xit\tAlt-X" );
|
||||||
|
|
||||||
wxMenu *viewMenu = new wxMenu;
|
wxMenu *viewMenu = new wxMenu;
|
||||||
viewMenu->Append( ID_TOGGLEROWLABELS, "&Row labels", "", TRUE );
|
viewMenu->Append( ID_TOGGLEROWLABELS, "&Row labels", "", TRUE );
|
||||||
viewMenu->Append( ID_TOGGLECOLLABELS, "&Col labels", "", TRUE );
|
viewMenu->Append( ID_TOGGLECOLLABELS, "&Col labels", "", TRUE );
|
||||||
viewMenu->Append( ID_TOGGLEEDIT, "&Editable", "", TRUE );
|
viewMenu->Append( ID_TOGGLEEDIT, "&Editable", "", TRUE );
|
||||||
viewMenu->Append( ID_SETLABELCOLOUR, "Set &label colour" );
|
viewMenu->Append( ID_SETLABELCOLOUR, "Set &label colour" );
|
||||||
viewMenu->Append( ID_SETLABELTEXTCOLOUR, "Set label &text colour" );
|
viewMenu->Append( ID_SETLABELTEXTCOLOUR, "Set label &text colour" );
|
||||||
|
|
||||||
wxMenu *rowLabelMenu = new wxMenu;
|
wxMenu *rowLabelMenu = new wxMenu;
|
||||||
|
|
||||||
viewMenu->Append( ID_ROWLABELALIGN, "R&ow label alignment",
|
viewMenu->Append( ID_ROWLABELALIGN, "R&ow label alignment",
|
||||||
@@ -100,8 +100,8 @@ GridFrame::GridFrame()
|
|||||||
"Change alignment of row labels" );
|
"Change alignment of row labels" );
|
||||||
|
|
||||||
rowLabelMenu->Append( ID_ROWLABELHORIZALIGN, "&Horizontal" );
|
rowLabelMenu->Append( ID_ROWLABELHORIZALIGN, "&Horizontal" );
|
||||||
rowLabelMenu->Append( ID_ROWLABELVERTALIGN, "&Vertical" );
|
rowLabelMenu->Append( ID_ROWLABELVERTALIGN, "&Vertical" );
|
||||||
|
|
||||||
wxMenu *colLabelMenu = new wxMenu;
|
wxMenu *colLabelMenu = new wxMenu;
|
||||||
|
|
||||||
viewMenu->Append( ID_COLLABELALIGN, "Col l&abel alignment",
|
viewMenu->Append( ID_COLLABELALIGN, "Col l&abel alignment",
|
||||||
@@ -119,10 +119,10 @@ GridFrame::GridFrame()
|
|||||||
editMenu->Append( ID_DELETEROW, "Delete selected ro&ws" );
|
editMenu->Append( ID_DELETEROW, "Delete selected ro&ws" );
|
||||||
editMenu->Append( ID_DELETECOL, "Delete selected co&ls" );
|
editMenu->Append( ID_DELETECOL, "Delete selected co&ls" );
|
||||||
editMenu->Append( ID_CLEARGRID, "Cl&ear grid cell contents" );
|
editMenu->Append( ID_CLEARGRID, "Cl&ear grid cell contents" );
|
||||||
|
|
||||||
wxMenu *helpMenu = new wxMenu;
|
wxMenu *helpMenu = new wxMenu;
|
||||||
helpMenu->Append( ID_ABOUT, "&About wxGrid demo" );
|
helpMenu->Append( ID_ABOUT, "&About wxGrid demo" );
|
||||||
|
|
||||||
wxMenuBar *menuBar = new wxMenuBar;
|
wxMenuBar *menuBar = new wxMenuBar;
|
||||||
menuBar->Append( fileMenu, "&File" );
|
menuBar->Append( fileMenu, "&File" );
|
||||||
menuBar->Append( viewMenu, "&View" );
|
menuBar->Append( viewMenu, "&View" );
|
||||||
@@ -135,14 +135,14 @@ GridFrame::GridFrame()
|
|||||||
-1,
|
-1,
|
||||||
wxPoint( 0, 0 ),
|
wxPoint( 0, 0 ),
|
||||||
wxSize( 400, 300 ) );
|
wxSize( 400, 300 ) );
|
||||||
|
|
||||||
logWin = new wxTextCtrl( this,
|
logWin = new wxTextCtrl( this,
|
||||||
-1,
|
-1,
|
||||||
wxEmptyString,
|
wxEmptyString,
|
||||||
wxPoint( 0, gridH + 20 ),
|
wxPoint( 0, gridH + 20 ),
|
||||||
wxSize( logW, logH ),
|
wxSize( logW, logH ),
|
||||||
wxTE_MULTILINE );
|
wxTE_MULTILINE );
|
||||||
|
|
||||||
logger = new wxLogTextCtrl( logWin );
|
logger = new wxLogTextCtrl( logWin );
|
||||||
logger->SetActiveTarget( logger );
|
logger->SetActiveTarget( logger );
|
||||||
logger->SetTimestamp( NULL );
|
logger->SetTimestamp( NULL );
|
||||||
@@ -154,7 +154,7 @@ GridFrame::GridFrame()
|
|||||||
|
|
||||||
grid->SetRowSize( 0, 60 );
|
grid->SetRowSize( 0, 60 );
|
||||||
grid->SetCellValue( 0, 0, "Ctrl+Home\nwill go to\nthis cell" );
|
grid->SetCellValue( 0, 0, "Ctrl+Home\nwill go to\nthis cell" );
|
||||||
|
|
||||||
grid->SetCellValue( 0, 1, "Blah" );
|
grid->SetCellValue( 0, 1, "Blah" );
|
||||||
grid->SetCellValue( 0, 2, "Blah" );
|
grid->SetCellValue( 0, 2, "Blah" );
|
||||||
|
|
||||||
@@ -167,17 +167,17 @@ GridFrame::GridFrame()
|
|||||||
topSizer->Add( grid,
|
topSizer->Add( grid,
|
||||||
1,
|
1,
|
||||||
wxEXPAND );
|
wxEXPAND );
|
||||||
|
|
||||||
topSizer->Add( logWin,
|
topSizer->Add( logWin,
|
||||||
0,
|
0,
|
||||||
wxEXPAND );
|
wxEXPAND );
|
||||||
|
|
||||||
SetAutoLayout( TRUE );
|
SetAutoLayout( TRUE );
|
||||||
SetSizer( topSizer );
|
SetSizer( topSizer );
|
||||||
|
|
||||||
topSizer->Fit( this );
|
topSizer->Fit( this );
|
||||||
topSizer->SetSizeHints( this );
|
topSizer->SetSizeHints( this );
|
||||||
|
|
||||||
Centre();
|
Centre();
|
||||||
SetDefaults();
|
SetDefaults();
|
||||||
}
|
}
|
||||||
@@ -261,13 +261,13 @@ void GridFrame::SetRowLabelHorizAlignment( wxCommandEvent& WXUNUSED(ev) )
|
|||||||
{
|
{
|
||||||
int horiz, vert;
|
int horiz, vert;
|
||||||
grid->GetRowLabelAlignment( &horiz, &vert );
|
grid->GetRowLabelAlignment( &horiz, &vert );
|
||||||
|
|
||||||
switch ( horiz )
|
switch ( horiz )
|
||||||
{
|
{
|
||||||
case wxLEFT:
|
case wxLEFT:
|
||||||
horiz = wxCENTRE;
|
horiz = wxCENTRE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wxCENTRE:
|
case wxCENTRE:
|
||||||
horiz = wxRIGHT;
|
horiz = wxRIGHT;
|
||||||
break;
|
break;
|
||||||
@@ -284,13 +284,13 @@ void GridFrame::SetRowLabelVertAlignment( wxCommandEvent& WXUNUSED(ev) )
|
|||||||
{
|
{
|
||||||
int horiz, vert;
|
int horiz, vert;
|
||||||
grid->GetRowLabelAlignment( &horiz, &vert );
|
grid->GetRowLabelAlignment( &horiz, &vert );
|
||||||
|
|
||||||
switch ( vert )
|
switch ( vert )
|
||||||
{
|
{
|
||||||
case wxTOP:
|
case wxTOP:
|
||||||
vert = wxCENTRE;
|
vert = wxCENTRE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wxCENTRE:
|
case wxCENTRE:
|
||||||
vert = wxBOTTOM;
|
vert = wxBOTTOM;
|
||||||
break;
|
break;
|
||||||
@@ -308,13 +308,13 @@ void GridFrame::SetColLabelHorizAlignment( wxCommandEvent& WXUNUSED(ev) )
|
|||||||
{
|
{
|
||||||
int horiz, vert;
|
int horiz, vert;
|
||||||
grid->GetColLabelAlignment( &horiz, &vert );
|
grid->GetColLabelAlignment( &horiz, &vert );
|
||||||
|
|
||||||
switch ( horiz )
|
switch ( horiz )
|
||||||
{
|
{
|
||||||
case wxLEFT:
|
case wxLEFT:
|
||||||
horiz = wxCENTRE;
|
horiz = wxCENTRE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wxCENTRE:
|
case wxCENTRE:
|
||||||
horiz = wxRIGHT;
|
horiz = wxRIGHT;
|
||||||
break;
|
break;
|
||||||
@@ -332,13 +332,13 @@ void GridFrame::SetColLabelVertAlignment( wxCommandEvent& WXUNUSED(ev) )
|
|||||||
{
|
{
|
||||||
int horiz, vert;
|
int horiz, vert;
|
||||||
grid->GetColLabelAlignment( &horiz, &vert );
|
grid->GetColLabelAlignment( &horiz, &vert );
|
||||||
|
|
||||||
switch ( vert )
|
switch ( vert )
|
||||||
{
|
{
|
||||||
case wxTOP:
|
case wxTOP:
|
||||||
vert = wxCENTRE;
|
vert = wxCENTRE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wxCENTRE:
|
case wxCENTRE:
|
||||||
vert = wxBOTTOM;
|
vert = wxBOTTOM;
|
||||||
break;
|
break;
|
||||||
@@ -424,7 +424,7 @@ void GridFrame::OnLabelLeftClick( wxGridEvent& ev )
|
|||||||
|
|
||||||
if ( ev.ShiftDown() ) logBuf << " (shift down)";
|
if ( ev.ShiftDown() ) logBuf << " (shift down)";
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
// you must call event skip if you want default grid processing
|
// you must call event skip if you want default grid processing
|
||||||
//
|
//
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
@@ -450,7 +450,7 @@ void GridFrame::OnRowSize( wxGridSizeEvent& ev )
|
|||||||
logBuf = "";
|
logBuf = "";
|
||||||
logBuf << "Resized row " << ev.GetRowOrCol();
|
logBuf << "Resized row " << ev.GetRowOrCol();
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -460,7 +460,7 @@ void GridFrame::OnColSize( wxGridSizeEvent& ev )
|
|||||||
logBuf = "";
|
logBuf = "";
|
||||||
logBuf << "Resized col " << ev.GetRowOrCol();
|
logBuf << "Resized col " << ev.GetRowOrCol();
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -471,7 +471,7 @@ void GridFrame::OnSelectCell( wxGridEvent& ev )
|
|||||||
logBuf << "Selected cell at row " << ev.GetRow()
|
logBuf << "Selected cell at row " << ev.GetRow()
|
||||||
<< " col " << ev.GetCol();
|
<< " col " << ev.GetCol();
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
// you must call Skip() if you want the default processing
|
// you must call Skip() if you want the default processing
|
||||||
// to occur in wxGrid
|
// to occur in wxGrid
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
@@ -484,9 +484,9 @@ void GridFrame::OnRangeSelected( wxGridRangeSelectEvent& ev )
|
|||||||
<< " col " << ev.GetLeftCol()
|
<< " col " << ev.GetLeftCol()
|
||||||
<< " to row " << ev.GetBottomRow()
|
<< " to row " << ev.GetBottomRow()
|
||||||
<< " col " << ev.GetRightCol();
|
<< " col " << ev.GetRightCol();
|
||||||
|
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -494,11 +494,11 @@ void GridFrame::OnCellValueChanged( wxGridEvent& ev )
|
|||||||
{
|
{
|
||||||
logBuf = "";
|
logBuf = "";
|
||||||
logBuf << "Value changed for cell at"
|
logBuf << "Value changed for cell at"
|
||||||
<< " row " << ev.GetRow()
|
<< " row " << ev.GetRow()
|
||||||
<< " col " << ev.GetCol();
|
<< " col " << ev.GetCol();
|
||||||
|
|
||||||
wxLogMessage( "%s", logBuf.c_str() );
|
wxLogMessage( "%s", logBuf.c_str() );
|
||||||
|
|
||||||
ev.Skip();
|
ev.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -36,7 +36,6 @@
|
|||||||
|
|
||||||
#include "wx/generic/grid.h"
|
#include "wx/generic/grid.h"
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
wxGridCellCoords wxGridNoCellCoords( -1, -1 );
|
wxGridCellCoords wxGridNoCellCoords( -1, -1 );
|
||||||
@@ -47,6 +46,9 @@ wxRect wxGridNoCellRect( -1, -1, -1, -1 );
|
|||||||
|
|
||||||
WX_DEFINE_OBJARRAY(wxGridCellCoordsArray)
|
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;
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
@@ -139,7 +141,7 @@ wxString wxGridTableBase::GetColLabelValue( int col )
|
|||||||
unsigned int i, n;
|
unsigned int i, n;
|
||||||
for ( n = 1; ; n++ )
|
for ( n = 1; ; n++ )
|
||||||
{
|
{
|
||||||
s += ('A' + (char)( col%26 ));
|
s += (_T('A') + (wxChar)( col%26 ));
|
||||||
col = col/26 - 1;
|
col = col/26 - 1;
|
||||||
if ( col < 0 ) break;
|
if ( col < 0 ) break;
|
||||||
}
|
}
|
||||||
@@ -639,7 +641,7 @@ void wxGridTextCtrl::OnKeyDown( wxKeyEvent& event )
|
|||||||
// the other ports can handle a Return key press
|
// the other ports can handle a Return key press
|
||||||
//
|
//
|
||||||
event.Skip();
|
event.Skip();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -670,7 +672,7 @@ void wxGridTextCtrl::OnKeyDown( wxKeyEvent& event )
|
|||||||
void wxGridTextCtrl::SetStartValue( const wxString& s )
|
void wxGridTextCtrl::SetStartValue( const wxString& s )
|
||||||
{
|
{
|
||||||
startValue = s;
|
startValue = s;
|
||||||
wxTextCtrl::SetValue( s.c_str() );
|
wxTextCtrl::SetValue(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -912,7 +914,7 @@ wxGrid::~wxGrid()
|
|||||||
//
|
//
|
||||||
|
|
||||||
void wxGrid::Create()
|
void wxGrid::Create()
|
||||||
{
|
{
|
||||||
int colLblH = WXGRID_DEFAULT_COL_LABEL_HEIGHT;
|
int colLblH = WXGRID_DEFAULT_COL_LABEL_HEIGHT;
|
||||||
int rowLblW = WXGRID_DEFAULT_ROW_LABEL_WIDTH;
|
int rowLblW = WXGRID_DEFAULT_ROW_LABEL_WIDTH;
|
||||||
|
|
||||||
@@ -1104,8 +1106,8 @@ void wxGrid::CalcDimensions()
|
|||||||
//
|
//
|
||||||
int x, y;
|
int x, y;
|
||||||
GetViewStart( &x, &y );
|
GetViewStart( &x, &y );
|
||||||
SetScrollbars( 10, 10,
|
SetScrollbars( GRID_SCROLL_LINE, GRID_SCROLL_LINE,
|
||||||
right/10, bottom/10,
|
right/GRID_SCROLL_LINE, bottom/GRID_SCROLL_LINE,
|
||||||
x, y );
|
x, y );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1864,10 +1866,10 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
|
|||||||
m_isDragging = TRUE;
|
m_isDragging = TRUE;
|
||||||
if ( m_cursorMode == WXGRID_CURSOR_SELECT_CELL )
|
if ( m_cursorMode == WXGRID_CURSOR_SELECT_CELL )
|
||||||
{
|
{
|
||||||
// Hide the edit control, so it
|
// Hide the edit control, so it
|
||||||
// won't interfer with drag-shrinking.
|
// won't interfer with drag-shrinking.
|
||||||
if ( IsCellEditControlEnabled() )
|
if ( IsCellEditControlEnabled() )
|
||||||
HideCellEditControl();
|
HideCellEditControl();
|
||||||
if ( coords != wxGridNoCellCoords )
|
if ( coords != wxGridNoCellCoords )
|
||||||
{
|
{
|
||||||
if ( !IsSelection() )
|
if ( !IsSelection() )
|
||||||
@@ -1876,7 +1878,7 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SelectBlock( m_currentCellCoords, coords );
|
SelectBlock( m_currentCellCoords, coords );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1931,10 +1933,10 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Show the edit control, if it has
|
// Show the edit control, if it has
|
||||||
// been hidden for drag-shrinking.
|
// been hidden for drag-shrinking.
|
||||||
if ( IsCellEditControlEnabled() )
|
if ( IsCellEditControlEnabled() )
|
||||||
ShowCellEditControl();
|
ShowCellEditControl();
|
||||||
|
|
||||||
m_dragLastPos = -1;
|
m_dragLastPos = -1;
|
||||||
}
|
}
|
||||||
@@ -3040,7 +3042,7 @@ void wxGrid::ShowCellEditControl()
|
|||||||
rect.SetRight( rect.GetRight() + 2*extra );
|
rect.SetRight( rect.GetRight() + 2*extra );
|
||||||
rect.SetBottom( rect.GetBottom() + 2*extra );
|
rect.SetBottom( rect.GetBottom() + 2*extra );
|
||||||
|
|
||||||
|
|
||||||
m_cellEditCtrl->SetSize( rect );
|
m_cellEditCtrl->SetSize( rect );
|
||||||
m_cellEditCtrl->Show( TRUE );
|
m_cellEditCtrl->Show( TRUE );
|
||||||
|
|
||||||
@@ -3354,6 +3356,11 @@ void wxGrid::MakeCellVisible( int row, int col )
|
|||||||
h += m_rowHeights[i];
|
h += m_rowHeights[i];
|
||||||
ypos -= 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 )
|
if ( left < 0 )
|
||||||
@@ -3371,12 +3378,15 @@ void wxGrid::MakeCellVisible( int row, int col )
|
|||||||
w += m_colWidths[i];
|
w += m_colWidths[i];
|
||||||
xpos -= 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 || ypos != -1 )
|
||||||
{
|
{
|
||||||
if ( xpos != -1 ) xpos = xpos/10;
|
if ( xpos != -1 ) xpos /= GRID_SCROLL_LINE;
|
||||||
if ( ypos != -1 ) ypos = ypos/10;
|
if ( ypos != -1 ) ypos /= GRID_SCROLL_LINE;
|
||||||
Scroll( xpos, ypos );
|
Scroll( xpos, ypos );
|
||||||
AdjustScrollbars();
|
AdjustScrollbars();
|
||||||
}
|
}
|
||||||
@@ -4305,41 +4315,41 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
|
|||||||
leftCol = rightCol;
|
leftCol = rightCol;
|
||||||
rightCol = temp;
|
rightCol = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
updateTopLeft = m_selectedTopLeft;
|
updateTopLeft = m_selectedTopLeft;
|
||||||
if (m_selectedTopLeft != wxGridCellCoords( topRow, leftCol ) )
|
if (m_selectedTopLeft != wxGridCellCoords( topRow, leftCol ) )
|
||||||
{
|
{
|
||||||
m_selectedTopLeft = wxGridCellCoords( topRow, leftCol );
|
m_selectedTopLeft = wxGridCellCoords( topRow, leftCol );
|
||||||
if (updateTopLeft == wxGridNoCellCoords)
|
if (updateTopLeft == wxGridNoCellCoords)
|
||||||
{
|
{
|
||||||
updateTopLeft = m_selectedTopLeft;
|
updateTopLeft = m_selectedTopLeft;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(updateTopLeft.GetRow() > topRow)
|
if(updateTopLeft.GetRow() > topRow)
|
||||||
updateTopLeft.SetRow(topRow);
|
updateTopLeft.SetRow(topRow);
|
||||||
if (updateTopLeft.GetCol() > leftCol)
|
if (updateTopLeft.GetCol() > leftCol)
|
||||||
updateTopLeft.SetCol(leftCol);
|
updateTopLeft.SetCol(leftCol);
|
||||||
}
|
}
|
||||||
changed = true;
|
changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
updateBottomRight = m_selectedBottomRight;
|
updateBottomRight = m_selectedBottomRight;
|
||||||
if (m_selectedBottomRight != wxGridCellCoords( bottomRow, rightCol ) )
|
if (m_selectedBottomRight != wxGridCellCoords( bottomRow, rightCol ) )
|
||||||
{
|
{
|
||||||
m_selectedBottomRight = wxGridCellCoords( bottomRow, rightCol );
|
m_selectedBottomRight = wxGridCellCoords( bottomRow, rightCol );
|
||||||
if (updateBottomRight == wxGridNoCellCoords)
|
if (updateBottomRight == wxGridNoCellCoords)
|
||||||
{
|
{
|
||||||
updateBottomRight = m_selectedBottomRight;
|
updateBottomRight = m_selectedBottomRight;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (updateBottomRight.GetRow() < bottomRow)
|
if (updateBottomRight.GetRow() < bottomRow)
|
||||||
updateBottomRight.SetRow(bottomRow);
|
updateBottomRight.SetRow(bottomRow);
|
||||||
if (updateBottomRight.GetCol() < rightCol)
|
if (updateBottomRight.GetCol() < rightCol)
|
||||||
updateBottomRight.SetCol(rightCol);
|
updateBottomRight.SetCol(rightCol);
|
||||||
}
|
}
|
||||||
changed = true;
|
changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (changed)
|
if (changed)
|
||||||
|
Reference in New Issue
Block a user