git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@57195
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// event handlers
void OnPaint(wxPaintEvent& event);
void OnMouse(wxMouseEvent& event);
// event handlers
void OnPaint(wxPaintEvent& event);
void OnMouse(wxMouseEvent& event);
+ void OnKeyDown(wxKeyEvent& event);
void OnCaptureLost(wxMouseCaptureLostEvent& event);
// return the horizontal start position of the given column in physical
void OnCaptureLost(wxMouseCaptureLostEvent& event);
// return the horizontal start position of the given column in physical
// column 1 but close enough to the divider separating it from column 0)
int FindColumnAtPos(int x, bool& onSeparator) const;
// column 1 but close enough to the divider separating it from column 0)
int FindColumnAtPos(int x, bool& onSeparator) const;
+ // return true if a drag resizing operation is currently in progress
+ bool IsResizing() const;
+
// end any drag operation currently in progress (resizing or reordering)
void EndDragging();
// end any drag operation currently in progress (resizing or reordering)
void EndDragging();
// wxHeaderCtrl dragging
// ----------------------------------------------------------------------------
// wxHeaderCtrl dragging
// ----------------------------------------------------------------------------
+bool wxHeaderCtrl::IsResizing() const
+{
+ return m_colBeingResized != COL_NONE;
+}
+
void wxHeaderCtrl::UpdateResizingMarker(int xPhysical)
{
// unfortunately drawing the marker over the parent window doesn't work as
void wxHeaderCtrl::UpdateResizingMarker(int xPhysical)
{
// unfortunately drawing the marker over the parent window doesn't work as
void wxHeaderCtrl::EndResizing(int width)
{
void wxHeaderCtrl::EndResizing(int width)
{
- wxASSERT_MSG( m_colBeingResized != COL_NONE,
- "shouldn't be called if we're not resizing" );
+ wxASSERT_MSG( IsResizing(), "shouldn't be called if we're not resizing" );
EVT_MOUSE_EVENTS(wxHeaderCtrl::OnMouse)
EVT_MOUSE_CAPTURE_LOST(wxHeaderCtrl::OnCaptureLost)
EVT_MOUSE_EVENTS(wxHeaderCtrl::OnMouse)
EVT_MOUSE_CAPTURE_LOST(wxHeaderCtrl::OnCaptureLost)
+
+ EVT_KEY_DOWN(wxHeaderCtrl::OnKeyDown)
END_EVENT_TABLE()
void wxHeaderCtrl::OnPaint(wxPaintEvent& WXUNUSED(event))
END_EVENT_TABLE()
void wxHeaderCtrl::OnPaint(wxPaintEvent& WXUNUSED(event))
void wxHeaderCtrl::OnCaptureLost(wxMouseCaptureLostEvent& WXUNUSED(event))
{
void wxHeaderCtrl::OnCaptureLost(wxMouseCaptureLostEvent& WXUNUSED(event))
{
- if ( m_colBeingResized != COL_NONE )
+ if ( IsResizing() )
+ EndResizing(-1);
+}
+
+void wxHeaderCtrl::OnKeyDown(wxKeyEvent& event)
+{
+ if ( IsResizing() && event.GetKeyCode() == WXK_ESCAPE )
+ {
+ ReleaseMouse();
+ }
+ else
+ {
+ event.Skip();
+ }
}
void wxHeaderCtrl::OnMouse(wxMouseEvent& mevent)
}
void wxHeaderCtrl::OnMouse(wxMouseEvent& mevent)
// first deal with the [continuation of any] dragging operations in
// progress
// first deal with the [continuation of any] dragging operations in
// progress
- if ( m_colBeingResized != COL_NONE )
{
if ( mevent.LeftUp() )
EndResizing(xPhysical - GetColStart(m_colBeingResized));
{
if ( mevent.LeftUp() )
EndResizing(xPhysical - GetColStart(m_colBeingResized));