cleanup - reformat
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36653 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
#include "wx/generic/gridsel.h"
|
#include "wx/generic/gridsel.h"
|
||||||
|
|
||||||
|
|
||||||
// Some explanation for the members of the class:
|
// Some explanation for the members of the class:
|
||||||
// m_cellSelection stores individual selected cells
|
// m_cellSelection stores individual selected cells
|
||||||
// -- this is only used if m_selectionMode == wxGridSelectCells
|
// -- this is only used if m_selectionMode == wxGridSelectCells
|
||||||
@@ -52,7 +53,7 @@ bool wxGridSelection::IsSelection()
|
|||||||
m_rowSelection.GetCount() || m_colSelection.GetCount() );
|
m_rowSelection.GetCount() || m_colSelection.GetCount() );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxGridSelection::IsInSelection ( int row, int col )
|
bool wxGridSelection::IsInSelection( int row, int col )
|
||||||
{
|
{
|
||||||
size_t count;
|
size_t count;
|
||||||
|
|
||||||
@@ -107,11 +108,12 @@ bool wxGridSelection::IsInSelection ( int row, int col )
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Change the selection mode
|
// Change the selection mode
|
||||||
void wxGridSelection::SetSelectionMode(wxGrid::wxGridSelectionModes selmode)
|
void wxGridSelection::SetSelectionMode( wxGrid::wxGridSelectionModes selmode )
|
||||||
{
|
{
|
||||||
// if selection mode is unchanged return immediately
|
// if selection mode is unchanged return immediately
|
||||||
if (selmode == m_selectionMode)
|
if (selmode == m_selectionMode)
|
||||||
@@ -144,8 +146,8 @@ void wxGridSelection::SetSelectionMode(wxGrid::wxGridSelectionModes selmode)
|
|||||||
SelectCol( col );
|
SelectCol( col );
|
||||||
}
|
}
|
||||||
|
|
||||||
for (n = 0; n < m_blockSelectionTopLeft.GetCount(); n++)
|
|
||||||
// Note that m_blockSelectionTopLeft's size may be changing!
|
// Note that m_blockSelectionTopLeft's size may be changing!
|
||||||
|
for (n = 0; n < m_blockSelectionTopLeft.GetCount(); n++)
|
||||||
{
|
{
|
||||||
wxGridCellCoords& coords = m_blockSelectionTopLeft[n];
|
wxGridCellCoords& coords = m_blockSelectionTopLeft[n];
|
||||||
int topRow = coords.GetRow();
|
int topRow = coords.GetRow();
|
||||||
@@ -153,6 +155,7 @@ void wxGridSelection::SetSelectionMode(wxGrid::wxGridSelectionModes selmode)
|
|||||||
coords = m_blockSelectionBottomRight[n];
|
coords = m_blockSelectionBottomRight[n];
|
||||||
int bottomRow = coords.GetRow();
|
int bottomRow = coords.GetRow();
|
||||||
int rightCol = coords.GetCol();
|
int rightCol = coords.GetCol();
|
||||||
|
|
||||||
if (selmode == wxGrid::wxGridSelectRows)
|
if (selmode == wxGrid::wxGridSelectRows)
|
||||||
{
|
{
|
||||||
if (leftCol != 0 || rightCol != m_grid->GetNumberCols() - 1 )
|
if (leftCol != 0 || rightCol != m_grid->GetNumberCols() - 1 )
|
||||||
@@ -176,6 +179,7 @@ void wxGridSelection::SetSelectionMode(wxGrid::wxGridSelectionModes selmode)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_selectionMode = selmode;
|
m_selectionMode = selmode;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -186,6 +190,7 @@ void wxGridSelection::SelectRow( int row,
|
|||||||
{
|
{
|
||||||
if ( m_selectionMode == wxGrid::wxGridSelectColumns )
|
if ( m_selectionMode == wxGrid::wxGridSelectColumns )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
size_t count, n;
|
size_t count, n;
|
||||||
|
|
||||||
// Remove single cells contained in newly selected block.
|
// Remove single cells contained in newly selected block.
|
||||||
@@ -199,7 +204,8 @@ void wxGridSelection::SelectRow( int row,
|
|||||||
coords.GetRow(), coords.GetCol() ) )
|
coords.GetRow(), coords.GetCol() ) )
|
||||||
{
|
{
|
||||||
m_cellSelection.RemoveAt(n);
|
m_cellSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -207,6 +213,7 @@ void wxGridSelection::SelectRow( int row,
|
|||||||
// Simplify list of selected blocks (if possible)
|
// Simplify list of selected blocks (if possible)
|
||||||
count = m_blockSelectionTopLeft.GetCount();
|
count = m_blockSelectionTopLeft.GetCount();
|
||||||
bool done = false;
|
bool done = false;
|
||||||
|
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
||||||
@@ -217,7 +224,8 @@ void wxGridSelection::SelectRow( int row,
|
|||||||
{
|
{
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
else if ( coords1.GetCol() == 0 &&
|
else if ( coords1.GetCol() == 0 &&
|
||||||
coords2.GetCol() == m_grid->GetNumberCols() - 1 )
|
coords2.GetCol() == m_grid->GetNumberCols() - 1 )
|
||||||
@@ -272,7 +280,7 @@ void wxGridSelection::SelectRow( int row,
|
|||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
|
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxGridSelection::SelectCol( int col,
|
void wxGridSelection::SelectCol( int col,
|
||||||
@@ -294,7 +302,8 @@ void wxGridSelection::SelectCol( int col,
|
|||||||
coords.GetRow(), coords.GetCol() ) )
|
coords.GetRow(), coords.GetCol() ) )
|
||||||
{
|
{
|
||||||
m_cellSelection.RemoveAt(n);
|
m_cellSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -312,7 +321,8 @@ void wxGridSelection::SelectCol( int col,
|
|||||||
{
|
{
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
else if ( coords1.GetRow() == 0 &&
|
else if ( coords1.GetRow() == 0 &&
|
||||||
coords2.GetRow() == m_grid->GetNumberRows() - 1 )
|
coords2.GetRow() == m_grid->GetNumberRows() - 1 )
|
||||||
@@ -367,7 +377,7 @@ void wxGridSelection::SelectCol( int col,
|
|||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
|
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
||||||
@@ -387,6 +397,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
topRow = 0;
|
topRow = 0;
|
||||||
bottomRow = m_grid->GetNumberRows() - 1;
|
bottomRow = m_grid->GetNumberRows() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( topRow > bottomRow )
|
if ( topRow > bottomRow )
|
||||||
{
|
{
|
||||||
int temp = topRow;
|
int temp = topRow;
|
||||||
@@ -407,10 +418,13 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
// grid only has 1 col)
|
// grid only has 1 col)
|
||||||
if ( m_selectionMode == wxGrid::wxGridSelectCells &&
|
if ( m_selectionMode == wxGrid::wxGridSelectCells &&
|
||||||
topRow == bottomRow && leftCol == rightCol )
|
topRow == bottomRow && leftCol == rightCol )
|
||||||
|
{
|
||||||
SelectCell( topRow, leftCol, ControlDown, ShiftDown,
|
SelectCell( topRow, leftCol, ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown, sendEvent );
|
AltDown, MetaDown, sendEvent );
|
||||||
|
}
|
||||||
|
|
||||||
size_t count, n;
|
size_t count, n;
|
||||||
|
|
||||||
// Remove single cells contained in newly selected block.
|
// Remove single cells contained in newly selected block.
|
||||||
if ( m_selectionMode == wxGrid::wxGridSelectCells )
|
if ( m_selectionMode == wxGrid::wxGridSelectCells )
|
||||||
{
|
{
|
||||||
@@ -422,7 +436,8 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
coords.GetRow(), coords.GetCol() ) )
|
coords.GetRow(), coords.GetCol() ) )
|
||||||
{
|
{
|
||||||
m_cellSelection.RemoveAt(n);
|
m_cellSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -435,6 +450,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
{
|
{
|
||||||
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
||||||
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
||||||
|
|
||||||
switch ( BlockContain( coords1.GetRow(), coords1.GetCol(),
|
switch ( BlockContain( coords1.GetRow(), coords1.GetCol(),
|
||||||
coords2.GetRow(), coords2.GetCol(),
|
coords2.GetRow(), coords2.GetCol(),
|
||||||
topRow, leftCol, bottomRow, rightCol ) )
|
topRow, leftCol, bottomRow, rightCol ) )
|
||||||
@@ -445,7 +461,8 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
case -1:
|
case -1:
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -461,7 +478,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
switch ( BlockContain( m_rowSelection[n], 0,
|
switch ( BlockContain( m_rowSelection[n], 0,
|
||||||
m_rowSelection[n], m_grid->GetNumberCols()-1,
|
m_rowSelection[n], m_grid->GetNumberCols() - 1,
|
||||||
topRow, leftCol, bottomRow, rightCol ) )
|
topRow, leftCol, bottomRow, rightCol ) )
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
@@ -469,7 +486,8 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
|
|
||||||
case -1:
|
case -1:
|
||||||
m_rowSelection.RemoveAt(n);
|
m_rowSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -477,13 +495,14 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( m_selectionMode != wxGrid::wxGridSelectRows )
|
if ( m_selectionMode != wxGrid::wxGridSelectRows )
|
||||||
{
|
{
|
||||||
count = m_colSelection.GetCount();
|
count = m_colSelection.GetCount();
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
switch ( BlockContain( 0, m_colSelection[n],
|
switch ( BlockContain( 0, m_colSelection[n],
|
||||||
m_grid->GetNumberRows()-1, m_colSelection[n],
|
m_grid->GetNumberRows() - 1, m_colSelection[n],
|
||||||
topRow, leftCol, bottomRow, rightCol ) )
|
topRow, leftCol, bottomRow, rightCol ) )
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
@@ -491,7 +510,8 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
|
|
||||||
case -1:
|
case -1:
|
||||||
m_colSelection.RemoveAt(n);
|
m_colSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -499,6 +519,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_blockSelectionTopLeft.Add( wxGridCellCoords( topRow, leftCol ) );
|
m_blockSelectionTopLeft.Add( wxGridCellCoords( topRow, leftCol ) );
|
||||||
m_blockSelectionBottomRight.Add( wxGridCellCoords( bottomRow, rightCol ) );
|
m_blockSelectionBottomRight.Add( wxGridCellCoords( bottomRow, rightCol ) );
|
||||||
|
|
||||||
@@ -514,14 +535,14 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol,
|
|||||||
if ( sendEvent )
|
if ( sendEvent )
|
||||||
{
|
{
|
||||||
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
||||||
wxEVT_GRID_RANGE_SELECT,
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
m_grid,
|
m_grid,
|
||||||
wxGridCellCoords( topRow, leftCol ),
|
wxGridCellCoords( topRow, leftCol ),
|
||||||
wxGridCellCoords( bottomRow, rightCol ),
|
wxGridCellCoords( bottomRow, rightCol ),
|
||||||
true,
|
true,
|
||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -534,23 +555,27 @@ void wxGridSelection::SelectCell( int row, int col,
|
|||||||
{
|
{
|
||||||
SelectBlock(row, 0, row, m_grid->GetNumberCols() - 1,
|
SelectBlock(row, 0, row, m_grid->GetNumberCols() - 1,
|
||||||
ControlDown, ShiftDown, AltDown, MetaDown, sendEvent);
|
ControlDown, ShiftDown, AltDown, MetaDown, sendEvent);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if ( m_selectionMode == wxGrid::wxGridSelectColumns )
|
else if ( m_selectionMode == wxGrid::wxGridSelectColumns )
|
||||||
{
|
{
|
||||||
SelectBlock(0, col, m_grid->GetNumberRows() - 1, col,
|
SelectBlock(0, col, m_grid->GetNumberRows() - 1, col,
|
||||||
ControlDown, ShiftDown, AltDown, MetaDown, sendEvent);
|
ControlDown, ShiftDown, AltDown, MetaDown, sendEvent);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if ( IsInSelection ( row, col ) )
|
else if ( IsInSelection ( row, col ) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
m_cellSelection.Add( wxGridCellCoords( row, col ) );
|
m_cellSelection.Add( wxGridCellCoords( row, col ) );
|
||||||
|
|
||||||
// Update View:
|
// Update View:
|
||||||
if ( !m_grid->GetBatchCount() )
|
if ( !m_grid->GetBatchCount() )
|
||||||
{
|
{
|
||||||
wxRect r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, col ),
|
wxRect r = m_grid->BlockToDeviceRect(
|
||||||
wxGridCellCoords( row, col ) );
|
wxGridCellCoords( row, col ),
|
||||||
|
wxGridCellCoords( row, col ) );
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -558,14 +583,14 @@ void wxGridSelection::SelectCell( int row, int col,
|
|||||||
if (sendEvent)
|
if (sendEvent)
|
||||||
{
|
{
|
||||||
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
||||||
wxEVT_GRID_RANGE_SELECT,
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
m_grid,
|
m_grid,
|
||||||
wxGridCellCoords( row, col ),
|
wxGridCellCoords( row, col ),
|
||||||
wxGridCellCoords( row, col ),
|
wxGridCellCoords( row, col ),
|
||||||
true,
|
true,
|
||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown);
|
AltDown, MetaDown );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -576,8 +601,8 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
// if the cell is not selected, select it
|
// if the cell is not selected, select it
|
||||||
if ( !IsInSelection ( row, col ) )
|
if ( !IsInSelection ( row, col ) )
|
||||||
{
|
{
|
||||||
SelectCell( row, col, ControlDown, ShiftDown,
|
SelectCell( row, col, ControlDown, ShiftDown, AltDown, MetaDown );
|
||||||
AltDown, MetaDown );
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -615,7 +640,8 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
false,
|
false,
|
||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -642,20 +668,22 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
|
|
||||||
count = m_blockSelectionTopLeft.GetCount();
|
count = m_blockSelectionTopLeft.GetCount();
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
wxGridCellCoords& coords1 = m_blockSelectionTopLeft[n];
|
||||||
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
||||||
int topRow = coords1.GetRow();
|
int topRow = coords1.GetRow();
|
||||||
int leftCol = coords1.GetCol();
|
int leftCol = coords1.GetCol();
|
||||||
int bottomRow = coords2.GetRow();
|
int bottomRow = coords2.GetRow();
|
||||||
int rightCol = coords2.GetCol();
|
int rightCol = coords2.GetCol();
|
||||||
if ( BlockContainsCell( topRow, leftCol, bottomRow, rightCol,
|
|
||||||
row, col ) )
|
if ( BlockContainsCell( topRow, leftCol, bottomRow, rightCol, row, col ) )
|
||||||
{
|
{
|
||||||
// remove the block
|
// remove the block
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
|
|
||||||
// add up to 4 smaller blocks and set update region
|
// add up to 4 smaller blocks and set update region
|
||||||
if ( m_selectionMode != wxGrid::wxGridSelectColumns )
|
if ( m_selectionMode != wxGrid::wxGridSelectColumns )
|
||||||
{
|
{
|
||||||
@@ -666,6 +694,7 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
SelectBlock( row + 1, leftCol, bottomRow, rightCol,
|
SelectBlock( row + 1, leftCol, bottomRow, rightCol,
|
||||||
false, false, false, false, false );
|
false, false, false, false, false );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( m_selectionMode != wxGrid::wxGridSelectRows )
|
if ( m_selectionMode != wxGrid::wxGridSelectRows )
|
||||||
{
|
{
|
||||||
if ( leftCol < col )
|
if ( leftCol < col )
|
||||||
@@ -687,7 +716,9 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
if ( m_rowSelection[n] == row )
|
if ( m_rowSelection[n] == row )
|
||||||
{
|
{
|
||||||
m_rowSelection.RemoveAt(n);
|
m_rowSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
|
|
||||||
if (m_selectionMode == wxGrid::wxGridSelectCells)
|
if (m_selectionMode == wxGrid::wxGridSelectCells)
|
||||||
{
|
{
|
||||||
if ( col > 0 )
|
if ( col > 0 )
|
||||||
@@ -711,7 +742,9 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
if ( m_colSelection[n] == col )
|
if ( m_colSelection[n] == col )
|
||||||
{
|
{
|
||||||
m_colSelection.RemoveAt(n);
|
m_colSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
|
|
||||||
if (m_selectionMode == wxGrid::wxGridSelectCells)
|
if (m_selectionMode == wxGrid::wxGridSelectCells)
|
||||||
{
|
{
|
||||||
if ( row > 0 )
|
if ( row > 0 )
|
||||||
@@ -731,66 +764,74 @@ void wxGridSelection::ToggleCellSelection( int row, int col,
|
|||||||
wxRect r;
|
wxRect r;
|
||||||
switch (m_selectionMode)
|
switch (m_selectionMode)
|
||||||
{
|
{
|
||||||
case wxGrid::wxGridSelectCells:
|
case wxGrid::wxGridSelectCells:
|
||||||
{
|
{
|
||||||
if ( !m_grid->GetBatchCount() )
|
if ( !m_grid->GetBatchCount() )
|
||||||
{
|
{
|
||||||
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, col ),
|
r = m_grid->BlockToDeviceRect(
|
||||||
wxGridCellCoords( row, col ) );
|
wxGridCellCoords( row, col ),
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
wxGridCellCoords( row, col ) );
|
||||||
}
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
}
|
||||||
|
|
||||||
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
||||||
wxEVT_GRID_RANGE_SELECT,
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
m_grid,
|
m_grid,
|
||||||
wxGridCellCoords( row, col ),
|
wxGridCellCoords( row, col ),
|
||||||
wxGridCellCoords( row, col ),
|
wxGridCellCoords( row, col ),
|
||||||
false,
|
false,
|
||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
break;
|
}
|
||||||
}
|
break;
|
||||||
case wxGrid::wxGridSelectRows:
|
|
||||||
{
|
|
||||||
if ( !m_grid->GetBatchCount() )
|
|
||||||
{
|
|
||||||
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ),
|
|
||||||
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ) );
|
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
|
||||||
}
|
|
||||||
|
|
||||||
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
case wxGrid::wxGridSelectRows:
|
||||||
wxEVT_GRID_RANGE_SELECT,
|
{
|
||||||
m_grid,
|
if ( !m_grid->GetBatchCount() )
|
||||||
wxGridCellCoords( row, 0 ),
|
{
|
||||||
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ),
|
r = m_grid->BlockToDeviceRect(
|
||||||
false,
|
wxGridCellCoords( row, 0 ),
|
||||||
ControlDown, ShiftDown,
|
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ) );
|
||||||
AltDown, MetaDown );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
}
|
||||||
break;
|
|
||||||
}
|
|
||||||
case wxGrid::wxGridSelectColumns:
|
|
||||||
{
|
|
||||||
if ( !m_grid->GetBatchCount() )
|
|
||||||
{
|
|
||||||
r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ),
|
|
||||||
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ) );
|
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
|
||||||
}
|
|
||||||
|
|
||||||
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
||||||
wxEVT_GRID_RANGE_SELECT,
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
m_grid,
|
m_grid,
|
||||||
wxGridCellCoords( 0, col ),
|
wxGridCellCoords( row, 0 ),
|
||||||
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ),
|
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ),
|
||||||
false,
|
false,
|
||||||
ControlDown, ShiftDown,
|
ControlDown, ShiftDown,
|
||||||
AltDown, MetaDown );
|
AltDown, MetaDown );
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
break;
|
}
|
||||||
}
|
break;
|
||||||
|
|
||||||
|
case wxGrid::wxGridSelectColumns:
|
||||||
|
{
|
||||||
|
if ( !m_grid->GetBatchCount() )
|
||||||
|
{
|
||||||
|
r = m_grid->BlockToDeviceRect(
|
||||||
|
wxGridCellCoords( 0, col ),
|
||||||
|
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ) );
|
||||||
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
}
|
||||||
|
|
||||||
|
wxGridRangeSelectEvent gridEvt( m_grid->GetId(),
|
||||||
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
|
m_grid,
|
||||||
|
wxGridCellCoords( 0, col ),
|
||||||
|
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ),
|
||||||
|
false,
|
||||||
|
ControlDown, ShiftDown,
|
||||||
|
AltDown, MetaDown );
|
||||||
|
m_grid->GetEventHandler()->ProcessEvent( gridEvt );
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -812,6 +853,7 @@ void wxGridSelection::ClearSelection()
|
|||||||
{
|
{
|
||||||
r = m_grid->BlockToDeviceRect( coords1, coords1 );
|
r = m_grid->BlockToDeviceRect( coords1, coords1 );
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
((wxWindow *)m_grid->m_gridWin)->Update();
|
((wxWindow *)m_grid->m_gridWin)->Update();
|
||||||
#endif
|
#endif
|
||||||
@@ -831,6 +873,7 @@ void wxGridSelection::ClearSelection()
|
|||||||
{
|
{
|
||||||
r = m_grid->BlockToDeviceRect( coords1, coords2 );
|
r = m_grid->BlockToDeviceRect( coords1, coords2 );
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
((wxWindow *)m_grid->m_gridWin)->Update();
|
((wxWindow *)m_grid->m_gridWin)->Update();
|
||||||
#endif
|
#endif
|
||||||
@@ -850,6 +893,7 @@ void wxGridSelection::ClearSelection()
|
|||||||
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ),
|
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ),
|
||||||
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ) );
|
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ) );
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
((wxWindow *)m_grid->m_gridWin)->Update();
|
((wxWindow *)m_grid->m_gridWin)->Update();
|
||||||
#endif
|
#endif
|
||||||
@@ -870,6 +914,7 @@ void wxGridSelection::ClearSelection()
|
|||||||
r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ),
|
r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ),
|
||||||
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ) );
|
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ) );
|
||||||
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
((wxWindow *)m_grid->m_gridWin)->Refresh( false, &r );
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
((wxWindow *)m_grid->m_gridWin)->Update();
|
((wxWindow *)m_grid->m_gridWin)->Update();
|
||||||
#endif
|
#endif
|
||||||
@@ -884,8 +929,9 @@ void wxGridSelection::ClearSelection()
|
|||||||
wxEVT_GRID_RANGE_SELECT,
|
wxEVT_GRID_RANGE_SELECT,
|
||||||
m_grid,
|
m_grid,
|
||||||
wxGridCellCoords( 0, 0 ),
|
wxGridCellCoords( 0, 0 ),
|
||||||
wxGridCellCoords( m_grid->GetNumberRows() - 1,
|
wxGridCellCoords(
|
||||||
m_grid->GetNumberCols() - 1 ),
|
m_grid->GetNumberRows() - 1,
|
||||||
|
m_grid->GetNumberCols() - 1 ),
|
||||||
false );
|
false );
|
||||||
|
|
||||||
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
m_grid->GetEventHandler()->ProcessEvent(gridEvt);
|
||||||
@@ -919,7 +965,8 @@ void wxGridSelection::UpdateRows( size_t pos, int numRows )
|
|||||||
{
|
{
|
||||||
// ...or remove the attribute
|
// ...or remove the attribute
|
||||||
m_cellSelection.RemoveAt(n);
|
m_cellSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -932,14 +979,15 @@ void wxGridSelection::UpdateRows( size_t pos, int numRows )
|
|||||||
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
||||||
wxCoord row1 = coords1.GetRow();
|
wxCoord row1 = coords1.GetRow();
|
||||||
wxCoord row2 = coords2.GetRow();
|
wxCoord row2 = coords2.GetRow();
|
||||||
|
|
||||||
if ((size_t)row2 >= pos)
|
if ((size_t)row2 >= pos)
|
||||||
{
|
{
|
||||||
if (numRows > 0)
|
if (numRows > 0)
|
||||||
{
|
{
|
||||||
// If rows inserted, increase row counter where necessary
|
// If rows inserted, increase row counter where necessary
|
||||||
coords2.SetRow(row2 + numRows);
|
coords2.SetRow( row2 + numRows );
|
||||||
if ( (size_t)row1 >= pos )
|
if ((size_t)row1 >= pos)
|
||||||
coords1.SetRow(row1 + numRows);
|
coords1.SetRow( row1 + numRows );
|
||||||
}
|
}
|
||||||
else if (numRows < 0)
|
else if (numRows < 0)
|
||||||
{
|
{
|
||||||
@@ -947,22 +995,23 @@ void wxGridSelection::UpdateRows( size_t pos, int numRows )
|
|||||||
if ((size_t)row2 >= pos - numRows)
|
if ((size_t)row2 >= pos - numRows)
|
||||||
{
|
{
|
||||||
// ...either decrement row counter (if row still exists)...
|
// ...either decrement row counter (if row still exists)...
|
||||||
coords2.SetRow(row2 + numRows);
|
coords2.SetRow( row2 + numRows );
|
||||||
if ( (size_t) row1 >= pos)
|
if ((size_t)row1 >= pos)
|
||||||
coords1.SetRow( wxMax(row1 + numRows, (int) pos) );
|
coords1.SetRow( wxMax(row1 + numRows, (int)pos) );
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( (size_t) row1 >= pos)
|
if ((size_t)row1 >= pos)
|
||||||
{
|
{
|
||||||
// ...or remove the attribute
|
// ...or remove the attribute
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
coords2.SetRow(pos);
|
coords2.SetRow( pos );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -971,21 +1020,21 @@ void wxGridSelection::UpdateRows( size_t pos, int numRows )
|
|||||||
count = m_rowSelection.GetCount();
|
count = m_rowSelection.GetCount();
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
int rowOrCol_ = m_rowSelection [ n ];
|
int rowOrCol_ = m_rowSelection[n];
|
||||||
|
|
||||||
if ( ( size_t ) rowOrCol_ >= pos )
|
if ((size_t) rowOrCol_ >= pos)
|
||||||
{
|
{
|
||||||
if ( numRows > 0 )
|
if ( numRows > 0 )
|
||||||
{
|
{
|
||||||
m_rowSelection [ n ] += numRows;
|
m_rowSelection[n] += numRows;
|
||||||
}
|
}
|
||||||
else if ( numRows < 0 )
|
else if ( numRows < 0 )
|
||||||
{
|
{
|
||||||
if ( ( size_t ) rowOrCol_ >= ( pos - numRows ) )
|
if ((size_t)rowOrCol_ >= (pos - numRows))
|
||||||
m_rowSelection [ n ] += numRows;
|
m_rowSelection[n] += numRows;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_rowSelection.RemoveAt ( n );
|
m_rowSelection.RemoveAt( n );
|
||||||
n--;
|
n--;
|
||||||
count--;
|
count--;
|
||||||
}
|
}
|
||||||
@@ -1004,6 +1053,7 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
{
|
{
|
||||||
size_t count = m_cellSelection.GetCount();
|
size_t count = m_cellSelection.GetCount();
|
||||||
size_t n;
|
size_t n;
|
||||||
|
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
wxGridCellCoords& coords = m_cellSelection[n];
|
wxGridCellCoords& coords = m_cellSelection[n];
|
||||||
@@ -1027,7 +1077,8 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
{
|
{
|
||||||
// ...or remove the attribute
|
// ...or remove the attribute
|
||||||
m_cellSelection.RemoveAt(n);
|
m_cellSelection.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1040,13 +1091,14 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
wxGridCellCoords& coords2 = m_blockSelectionBottomRight[n];
|
||||||
wxCoord col1 = coords1.GetCol();
|
wxCoord col1 = coords1.GetCol();
|
||||||
wxCoord col2 = coords2.GetCol();
|
wxCoord col2 = coords2.GetCol();
|
||||||
|
|
||||||
if ((size_t)col2 >= pos)
|
if ((size_t)col2 >= pos)
|
||||||
{
|
{
|
||||||
if (numCols > 0)
|
if (numCols > 0)
|
||||||
{
|
{
|
||||||
// If rows inserted, increase row counter where necessary
|
// If rows inserted, increase row counter where necessary
|
||||||
coords2.SetCol(col2 + numCols);
|
coords2.SetCol(col2 + numCols);
|
||||||
if ( (size_t)col1 >= pos )
|
if ((size_t)col1 >= pos)
|
||||||
coords1.SetCol(col1 + numCols);
|
coords1.SetCol(col1 + numCols);
|
||||||
}
|
}
|
||||||
else if (numCols < 0)
|
else if (numCols < 0)
|
||||||
@@ -1057,17 +1109,18 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
// ...either decrement col counter (if col still exists)...
|
// ...either decrement col counter (if col still exists)...
|
||||||
coords2.SetCol(col2 + numCols);
|
coords2.SetCol(col2 + numCols);
|
||||||
if ( (size_t) col1 >= pos)
|
if ( (size_t) col1 >= pos)
|
||||||
coords1.SetCol( wxMax(col1 + numCols, (int) pos) );
|
coords1.SetCol( wxMax(col1 + numCols, (int)pos) );
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( (size_t) col1 >= pos)
|
if ((size_t)col1 >= pos)
|
||||||
{
|
{
|
||||||
// ...or remove the attribute
|
// ...or remove the attribute
|
||||||
m_blockSelectionTopLeft.RemoveAt(n);
|
m_blockSelectionTopLeft.RemoveAt(n);
|
||||||
m_blockSelectionBottomRight.RemoveAt(n);
|
m_blockSelectionBottomRight.RemoveAt(n);
|
||||||
n--; count--;
|
n--;
|
||||||
|
count--;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
coords2.SetCol(pos);
|
coords2.SetCol(pos);
|
||||||
@@ -1079,25 +1132,24 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
count = m_colSelection.GetCount();
|
count = m_colSelection.GetCount();
|
||||||
for ( n = 0; n < count; n++ )
|
for ( n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
|
int rowOrCol = m_colSelection[n];
|
||||||
|
|
||||||
int rowOrCol = m_colSelection [ n ];
|
if ((size_t)rowOrCol >= pos)
|
||||||
if ( ( size_t ) rowOrCol >= pos )
|
|
||||||
{
|
{
|
||||||
if ( numCols > 0 )
|
if ( numCols > 0 )
|
||||||
m_colSelection [ n ] += numCols;
|
m_colSelection[n] += numCols;
|
||||||
else if ( numCols < 0 )
|
else if ( numCols < 0 )
|
||||||
{
|
{
|
||||||
if ( ( size_t ) rowOrCol >= ( pos -numCols ) )
|
if ((size_t)rowOrCol >= (pos - numCols))
|
||||||
m_colSelection [ n ] += numCols;
|
m_colSelection[n] += numCols;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_colSelection.RemoveAt ( n );
|
m_colSelection.RemoveAt( n );
|
||||||
n--;
|
n--;
|
||||||
count--;
|
count--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// No need to touch selected rows, unless we removed _all_
|
// No need to touch selected rows, unless we removed _all_
|
||||||
@@ -1106,7 +1158,6 @@ void wxGridSelection::UpdateCols( size_t pos, int numCols )
|
|||||||
m_rowSelection.Clear();
|
m_rowSelection.Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int wxGridSelection::BlockContain( int topRow1, int leftCol1,
|
int wxGridSelection::BlockContain( int topRow1, int leftCol1,
|
||||||
int bottomRow1, int rightCol1,
|
int bottomRow1, int rightCol1,
|
||||||
int topRow2, int leftCol2,
|
int topRow2, int leftCol2,
|
||||||
@@ -1121,6 +1172,7 @@ int wxGridSelection::BlockContain( int topRow1, int leftCol1,
|
|||||||
else if ( topRow2 <= topRow1 && bottomRow1 <= bottomRow2 &&
|
else if ( topRow2 <= topRow1 && bottomRow1 <= bottomRow2 &&
|
||||||
leftCol2 <= leftCol1 && rightCol1 <= rightCol2 )
|
leftCol2 <= leftCol1 && rightCol1 <= rightCol2 )
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user