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:
@@ -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
|
||||||
|
|
||||||
|
@@ -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__
|
||||||
|
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -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
|
||||||
|
|
||||||
|
@@ -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 ),
|
||||||
|
Reference in New Issue
Block a user