constraints for notebook pages work (again)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@259 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
1998-07-13 16:57:43 +00:00
parent 85504caca9
commit 5a8c929eb4
4 changed files with 88 additions and 56 deletions

View File

@@ -137,8 +137,15 @@ public:
// get the panel which represents the given page // get the panel which represents the given page
wxWindow *GetPage(int nPage) const; wxWindow *GetPage(int nPage) const;
// implementation
// --------------
// callbacks
void OnSize(wxSizeEvent&);
// base class virtuals // base class virtuals
virtual void AddChild(wxWindow *child); virtual void AddChild(wxWindow *child);
virtual void SetConstraintSizes(bool recurse);
virtual bool DoPhase(int phase);
private: private:
// common part of all ctors // common part of all ctors

View File

@@ -137,8 +137,15 @@ public:
// get the panel which represents the given page // get the panel which represents the given page
wxWindow *GetPage(int nPage) const; wxWindow *GetPage(int nPage) const;
// implementation
// --------------
// callbacks
void OnSize(wxSizeEvent&);
// base class virtuals // base class virtuals
virtual void AddChild(wxWindow *child); virtual void AddChild(wxWindow *child);
virtual void SetConstraintSizes(bool recurse);
virtual bool DoPhase(int phase);
private: private:
// common part of all ctors // common part of all ctors

View File

@@ -69,26 +69,6 @@ static void gtk_notebook_page_change_callback(GtkNotebook *WXUNUSED(widget),
notebook->ProcessEvent(event); notebook->ProcessEvent(event);
} }
static void gtk_notebook_client_size_callback( GtkWidget *WXUNUSED(widget), GtkAllocation* alloc,
wxNotebookPage *page )
{
if (!page->m_client->HasVMT()) return;
/*
printf( "OnResize from " );
if (page->m_client->GetClassInfo() && page->m_client->GetClassInfo()->GetClassName())
printf( page->m_client->GetClassInfo()->GetClassName() );
printf( ".\n" );
printf( " New: X: %d Y: %d ", alloc->x, alloc->y );
printf( " W: %d H: %d ", alloc->width, alloc->height );
printf( " .\n" );
*/
page->m_client->SetSize( alloc->x, alloc->y+26,
alloc->width, alloc->height );
};
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// wxNotebook // wxNotebook
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@@ -405,9 +385,6 @@ void wxNotebook::AddChild( wxWindow *win )
page->m_parent = GTK_NOTEBOOK(m_widget); page->m_parent = GTK_NOTEBOOK(m_widget);
gtk_signal_connect( GTK_OBJECT(m_widget), "size_allocate",
GTK_SIGNAL_FUNC(gtk_notebook_client_size_callback), (gpointer)page );
if (!page->m_page) if (!page->m_page)
{ {
wxLogFatalError( "Notebook page creation error" ); wxLogFatalError( "Notebook page creation error" );
@@ -417,6 +394,38 @@ void wxNotebook::AddChild( wxWindow *win )
m_pages.Append( page ); m_pages.Append( page );
}; };
void wxNotebook::OnSize(wxSizeEvent& event)
{
// forward this event to all pages
wxNode *node = m_pages.First();
while (node)
{
wxWindow *page = ((wxNotebookPage*)node->Data())->m_client;
// @@@@ the numbers I substract here are completely arbitrary, instead we
// should somehow calculate the size of the page from the size of the
// notebook
page->SetSize(event.GetSize().GetX() - 5,
event.GetSize().GetY() - 30);
if ( page->GetAutoLayout() )
page->Layout();
node = node->Next();
};
}
// override these 2 functions to do nothing: everything is done in OnSize
void wxNotebook::SetConstraintSizes(bool /* recurse */)
{
// don't set the sizes of the pages - their correct size is not yet known
wxControl::SetConstraintSizes(FALSE);
}
bool wxNotebook::DoPhase(int /* nPhase */)
{
return TRUE;
}
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// wxNotebookEvent // wxNotebookEvent
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------

View File

@@ -69,26 +69,6 @@ static void gtk_notebook_page_change_callback(GtkNotebook *WXUNUSED(widget),
notebook->ProcessEvent(event); notebook->ProcessEvent(event);
} }
static void gtk_notebook_client_size_callback( GtkWidget *WXUNUSED(widget), GtkAllocation* alloc,
wxNotebookPage *page )
{
if (!page->m_client->HasVMT()) return;
/*
printf( "OnResize from " );
if (page->m_client->GetClassInfo() && page->m_client->GetClassInfo()->GetClassName())
printf( page->m_client->GetClassInfo()->GetClassName() );
printf( ".\n" );
printf( " New: X: %d Y: %d ", alloc->x, alloc->y );
printf( " W: %d H: %d ", alloc->width, alloc->height );
printf( " .\n" );
*/
page->m_client->SetSize( alloc->x, alloc->y+26,
alloc->width, alloc->height );
};
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// wxNotebook // wxNotebook
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@@ -405,9 +385,6 @@ void wxNotebook::AddChild( wxWindow *win )
page->m_parent = GTK_NOTEBOOK(m_widget); page->m_parent = GTK_NOTEBOOK(m_widget);
gtk_signal_connect( GTK_OBJECT(m_widget), "size_allocate",
GTK_SIGNAL_FUNC(gtk_notebook_client_size_callback), (gpointer)page );
if (!page->m_page) if (!page->m_page)
{ {
wxLogFatalError( "Notebook page creation error" ); wxLogFatalError( "Notebook page creation error" );
@@ -417,6 +394,38 @@ void wxNotebook::AddChild( wxWindow *win )
m_pages.Append( page ); m_pages.Append( page );
}; };
void wxNotebook::OnSize(wxSizeEvent& event)
{
// forward this event to all pages
wxNode *node = m_pages.First();
while (node)
{
wxWindow *page = ((wxNotebookPage*)node->Data())->m_client;
// @@@@ the numbers I substract here are completely arbitrary, instead we
// should somehow calculate the size of the page from the size of the
// notebook
page->SetSize(event.GetSize().GetX() - 5,
event.GetSize().GetY() - 30);
if ( page->GetAutoLayout() )
page->Layout();
node = node->Next();
};
}
// override these 2 functions to do nothing: everything is done in OnSize
void wxNotebook::SetConstraintSizes(bool /* recurse */)
{
// don't set the sizes of the pages - their correct size is not yet known
wxControl::SetConstraintSizes(FALSE);
}
bool wxNotebook::DoPhase(int /* nPhase */)
{
return TRUE;
}
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// wxNotebookEvent // wxNotebookEvent
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------