您仍然需要一个覆盖整个框架的面板,如果面板是框架的唯一子级,这将自动发生。
要获得所需的布局,您需要在水平盒子大小调整器 ( wx.BoxSizer(wx.HORIZONTAL)
) 中安排内容。如果您首先添加带有按钮的 sizer,然后添加 NBPanel,然后在右侧添加您想要的面板,您应该会获得所需的布局。
所有这些控件都需要 AppPanel 作为父控件,并且您需要将水平大小调整器设置为 AppPanels 大小调整器。
为了让笔记本占据框架中的大部分空间,您需要将其添加到比例为 1 的尺寸器中,而其他项目的比例为 0。
如果这会让事情变得更清楚,我很乐意制作一个快速演示:)
编辑:
这是一个简单的示例,它应该为您所追求的布局提供一个大纲,如果您有任何问题,请告诉我。另请查看本指南,它真的很棒,并提供了大量示例来帮助您开始使用不同的程序和布局。
import wx
class NoteBookPage(wx.Panel):
def __init__(self,parent,message):
wx.Panel.__init__(self,parent)
sizer= wx.BoxSizer(wx.VERTICAL)
message= wx.StaticText(self,label=message)
sizer.Add(message,1,wx.ALIGN_CENTRE)
self.SetSizer(sizer)
class AppFrame(wx.Frame):
def __init__(self,parent,id=-1,title='program'):
wx.Frame.__init__(self,parent,id,title,size=((400,400)))
# Panels
self.AppPanel = wx.Panel(self,-1)
self.AppPanel.SetBackgroundColour('grey')
main_sizer= wx.BoxSizer(wx.HORIZONTAL)
button_sizer= wx.BoxSizer(wx.VERTICAL)
#buttons
self.button1= wx.Button(self.AppPanel,label="Button 1")
button_sizer.Add(self.button1,0,wx.EXPAND)
self.button2= wx.Button(self.AppPanel,label="Button 2")
button_sizer.Add(self.button2,0,wx.EXPAND)
self.button3= wx.Button(self.AppPanel,label="Button 3")
button_sizer.Add(self.button3,0,wx.EXPAND)
main_sizer.Add(button_sizer,0,wx.ALL,5)
#notebook
self.Notebook= wx.Notebook(self.AppPanel)
page1= NoteBookPage(self.Notebook,"I'm on page 1")
page2= NoteBookPage(self.Notebook,"I'm on page 2")
self.Notebook.AddPage(page1,"Page 1")
self.Notebook.AddPage(page2,"Page 2")
main_sizer.Add(self.Notebook,1,wx.ALL|wx.EXPAND,5)
#panel on the right (I'm just re-using the NoteBookPage panel to save making a new one)
right_panel= NoteBookPage(self.AppPanel,"right panel")
main_sizer.Add(right_panel,0,wx.ALL,5)
self.AppPanel.SetSizer(main_sizer)
self.Show()
if __name__ == "__main__":
app= wx.App(False)
frame= AppFrame(None)
app.MainLoop()