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