Added extended selection support.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6412 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Neis
2000-03-03 16:44:33 +00:00
parent d2e4966591
commit b58088819b
5 changed files with 475 additions and 561 deletions

View File

@@ -76,6 +76,7 @@ class WXDLLEXPORT wxGridRowLabelWindow;
class WXDLLEXPORT wxGridTableBase; class WXDLLEXPORT wxGridTableBase;
class WXDLLEXPORT wxGridWindow; class WXDLLEXPORT wxGridWindow;
class WXDLLEXPORT wxGridTypeRegistry; class WXDLLEXPORT wxGridTypeRegistry;
class WXDLLEXPORT wxGridSelection;
class WXDLLEXPORT wxCheckBox; class WXDLLEXPORT wxCheckBox;
class WXDLLEXPORT wxComboBox; class WXDLLEXPORT wxComboBox;
@@ -960,7 +961,13 @@ public:
~wxGrid(); ~wxGrid();
bool CreateGrid( int numRows, int numCols ); enum wxGridSelectionModes {wxGridSelectCells,
wxGridSelectRows,
wxGridSelectColumns};
bool CreateGrid( int numRows, int numCols,
wxGrid::wxGridSelectionModes selmode =
wxGrid::wxGridSelectCells );
// ------ grid dimensions // ------ grid dimensions
@@ -1269,34 +1276,15 @@ public:
void SelectAll(); void SelectAll();
bool IsSelection() bool IsSelection();
{ return ( m_selectedTopLeft != wxGridNoCellCoords &&
m_selectedBottomRight != wxGridNoCellCoords );
}
void ClearSelection(); void ClearSelection();
bool IsInSelection( int row, int col ) bool IsInSelection( int row, int col );
{ return ( IsSelection() &&
row >= m_selectedTopLeft.GetRow() &&
col >= m_selectedTopLeft.GetCol() &&
row <= m_selectedBottomRight.GetRow() &&
col <= m_selectedBottomRight.GetCol() );
}
bool IsInSelection( const wxGridCellCoords& coords ) bool IsInSelection( const wxGridCellCoords& coords )
{ return IsInSelection( coords.GetRow(), coords.GetCol() ); } { return IsInSelection( coords.GetRow(), coords.GetCol() ); }
void GetSelection( int* topRow, int* leftCol, int* bottomRow, int* rightCol )
{
// these will all be -1 if there is no selected block
//
*topRow = m_selectedTopLeft.GetRow();
*leftCol = m_selectedTopLeft.GetCol();
*bottomRow = m_selectedBottomRight.GetRow();
*rightCol = m_selectedBottomRight.GetCol();
}
// This function returns the rectangle that encloses the block of cells // This function returns the rectangle that encloses the block of cells
// limited by TopLeft and BottomRight cell in device coords and clipped // limited by TopLeft and BottomRight cell in device coords and clipped
@@ -1310,8 +1298,8 @@ public:
// //
wxRect SelectionToDeviceRect() wxRect SelectionToDeviceRect()
{ {
return BlockToDeviceRect( m_selectedTopLeft, return BlockToDeviceRect( m_selectingTopLeft,
m_selectedBottomRight ); m_selectingBottomRight );
} }
// Access or update the selection fore/back colours // Access or update the selection fore/back colours
@@ -1531,8 +1519,9 @@ protected:
wxGridCellCoords m_currentCellCoords; wxGridCellCoords m_currentCellCoords;
wxGridCellCoords m_selectedTopLeft; wxGridCellCoords m_selectingTopLeft;
wxGridCellCoords m_selectedBottomRight; wxGridCellCoords m_selectingBottomRight;
wxGridSelection *m_selection;
wxColour m_selectionBackground; wxColour m_selectionBackground;
wxColour m_selectionForeground; wxColour m_selectionForeground;
@@ -1898,4 +1887,3 @@ const wxEventType wxEVT_GRID_CHANGE_SEL_LABEL = wxEVT_FIRST + 1578;
#endif // #ifndef __WXGRID_H__ #endif // #ifndef __WXGRID_H__
#endif // ifndef wxUSE_NEW_GRID #endif // ifndef wxUSE_NEW_GRID

View File

@@ -24,11 +24,8 @@
class WXDLLEXPORT wxGridSelection{ class WXDLLEXPORT wxGridSelection{
public: public:
enum wxGridSelectionModes {wxGridSelectCells, wxGridSelection( wxGrid * grid, wxGrid::wxGridSelectionModes sel =
wxGridSelectRows, wxGrid::wxGridSelectCells );
wxGridSelectColumns};
wxGridSelection( wxGrid * grid, wxGridSelection::wxGridSelectionModes sel =
wxGridSelection::wxGridSelectCells );
bool IsSelection(); bool IsSelection();
bool IsInSelection ( int row, int col ); bool IsInSelection ( int row, int col );
void SelectRow( int row, bool addToSelected = FALSE ); void SelectRow( int row, bool addToSelected = FALSE );
@@ -67,7 +64,7 @@ private:
wxArrayInt m_colSelection; wxArrayInt m_colSelection;
wxGrid *m_grid; wxGrid *m_grid;
wxGridSelectionModes m_selectionMode; wxGrid::wxGridSelectionModes m_selectionMode;
}; };
#endif // #ifdef __WXGRIDSEL_H__ #endif // #ifdef __WXGRIDSEL_H__

View File

@@ -482,23 +482,27 @@ void GridFrame::InsertCol( wxCommandEvent& WXUNUSED(ev) )
void GridFrame::DeleteSelectedRows( wxCommandEvent& WXUNUSED(ev) ) void GridFrame::DeleteSelectedRows( wxCommandEvent& WXUNUSED(ev) )
{ {
#if 0
if ( grid->IsSelection() ) if ( grid->IsSelection() )
{ {
int topRow, bottomRow, leftCol, rightCol; int topRow, bottomRow, leftCol, rightCol;
grid->GetSelection( &topRow, &leftCol, &bottomRow, &rightCol ); grid->GetSelection( &topRow, &leftCol, &bottomRow, &rightCol );
grid->DeleteRows( topRow, bottomRow - topRow + 1 ); grid->DeleteRows( topRow, bottomRow - topRow + 1 );
} }
#endif
} }
void GridFrame::DeleteSelectedCols( wxCommandEvent& WXUNUSED(ev) ) void GridFrame::DeleteSelectedCols( wxCommandEvent& WXUNUSED(ev) )
{ {
#if 0
if ( grid->IsSelection() ) if ( grid->IsSelection() )
{ {
int topRow, bottomRow, leftCol, rightCol; int topRow, bottomRow, leftCol, rightCol;
grid->GetSelection( &topRow, &leftCol, &bottomRow, &rightCol ); grid->GetSelection( &topRow, &leftCol, &bottomRow, &rightCol );
grid->DeleteCols( leftCol, rightCol - leftCol + 1 ); grid->DeleteCols( leftCol, rightCol - leftCol + 1 );
} }
#endif
} }

View File

@@ -50,6 +50,7 @@
#include "wx/tokenzr.h" #include "wx/tokenzr.h"
#include "wx/grid.h" #include "wx/grid.h"
#include "wx/generic/gridsel.h"
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// array classes // array classes
@@ -3078,6 +3079,7 @@ wxGrid::~wxGrid()
delete m_table; delete m_table;
delete m_typeRegistry; delete m_typeRegistry;
delete m_selection;
} }
@@ -3118,7 +3120,7 @@ void wxGrid::Create()
// create the type registry // create the type registry
m_typeRegistry = new wxGridTypeRegistry; m_typeRegistry = new wxGridTypeRegistry;
m_selection = 0;
// subwindow components that make up the wxGrid // subwindow components that make up the wxGrid
m_cornerLabelWin = new wxGridCornerLabelWindow( this, m_cornerLabelWin = new wxGridCornerLabelWindow( this,
-1, -1,
@@ -3146,7 +3148,8 @@ void wxGrid::Create()
} }
bool wxGrid::CreateGrid( int numRows, int numCols ) bool wxGrid::CreateGrid( int numRows, int numCols,
wxGrid::wxGridSelectionModes selmode )
{ {
if ( m_created ) if ( m_created )
{ {
@@ -3164,7 +3167,7 @@ bool wxGrid::CreateGrid( int numRows, int numCols )
Init(); Init();
m_created = TRUE; m_created = TRUE;
} }
m_selection = new wxGridSelection( this, selmode );
return m_created; return m_created;
} }
@@ -3262,8 +3265,8 @@ void wxGrid::Init()
m_currentCellCoords = wxGridNoCellCoords; m_currentCellCoords = wxGridNoCellCoords;
m_selectedTopLeft = wxGridNoCellCoords; m_selectingTopLeft = wxGridNoCellCoords;
m_selectedBottomRight = wxGridNoCellCoords; m_selectingBottomRight = wxGridNoCellCoords;
m_selectionBackground = wxSystemSettings::GetSystemColour(wxSYS_COLOUR_HIGHLIGHT); m_selectionBackground = wxSystemSettings::GetSystemColour(wxSYS_COLOUR_HIGHLIGHT);
m_selectionForeground = wxSystemSettings::GetSystemColour(wxSYS_COLOUR_HIGHLIGHTTEXT); m_selectionForeground = wxSystemSettings::GetSystemColour(wxSYS_COLOUR_HIGHLIGHTTEXT);
@@ -4304,6 +4307,8 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
// //
if ( event.LeftDown() && coords != wxGridNoCellCoords ) if ( event.LeftDown() && coords != wxGridNoCellCoords )
{ {
if ( !event.ShiftDown() && !event.ControlDown() )
ClearSelection();
if ( event.ShiftDown() ) if ( event.ShiftDown() )
{ {
SelectBlock( m_currentCellCoords, coords ); SelectBlock( m_currentCellCoords, coords );
@@ -4339,6 +4344,10 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
} }
else else
{ {
m_selection->ToggleCellSelection( coords.GetRow(),
coords.GetCol() );
m_selectingTopLeft = wxGridNoCellCoords;
m_selectingBottomRight = wxGridNoCellCoords;
SetCurrentCell( coords ); SetCurrentCell( coords );
m_waitForSlowClick = TRUE; m_waitForSlowClick = TRUE;
} }
@@ -4369,8 +4378,13 @@ void wxGrid::ProcessGridCellMouseEvent( wxMouseEvent& event )
{ {
if ( m_cursorMode == WXGRID_CURSOR_SELECT_CELL ) if ( m_cursorMode == WXGRID_CURSOR_SELECT_CELL )
{ {
if ( IsSelection() ) if ( m_selectingTopLeft != wxGridNoCellCoords &&
m_selectingBottomRight != wxGridNoCellCoords )
{ {
m_selection->SelectBlock( m_selectingTopLeft.GetRow(),
m_selectingTopLeft.GetCol(),
m_selectingBottomRight.GetRow(),
m_selectingBottomRight.GetCol() );
if (m_winCapture) if (m_winCapture)
{ {
m_winCapture->ReleaseMouse(); m_winCapture->ReleaseMouse();
@@ -4659,7 +4673,7 @@ bool wxGrid::InsertRows( int pos, int numRows, bool WXUNUSED(updateLabels) )
SetCurrentCell( 0, 0 ); SetCurrentCell( 0, 0 );
} }
ClearSelection(); m_selection->UpdateRows( pos, numRows );
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
} }
@@ -4695,7 +4709,6 @@ bool wxGrid::AppendRows( int numRows, bool WXUNUSED(updateLabels) )
// the table will have sent the results of the append row // the table will have sent the results of the append row
// operation to this view object as a grid table message // operation to this view object as a grid table message
// //
ClearSelection();
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
return TRUE; return TRUE;
} }
@@ -4727,7 +4740,7 @@ bool wxGrid::DeleteRows( int pos, int numRows, bool WXUNUSED(updateLabels) )
// the table will have sent the results of the delete row // the table will have sent the results of the delete row
// operation to this view object as a grid table message // operation to this view object as a grid table message
// //
ClearSelection(); m_selection->UpdateRows( pos, -((int)numRows) );
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
return TRUE; return TRUE;
} }
@@ -4766,7 +4779,7 @@ bool wxGrid::InsertCols( int pos, int numCols, bool WXUNUSED(updateLabels) )
SetCurrentCell( 0, 0 ); SetCurrentCell( 0, 0 );
} }
ClearSelection(); m_selection->UpdateCols( pos, numCols );
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
} }
@@ -4802,7 +4815,6 @@ bool wxGrid::AppendCols( int numCols, bool WXUNUSED(updateLabels) )
SetCurrentCell( 0, 0 ); SetCurrentCell( 0, 0 );
} }
ClearSelection();
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
return TRUE; return TRUE;
} }
@@ -4833,7 +4845,7 @@ bool wxGrid::DeleteCols( int pos, int numCols, bool WXUNUSED(updateLabels) )
// the table will have sent the results of the delete col // the table will have sent the results of the delete col
// operation to this view object as a grid table message // operation to this view object as a grid table message
// //
ClearSelection(); m_selection->UpdateCols( pos, -((int)numCols) );
if ( !GetBatchCount() ) Refresh(); if ( !GetBatchCount() ) Refresh();
return TRUE; return TRUE;
} }
@@ -4875,8 +4887,8 @@ bool wxGrid::SendEvent( const wxEventType type,
wxGridRangeSelectEvent gridEvt( GetId(), wxGridRangeSelectEvent gridEvt( GetId(),
type, type,
this, this,
m_selectedTopLeft, m_selectingTopLeft,
m_selectedBottomRight, m_selectingBottomRight,
mouseEv.ControlDown(), mouseEv.ControlDown(),
mouseEv.ShiftDown(), mouseEv.ShiftDown(),
mouseEv.AltDown(), mouseEv.AltDown(),
@@ -5157,13 +5169,16 @@ void wxGrid::SetCurrentCell( const wxGridCellCoords& coords )
wxGridCellAttr* attr = GetCellAttr(coords); wxGridCellAttr* attr = GetCellAttr(coords);
DrawCellHighlight(dc, attr); DrawCellHighlight(dc, attr);
attr->DecRef(); attr->DecRef();
#if 0
// SN: For my extended selection code, automatic
// deselection is definitely not a good idea.
if ( IsSelection() ) if ( IsSelection() )
{ {
wxRect r( SelectionToDeviceRect() ); wxRect r( SelectionToDeviceRect() );
ClearSelection(); ClearSelection();
if ( !GetBatchCount() ) m_gridWin->Refresh( FALSE, &r ); if ( !GetBatchCount() ) m_gridWin->Refresh( FALSE, &r );
} }
#endif
} }
} }
@@ -7422,83 +7437,16 @@ void wxGrid::SetCellValue( int row, int col, const wxString& s )
void wxGrid::SelectRow( int row, bool addToSelected ) void wxGrid::SelectRow( int row, bool addToSelected )
{ {
wxRect r; if ( IsSelection() && !addToSelected )
m_selection->ClearSelection();
if ( IsSelection() && addToSelected ) m_selection->SelectRow( row );
{
wxRect rect[4];
bool need_refresh[4];
need_refresh[0] =
need_refresh[1] =
need_refresh[2] =
need_refresh[3] = FALSE;
int i;
wxCoord oldLeft = m_selectedTopLeft.GetCol();
wxCoord oldTop = m_selectedTopLeft.GetRow();
wxCoord oldRight = m_selectedBottomRight.GetCol();
wxCoord oldBottom = m_selectedBottomRight.GetRow();
if ( oldTop > row )
{
need_refresh[0] = TRUE;
rect[0] = BlockToDeviceRect( wxGridCellCoords ( row, 0 ),
wxGridCellCoords ( oldTop - 1,
m_numCols - 1 ) );
m_selectedTopLeft.SetRow( row );
}
if ( oldLeft > 0 )
{
need_refresh[1] = TRUE;
rect[1] = BlockToDeviceRect( wxGridCellCoords ( oldTop, 0 ),
wxGridCellCoords ( oldBottom,
oldLeft - 1 ) );
m_selectedTopLeft.SetCol( 0 );
}
if ( oldBottom < row )
{
need_refresh[2] = TRUE;
rect[2] = BlockToDeviceRect( wxGridCellCoords ( oldBottom + 1, 0 ),
wxGridCellCoords ( row,
m_numCols - 1 ) );
m_selectedBottomRight.SetRow( row );
}
if ( oldRight < m_numCols - 1 )
{
need_refresh[3] = TRUE;
rect[3] = BlockToDeviceRect( wxGridCellCoords ( oldTop ,
oldRight + 1 ),
wxGridCellCoords ( oldBottom,
m_numCols - 1 ) );
m_selectedBottomRight.SetCol( m_numCols - 1 );
}
for (i = 0; i < 4; i++ )
if ( need_refresh[i] && rect[i] != wxGridNoCellRect )
m_gridWin->Refresh( FALSE, &(rect[i]) );
}
else
{
r = SelectionToDeviceRect();
ClearSelection();
if ( r != wxGridNoCellRect ) m_gridWin->Refresh( FALSE, &r );
m_selectedTopLeft.Set( row, 0 );
m_selectedBottomRight.Set( row, m_numCols-1 );
r = SelectionToDeviceRect();
m_gridWin->Refresh( FALSE, &r );
}
wxGridRangeSelectEvent gridEvt( GetId(), wxGridRangeSelectEvent gridEvt( GetId(),
wxEVT_GRID_RANGE_SELECT, wxEVT_GRID_RANGE_SELECT,
this, this,
m_selectedTopLeft, wxGridCellCoords( row, 0 ),
m_selectedBottomRight ); wxGridCellCoords( row, m_numCols - 1 ) );
GetEventHandler()->ProcessEvent(gridEvt); GetEventHandler()->ProcessEvent(gridEvt);
} }
@@ -7506,81 +7454,16 @@ void wxGrid::SelectRow( int row, bool addToSelected )
void wxGrid::SelectCol( int col, bool addToSelected ) void wxGrid::SelectCol( int col, bool addToSelected )
{ {
if ( IsSelection() && addToSelected ) if ( IsSelection() && !addToSelected )
{ m_selection->ClearSelection();
wxRect rect[4];
bool need_refresh[4];
need_refresh[0] =
need_refresh[1] =
need_refresh[2] =
need_refresh[3] = FALSE;
int i;
wxCoord oldLeft = m_selectedTopLeft.GetCol(); m_selection->SelectCol( col );
wxCoord oldTop = m_selectedTopLeft.GetRow();
wxCoord oldRight = m_selectedBottomRight.GetCol();
wxCoord oldBottom = m_selectedBottomRight.GetRow();
if ( oldLeft > col )
{
need_refresh[0] = TRUE;
rect[0] = BlockToDeviceRect( wxGridCellCoords ( 0, col ),
wxGridCellCoords ( m_numRows - 1,
oldLeft - 1 ) );
m_selectedTopLeft.SetCol( col );
}
if ( oldTop > 0 )
{
need_refresh[1] = TRUE;
rect[1] = BlockToDeviceRect( wxGridCellCoords ( 0, oldLeft ),
wxGridCellCoords ( oldTop - 1,
oldRight ) );
m_selectedTopLeft.SetRow( 0 );
}
if ( oldRight < col )
{
need_refresh[2] = TRUE;
rect[2] = BlockToDeviceRect( wxGridCellCoords ( 0, oldRight + 1 ),
wxGridCellCoords ( m_numRows - 1,
col ) );
m_selectedBottomRight.SetCol( col );
}
if ( oldBottom < m_numRows - 1 )
{
need_refresh[3] = TRUE;
rect[3] = BlockToDeviceRect( wxGridCellCoords ( oldBottom + 1,
oldLeft ),
wxGridCellCoords ( m_numRows - 1,
oldRight ) );
m_selectedBottomRight.SetRow( m_numRows - 1 );
}
for (i = 0; i < 4; i++ )
if ( need_refresh[i] && rect[i] != wxGridNoCellRect )
m_gridWin->Refresh( FALSE, &(rect[i]) );
}
else
{
wxRect r;
r = SelectionToDeviceRect();
ClearSelection();
if ( r != wxGridNoCellRect ) m_gridWin->Refresh( FALSE, &r );
m_selectedTopLeft.Set( 0, col );
m_selectedBottomRight.Set( m_numRows-1, col );
r = SelectionToDeviceRect();
m_gridWin->Refresh( FALSE, &r );
}
wxGridRangeSelectEvent gridEvt( GetId(), wxGridRangeSelectEvent gridEvt( GetId(),
wxEVT_GRID_RANGE_SELECT, wxEVT_GRID_RANGE_SELECT,
this, this,
m_selectedTopLeft, wxGridCellCoords( 0, col ),
m_selectedBottomRight ); wxGridCellCoords( m_numRows - 1, col ) );
GetEventHandler()->ProcessEvent(gridEvt); GetEventHandler()->ProcessEvent(gridEvt);
} }
@@ -7608,8 +7491,8 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
updateTopLeft = wxGridCellCoords( topRow, leftCol ); updateTopLeft = wxGridCellCoords( topRow, leftCol );
updateBottomRight = wxGridCellCoords( bottomRow, rightCol ); updateBottomRight = wxGridCellCoords( bottomRow, rightCol );
if ( m_selectedTopLeft != updateTopLeft || if ( m_selectingTopLeft != updateTopLeft ||
m_selectedBottomRight != updateBottomRight ) m_selectingBottomRight != updateBottomRight )
{ {
// Compute two optimal update rectangles: // Compute two optimal update rectangles:
// Either one rectangle is a real subset of the // Either one rectangle is a real subset of the
@@ -7623,10 +7506,10 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
int i; int i;
// Store intermediate values // Store intermediate values
wxCoord oldLeft = m_selectedTopLeft.GetCol(); wxCoord oldLeft = m_selectingTopLeft.GetCol();
wxCoord oldTop = m_selectedTopLeft.GetRow(); wxCoord oldTop = m_selectingTopLeft.GetRow();
wxCoord oldRight = m_selectedBottomRight.GetCol(); wxCoord oldRight = m_selectingBottomRight.GetCol();
wxCoord oldBottom = m_selectedBottomRight.GetRow(); wxCoord oldBottom = m_selectingBottomRight.GetRow();
// Determine the outer/inner coordinates. // Determine the outer/inner coordinates.
if (oldLeft > leftCol) if (oldLeft > leftCol)
@@ -7696,8 +7579,8 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
// Change Selection // Change Selection
m_selectedTopLeft = updateTopLeft; m_selectingTopLeft = updateTopLeft;
m_selectedBottomRight = updateBottomRight; m_selectingBottomRight = updateBottomRight;
// various Refresh() calls // various Refresh() calls
for (i = 0; i < 4; i++ ) for (i = 0; i < 4; i++ )
@@ -7713,8 +7596,8 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
wxGridRangeSelectEvent gridEvt( GetId(), wxGridRangeSelectEvent gridEvt( GetId(),
wxEVT_GRID_RANGE_SELECT, wxEVT_GRID_RANGE_SELECT,
this, this,
m_selectedTopLeft, m_selectingTopLeft,
m_selectedBottomRight ); m_selectingBottomRight );
GetEventHandler()->ProcessEvent(gridEvt); GetEventHandler()->ProcessEvent(gridEvt);
} }
@@ -7722,17 +7605,30 @@ void wxGrid::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
void wxGrid::SelectAll() void wxGrid::SelectAll()
{ {
m_selectedTopLeft.Set( 0, 0 ); m_selection->SelectBlock( 0, 0, m_numRows-1, m_numCols-1 );
m_selectedBottomRight.Set( m_numRows-1, m_numCols-1 );
m_gridWin->Refresh();
} }
bool wxGrid::IsSelection()
{
return ( m_selection->IsSelection() ||
( m_selectingTopLeft != wxGridNoCellCoords &&
m_selectingBottomRight != wxGridNoCellCoords ) );
}
bool wxGrid::IsInSelection( int row, int col )
{
return ( m_selection->IsInSelection( row, col ) ||
( row >= m_selectingTopLeft.GetRow() &&
col >= m_selectingTopLeft.GetCol() &&
row <= m_selectingBottomRight.GetRow() &&
col <= m_selectingBottomRight.GetCol() ) );
}
void wxGrid::ClearSelection() void wxGrid::ClearSelection()
{ {
m_selectedTopLeft = wxGridNoCellCoords; m_selectingTopLeft = wxGridNoCellCoords;
m_selectedBottomRight = wxGridNoCellCoords; m_selectingBottomRight = wxGridNoCellCoords;
m_selection->ClearSelection();
} }
@@ -7847,4 +7743,3 @@ wxGridRangeSelectEvent::wxGridRangeSelectEvent(int id, wxEventType type, wxObjec
#endif // ifndef wxUSE_NEW_GRID #endif // ifndef wxUSE_NEW_GRID

View File

@@ -33,7 +33,7 @@
#include "wx/generic/gridsel.h" #include "wx/generic/gridsel.h"
wxGridSelection::wxGridSelection( wxGrid * grid, wxGridSelection::wxGridSelection( wxGrid * grid,
wxGridSelection::wxGridSelectionModes sel ) wxGrid::wxGridSelectionModes sel )
{ {
m_grid = grid; m_grid = grid;
m_selectionMode = sel; m_selectionMode = sel;
@@ -48,8 +48,8 @@ bool wxGridSelection::IsSelection()
bool wxGridSelection::IsInSelection ( int row, int col ) bool wxGridSelection::IsInSelection ( int row, int col )
{ {
size_t count; size_t count;
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
count = m_cellSelection.GetCount(); count = m_cellSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -69,7 +69,7 @@ bool wxGridSelection::IsInSelection ( int row, int col )
row, col ) ) row, col ) )
return true; return true;
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
size_t count = m_rowSelection.GetCount(); size_t count = m_rowSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -78,7 +78,7 @@ bool wxGridSelection::IsInSelection ( int row, int col )
return true; return true;
} }
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectRows ) if ( m_selectionMode != wxGrid::wxGridSelectRows )
{ {
size_t count = m_colSelection.GetCount(); size_t count = m_colSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -92,13 +92,13 @@ bool wxGridSelection::IsInSelection ( int row, int col )
void wxGridSelection::SelectRow( int row, bool addToSelected = FALSE ) void wxGridSelection::SelectRow( int row, bool addToSelected = FALSE )
{ {
if ( m_selectionMode == wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode == wxGrid::wxGridSelectColumns )
return; return;
size_t count; size_t count;
// Remove single cells contained in newly selected block. // Remove single cells contained in newly selected block.
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
count = m_cellSelection.GetCount(); count = m_cellSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -153,17 +153,23 @@ void wxGridSelection::SelectRow( int row, bool addToSelected = FALSE )
// Add row to selection // Add row to selection
m_rowSelection.Add(row); m_rowSelection.Add(row);
// Update View:
wxRect r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ),
wxGridCellCoords( row, m_grid->GetNumberCols() - 1 ) );
if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
void wxGridSelection::SelectCol( int col, bool addToSelected = FALSE ) void wxGridSelection::SelectCol( int col, bool addToSelected = FALSE )
{ {
if ( m_selectionMode == wxGridSelection::wxGridSelectRows ) if ( m_selectionMode == wxGrid::wxGridSelectRows )
return; return;
size_t count; size_t count;
// Remove single cells contained in newly selected block. // Remove single cells contained in newly selected block.
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
count = m_cellSelection.GetCount(); count = m_cellSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -218,17 +224,23 @@ void wxGridSelection::SelectCol( int col, bool addToSelected = FALSE )
// Add col to selection // Add col to selection
m_colSelection.Add(col); m_colSelection.Add(col);
// Update View:
wxRect r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ),
wxGridCellCoords( m_grid->GetNumberRows() - 1, col ) );
if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol ) void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int rightCol )
{ {
// Fix the coordinates of the block if potentially needed // Fix the coordinates of the block if potentially needed
if ( m_selectionMode == wxGridSelection::wxGridSelectRows ) if ( m_selectionMode == wxGrid::wxGridSelectRows )
{ {
leftCol = 0; leftCol = 0;
rightCol = m_grid->GetNumberCols() - 1; rightCol = m_grid->GetNumberCols() - 1;
} }
else if ( m_selectionMode == wxGridSelection::wxGridSelectColumns ) else if ( m_selectionMode == wxGrid::wxGridSelectColumns )
{ {
topRow = 0; topRow = 0;
bottomRow = m_grid->GetNumberRows() - 1; bottomRow = m_grid->GetNumberRows() - 1;
@@ -240,8 +252,8 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int r
size_t count; size_t count;
// Remove single cells contained in newly selected block. // Remove single cells contained in newly selected block.
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
count = m_cellSelection.GetCount(); count = m_cellSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -281,7 +293,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int r
// If a row containing the selection is already selected, return, // If a row containing the selection is already selected, return,
// if a row contained in newly selected block is found, remove it. // if a row contained in newly selected block is found, remove it.
if ( m_selectionMode != wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
size_t count = m_rowSelection.GetCount(); size_t count = m_rowSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -300,7 +312,7 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int r
} }
} }
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectRows ) if ( m_selectionMode != wxGrid::wxGridSelectRows )
{ {
size_t count = m_colSelection.GetCount(); size_t count = m_colSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -321,31 +333,45 @@ void wxGridSelection::SelectBlock( int topRow, int leftCol, int bottomRow, int r
} }
m_blockSelectionTopLeft.Add( wxGridCellCoords( topRow, leftCol ) ); m_blockSelectionTopLeft.Add( wxGridCellCoords( topRow, leftCol ) );
m_blockSelectionBottomRight.Add( wxGridCellCoords( bottomRow, rightCol ) ); m_blockSelectionBottomRight.Add( wxGridCellCoords( bottomRow, rightCol ) );
// Update View:
wxRect r = m_grid->BlockToDeviceRect( wxGridCellCoords( topRow, leftCol ),
wxGridCellCoords( bottomRow, rightCol ) );
if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
void wxGridSelection::SelectCell( int row, int col) void wxGridSelection::SelectCell( int row, int col)
{ {
if ( m_selectionMode == wxGridSelection::wxGridSelectRows ) if ( m_selectionMode == wxGrid::wxGridSelectRows )
SelectBlock(row, 0, row, m_grid->GetNumberCols() - 1 ); SelectBlock(row, 0, row, m_grid->GetNumberCols() - 1 );
else if ( m_selectionMode == wxGridSelection::wxGridSelectColumns ) else if ( m_selectionMode == wxGrid::wxGridSelectColumns )
SelectBlock(0, col, m_grid->GetNumberRows() - 1, col ); SelectBlock(0, col, m_grid->GetNumberRows() - 1, col );
else if ( IsInSelection ( row, col ) ) else if ( IsInSelection ( row, col ) )
return; return;
m_cellSelection.Add( wxGridCellCoords( row, col ) ); m_cellSelection.Add( wxGridCellCoords( row, col ) );
wxRect r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, col ),
wxGridCellCoords( row, col ) );
if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
void wxGridSelection::ToggleCellSelection( int row, int col) void wxGridSelection::ToggleCellSelection( int row, int col)
{ {
if ( !IsInSelection ( row, col ) ) if ( !IsInSelection ( row, col ) )
{
SelectCell( row, col ); SelectCell( row, col );
return;
}
size_t count; size_t count;
// Maybe we want to toggle a member of m_cellSelection. // Maybe we want to toggle a member of m_cellSelection.
// Then it can't be contained in rows/cols/block, and we // Then it can't be contained in rows/cols/block, and we
// just have to remove it from m_cellSelection. // just have to remove it from m_cellSelection.
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
count = m_cellSelection.GetCount(); count = m_cellSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -353,11 +379,11 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
wxGridCellCoords& coords = m_cellSelection[n]; wxGridCellCoords& coords = m_cellSelection[n];
if ( row == coords.GetRow() && col == coords.GetCol() ) if ( row == coords.GetRow() && col == coords.GetCol() )
{ {
m_cellSelection.RemoveAt(n);
n--; count--;
wxRect r; wxRect r;
r = m_grid->BlockToDeviceRect( m_cellSelection[n], r = m_grid->BlockToDeviceRect( m_cellSelection[n],
m_cellSelection[n] ); m_cellSelection[n] );
m_cellSelection.RemoveAt(n);
n--; count--;
if ( !m_grid->GetBatchCount() ) if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r ); ((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
return; return;
@@ -383,14 +409,14 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
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 != wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
if ( topRow < row ) if ( topRow < row )
SelectBlock( topRow, leftCol, row - 1, rightCol ); SelectBlock( topRow, leftCol, row - 1, rightCol );
if ( bottomRow > row ) if ( bottomRow > row )
SelectBlock( row + 1, leftCol, bottomRow, rightCol ); SelectBlock( row + 1, leftCol, bottomRow, rightCol );
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectRows ) if ( m_selectionMode != wxGrid::wxGridSelectRows )
{ {
if ( leftCol < col ) if ( leftCol < col )
SelectBlock( row, leftCol, row, col - 1 ); SelectBlock( row, leftCol, row, col - 1 );
@@ -401,7 +427,7 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
} }
// remove a cell from a row, adding up to two new blocks // remove a cell from a row, adding up to two new blocks
if ( m_selectionMode != wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
size_t count = m_rowSelection.GetCount(); size_t count = m_rowSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -410,7 +436,7 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
{ {
m_rowSelection.RemoveAt(n); m_rowSelection.RemoveAt(n);
n--; count--; n--; count--;
if (m_selectionMode == wxGridSelection::wxGridSelectCells) if (m_selectionMode == wxGrid::wxGridSelectCells)
{ {
if ( col > 0 ) if ( col > 0 )
SelectBlock( row, 0, row, col - 1 ); SelectBlock( row, 0, row, col - 1 );
@@ -422,7 +448,7 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
} }
// remove a cell from a column, adding up to two new blocks // remove a cell from a column, adding up to two new blocks
if ( m_selectionMode != wxGridSelection::wxGridSelectRows ) if ( m_selectionMode != wxGrid::wxGridSelectRows )
{ {
size_t count = m_colSelection.GetCount(); size_t count = m_colSelection.GetCount();
for ( size_t n = 0; n < count; n++ ) for ( size_t n = 0; n < count; n++ )
@@ -431,7 +457,7 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
{ {
m_colSelection.RemoveAt(n); m_colSelection.RemoveAt(n);
n--; count--; n--; count--;
if (m_selectionMode == wxGridSelection::wxGridSelectCells) if (m_selectionMode == wxGrid::wxGridSelectCells)
{ {
if ( row > 0 ) if ( row > 0 )
SelectBlock( 0, col, row - 1, col ); SelectBlock( 0, col, row - 1, col );
@@ -444,15 +470,15 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
wxRect r; wxRect r;
switch (m_selectionMode) switch (m_selectionMode)
{ {
case wxGridSelection::wxGridSelectCells: case wxGrid::wxGridSelectCells:
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, col ), r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, col ),
wxGridCellCoords( row, col ) ); wxGridCellCoords( row, col ) );
break; break;
case wxGridSelection::wxGridSelectRows: case wxGrid::wxGridSelectRows:
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 ) );
break; break;
case wxGridSelection::wxGridSelectColumns: case wxGrid::wxGridSelectColumns:
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 ) );
break; break;
@@ -464,13 +490,14 @@ void wxGridSelection::ToggleCellSelection( int row, int col)
void wxGridSelection::ClearSelection() void wxGridSelection::ClearSelection()
{ {
size_t n; size_t n;
if ( m_selectionMode != wxGridSelection::wxGridSelectRows && if ( m_selectionMode != wxGrid::wxGridSelectRows &&
m_selectionMode != wxGridSelection::wxGridSelectColumns ) m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
while( ( n = m_cellSelection.GetCount() ) > 0) while( ( n = m_cellSelection.GetCount() ) > 0)
{ {
wxRect r; wxRect r;
n--;
r = m_grid->BlockToDeviceRect( m_cellSelection[n], r = m_grid->BlockToDeviceRect( m_cellSelection[n],
m_cellSelection[n] ); m_cellSelection[n] );
m_cellSelection.RemoveAt(n); m_cellSelection.RemoveAt(n);
@@ -481,6 +508,7 @@ void wxGridSelection::ClearSelection()
while( ( n = m_blockSelectionTopLeft.GetCount() ) > 0) while( ( n = m_blockSelectionTopLeft.GetCount() ) > 0)
{ {
wxRect r; wxRect r;
n--;
r = m_grid->BlockToDeviceRect( m_blockSelectionTopLeft[n], r = m_grid->BlockToDeviceRect( m_blockSelectionTopLeft[n],
m_blockSelectionBottomRight[n] ); m_blockSelectionBottomRight[n] );
m_blockSelectionTopLeft.RemoveAt(n); m_blockSelectionTopLeft.RemoveAt(n);
@@ -488,10 +516,11 @@ void wxGridSelection::ClearSelection()
if ( !m_grid->GetBatchCount() ) if ( !m_grid->GetBatchCount() )
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r ); ((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectColumns ) if ( m_selectionMode != wxGrid::wxGridSelectColumns )
{ {
while( ( n = m_rowSelection.GetCount() ) > 0) while( ( n = m_rowSelection.GetCount() ) > 0)
{ {
n--;
int & row = m_rowSelection[n]; int & row = m_rowSelection[n];
wxRect r; wxRect r;
r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ), r = m_grid->BlockToDeviceRect( wxGridCellCoords( row, 0 ),
@@ -501,10 +530,11 @@ void wxGridSelection::ClearSelection()
((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r ); ((wxWindow *)m_grid->m_gridWin)->Refresh( FALSE, &r );
} }
} }
if ( m_selectionMode != wxGridSelection::wxGridSelectRows ) if ( m_selectionMode != wxGrid::wxGridSelectRows )
{ {
while( ( n = m_colSelection.GetCount() ) > 0) while( ( n = m_colSelection.GetCount() ) > 0)
{ {
n--;
int & col = m_colSelection[n]; int & col = m_colSelection[n];
wxRect r; wxRect r;
r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ), r = m_grid->BlockToDeviceRect( wxGridCellCoords( 0, col ),