Added wxWindow::IsDescendant() helper.
This function checks if another window is a direct or indirect child of this one, which can be needed in a number of situations. See #3063. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@71024 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -740,6 +740,10 @@ public:
|
|||||||
// is this window a top level one?
|
// is this window a top level one?
|
||||||
virtual bool IsTopLevel() const;
|
virtual bool IsTopLevel() const;
|
||||||
|
|
||||||
|
// is this window a child or grand child of this one (inside the same
|
||||||
|
// TLW)?
|
||||||
|
bool IsDescendant(wxWindowBase* win) const;
|
||||||
|
|
||||||
// it doesn't really change parent, use Reparent() instead
|
// it doesn't really change parent, use Reparent() instead
|
||||||
void SetParent( wxWindowBase *parent ) { m_parent = (wxWindow *)parent; }
|
void SetParent( wxWindowBase *parent ) { m_parent = (wxWindow *)parent; }
|
||||||
// change the real parent of this window, return true if the parent
|
// change the real parent of this window, return true if the parent
|
||||||
|
@@ -493,6 +493,23 @@ public:
|
|||||||
@see GetNextSibling()
|
@see GetNextSibling()
|
||||||
*/
|
*/
|
||||||
wxWindow* GetPrevSibling() const;
|
wxWindow* GetPrevSibling() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Check if the specified window is a descendant of this one.
|
||||||
|
|
||||||
|
Returns @true if the window is a descendant (i.e. a child or
|
||||||
|
grand-child or grand-grand-child or ...) of this one.
|
||||||
|
|
||||||
|
Notice that a window can never be a descendant of another one if they
|
||||||
|
are in different top level windows, i.e. a child of a wxDialog is not
|
||||||
|
considered to be a descendant of dialogs parent wxFrame.
|
||||||
|
|
||||||
|
@param win Any window, possible @NULL (@false is always returned then).
|
||||||
|
|
||||||
|
@since 2.9.4
|
||||||
|
*/
|
||||||
|
bool IsDescendant(wxWindowBase* win) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Reparents the window, i.e. the window will be removed from its
|
Reparents the window, i.e. the window will be removed from its
|
||||||
current parent window (e.g. a non-standard toolbar in a wxFrame)
|
current parent window (e.g. a non-standard toolbar in a wxFrame)
|
||||||
|
@@ -1242,9 +1242,28 @@ void wxWindowBase::Thaw()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// reparenting the window
|
// Dealing with parents and children.
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxWindowBase::IsDescendant(wxWindowBase* win) const
|
||||||
|
{
|
||||||
|
// Iterate until we find this window in the parent chain or exhaust it.
|
||||||
|
while ( win )
|
||||||
|
{
|
||||||
|
wxWindow* const parent = win->GetParent();
|
||||||
|
if ( parent == this )
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// Stop iterating on reaching the top level window boundary.
|
||||||
|
if ( parent->IsTopLevel() )
|
||||||
|
break;
|
||||||
|
|
||||||
|
win = parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void wxWindowBase::AddChild(wxWindowBase *child)
|
void wxWindowBase::AddChild(wxWindowBase *child)
|
||||||
{
|
{
|
||||||
wxCHECK_RET( child, wxT("can't add a NULL child") );
|
wxCHECK_RET( child, wxT("can't add a NULL child") );
|
||||||
|
Reference in New Issue
Block a user