X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/77ffb5937e89927b621128789401db8921fe580f..3996b21a7f11ae6c1985b5ee55223ddec537f689:/include/wx/generic/gridsel.h diff --git a/include/wx/generic/gridsel.h b/include/wx/generic/gridsel.h index de64949e15..f6d3a98c40 100644 --- a/include/wx/generic/gridsel.h +++ b/include/wx/generic/gridsel.h @@ -4,51 +4,69 @@ // Author: Stefan Neis // Modified by: // Created: 20/02/2000 -// RCS-ID: $$ +// RCS-ID: $Id$ // Copyright: (c) Stefan Neis -// Licence: wxWidgets licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// +#ifndef _WX_GENERIC_GRIDSEL_H_ +#define _WX_GENERIC_GRIDSEL_H_ + #include "wx/defs.h" #if wxUSE_GRID -#ifndef __WXGRIDSEL_H__ -#define __WXGRIDSEL_H__ - -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) -#pragma interface "gridsel.h" -#endif - #include "wx/grid.h" -class WXDLLIMPEXP_ADV wxGridSelection{ +class WXDLLIMPEXP_ADV wxGridSelection +{ public: - wxGridSelection( wxGrid * grid, wxGrid::wxGridSelectionModes sel = - wxGrid::wxGridSelectCells ); + wxGridSelection(wxGrid *grid, + wxGrid::wxGridSelectionModes sel = wxGrid::wxGridSelectCells); + bool IsSelection(); - bool IsInSelection ( int row, int col ); + bool IsInSelection(int row, int col); + bool IsInSelection(const wxGridCellCoords& coords) + { + return IsInSelection(coords.GetRow(), coords.GetCol()); + } + void SetSelectionMode(wxGrid::wxGridSelectionModes selmode); wxGrid::wxGridSelectionModes GetSelectionMode() { return m_selectionMode; } - void SelectRow( int row, - bool ControlDown = FALSE, bool ShiftDown = FALSE, - bool AltDown = FALSE, bool MetaDown = FALSE ); - void SelectCol( int col, - bool ControlDown = FALSE, bool ShiftDown = FALSE, - bool AltDown = FALSE, bool MetaDown = FALSE ); - void SelectBlock( int topRow, int leftCol, - int bottomRow, int rightCol, - bool ControlDown = FALSE, bool ShiftDown = FALSE, - bool AltDown = FALSE, bool MetaDown = FALSE, - bool sendEvent = TRUE ); - void SelectCell( int row, int col, - bool ControlDown = FALSE, bool ShiftDown = FALSE, - bool AltDown = FALSE, bool MetaDown = FALSE, - bool sendEvent = TRUE ); - void ToggleCellSelection( int row, int col, - bool ControlDown = FALSE, - bool ShiftDown = FALSE, - bool AltDown = FALSE, bool MetaDown = FALSE ); + void SelectRow(int row, const wxKeyboardState& kbd = wxKeyboardState()); + void SelectCol(int col, const wxKeyboardState& kbd = wxKeyboardState()); + void SelectBlock(int topRow, int leftCol, + int bottomRow, int rightCol, + const wxKeyboardState& kbd = wxKeyboardState(), + bool sendEvent = true ); + void SelectBlock(const wxGridCellCoords& topLeft, + const wxGridCellCoords& bottomRight, + const wxKeyboardState& kbd = wxKeyboardState(), + bool sendEvent = true ) + { + SelectBlock(topLeft.GetRow(), topLeft.GetCol(), + bottomRight.GetRow(), bottomRight.GetCol(), + kbd, sendEvent); + } + + void SelectCell(int row, int col, + const wxKeyboardState& kbd = wxKeyboardState(), + bool sendEvent = true); + void SelectCell(const wxGridCellCoords& coords, + const wxKeyboardState& kbd = wxKeyboardState(), + bool sendEvent = true) + { + SelectCell(coords.GetRow(), coords.GetCol(), kbd, sendEvent); + } + + void ToggleCellSelection(int row, int col, + const wxKeyboardState& kbd = wxKeyboardState()); + void ToggleCellSelection(const wxGridCellCoords& coords, + const wxKeyboardState& kbd = wxKeyboardState()) + { + ToggleCellSelection(coords.GetRow(), coords.GetCol(), kbd); + } + void ClearSelection(); void UpdateRows( size_t pos, int numRows ); @@ -73,6 +91,13 @@ private: leftCol <= col && col <= rightCol ); } + void SelectBlockNoEvent(int topRow, int leftCol, + int bottomRow, int rightCol) + { + SelectBlock(topRow, leftCol, bottomRow, rightCol, + wxKeyboardState(), false); + } + wxGridCellCoordsArray m_cellSelection; wxGridCellCoordsArray m_blockSelectionTopLeft; wxGridCellCoordsArray m_blockSelectionBottomRight; @@ -82,11 +107,10 @@ private: wxGrid *m_grid; wxGrid::wxGridSelectionModes m_selectionMode; - friend class WXDLLIMPEXP_ADV wxGrid; + friend class WXDLLIMPEXP_FWD_ADV wxGrid; - DECLARE_NO_COPY_CLASS(wxGridSelection) + wxDECLARE_NO_COPY_CLASS(wxGridSelection); }; -#endif // #ifdef __WXGRIDSEL_H__ -#endif // #ifndef wxUSE_GRID - +#endif // wxUSE_GRID +#endif // _WX_GENERIC_GRIDSEL_H_