bug with Shift-TAB handling corrected

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1543 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
1999-01-31 23:50:58 +00:00
parent 396bdd5ab1
commit fb99aca7f3

View File

@@ -6,7 +6,7 @@
// Created: 04/01/98 // Created: 04/01/98
// RCS-ID: $Id$ // RCS-ID: $Id$
// Copyright: (c) Julian Smart and Markus Holzem // Copyright: (c) Julian Smart and Markus Holzem
// Licence: wxWindows license // Licence: wxWindows license
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__ #ifdef __GNUG__
@@ -51,7 +51,7 @@ bool wxPanel::Create(wxWindow *parent, wxWindowID id,
{ {
bool ret = wxWindow::Create(parent, id, pos, size, style, name); bool ret = wxWindow::Create(parent, id, pos, size, style, name);
if ( ret ) if ( ret )
{ {
#ifndef __WXGTK__ #ifndef __WXGTK__
SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_3DFACE)); SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_3DFACE));
@@ -81,6 +81,7 @@ void wxPanel::OnSysColourChanged(wxSysColourChangedEvent& event)
void wxPanel::OnNavigationKey( wxNavigationKeyEvent& event ) void wxPanel::OnNavigationKey( wxNavigationKeyEvent& event )
{ {
// there is not much to do if we have only one child (or not at all)
if (GetChildren().GetCount() < 2) if (GetChildren().GetCount() < 2)
{ {
event.Skip(); event.Skip();
@@ -88,59 +89,66 @@ void wxPanel::OnNavigationKey( wxNavigationKeyEvent& event )
} }
// don't process these ones here // don't process these ones here
if (event.IsWindowChange()) if (event.IsWindowChange())
{ {
event.Skip(); event.Skip();
return; return;
} }
wxWindow *winFocus = event.GetCurrentFocus(); wxWindow *winFocus = event.GetCurrentFocus();
if (!winFocus) winFocus = wxWindow::FindFocus(); if (!winFocus)
winFocus = wxWindow::FindFocus();
if (!winFocus) if (!winFocus)
{ {
event.Skip(); event.Skip();
return; return;
} }
wxNode *start_node = GetChildren().Find( winFocus ); wxNode *start_node = GetChildren().Find( winFocus );
if (!start_node) start_node = GetChildren().First(); if (!start_node)
start_node = GetChildren().First();
wxNode *node = event.GetDirection() ? start_node->Next() : start_node->Previous();
wxNode *node = event.GetDirection() ? start_node->Next()
: start_node->Previous();
while (node != start_node) while (node != start_node)
{ {
if (!node) if (!node)
{ {
/* #if 0
if (GetParent() != NULL) if (GetParent() != NULL)
{ {
wxNavigationKeyEvent new_event; wxNavigationKeyEvent new_event;
new_event.SetDirection( event.GetDirection() ); new_event.SetDirection( event.GetDirection() );
new_event.SetWindowChange(FALSE); new_event.SetWindowChange(FALSE);
new_event.SetCurrentFocus( this ); new_event.SetCurrentFocus( this );
if (GetParent()->GetEventHandler()->ProcessEvent(new_event)) if (GetParent()->GetEventHandler()->ProcessEvent(new_event))
{ {
return; return;
} }
} }
*/ #endif // 0
node = event.GetDirection() ? GetChildren().First() : GetChildren().Last(); node = event.GetDirection() ? GetChildren().First()
} : GetChildren().Last();
}
wxWindow *child = (wxWindow*) node->Data();
wxWindow *child = (wxWindow *)node->Data();
if (child->AcceptsFocus())
{ if (child->AcceptsFocus())
child->SetFocus(); {
return; // ok, event processed
} child->SetFocus();
return;
node = node->Next(); }
node = event.GetDirection() ? node->Next() : node->Previous();
} }
// we cycled through all of our children and none of them wanted to accept
// focus
event.Skip(); event.Skip();
} }