wxPython正确的方式来对齐小部件

时间:2013-08-18 23:32:30

标签: wxpython alignment wxwidgets

我希望我的StaticTexts和TextCtrls像这样对齐: http://i.stack.imgur.com/llE7F.png

所以我这样做了:

import wx

class LoginForm(wx.Frame):
 def __init__(self):
    wx.Frame.__init__(self,None,wx.ID_ANY,title='Login',size=(800,600))

    self.panel = wx.Panel(self,wx.ID_ANY)

    email_label = wx.StaticText(self.panel,wx.ID_ANY,'Email: ')
    pass_label = wx.StaticText(self.panel,wx.ID_ANY,'Password: ')

    email = wx.TextCtrl(self.panel,wx.ID_ANY,'',size=(150,-1))
    passwd = wx.TextCtrl(self.panel,wx.ID_ANY,'',size=(150,-1))

    loginBtn = wx.Button(self.panel,wx.ID_ANY,'Login')
    self.Bind(wx.EVT_BUTTON,self.onLogin,loginBtn)

    topSizer =   wx.BoxSizer(wx.VERTICAL)
    labelSizer = wx.BoxSizer(wx.HORIZONTAL)
    inputSizer = wx.BoxSizer(wx.HORIZONTAL)

    labelSizer.Add(email_label,0,wx.RIGHT,112)
    labelSizer.Add(pass_label,0,wx.RIGHT,177)

    inputSizer.Add(email,0,wx.RIGHT,5)
    inputSizer.Add(passwd,0,wx.RIGHT,5)
    inputSizer.Add(loginBtn,0,wx.RIGHT,10)

    topSizer.Add(labelSizer,0,wx.TOP|wx.ALIGN_RIGHT,0)
    topSizer.Add(inputSizer,0,wx.TOP|wx.ALIGN_RIGHT,0)

    self.panel.SetSizer(topSizer)

 def onLogin(self):
    pass

if __name__=='__main__':
app = wx.App()
frame = LoginForm().Show()
app.MainLoop()

这是正确的方法吗?使用对齐标志和边框值?或者还有另一种方法可以做到这一点?

我这样做的方式,如果我想改变,例如登录按钮的宽度,一切都会搞砸

2 个答案:

答案 0 :(得分:0)

不,你永远不应该使用边框进行任何类型的对齐,这可以保证在其他平台甚至是使用不同字体的同一平台上中断。

我不确定你想要的布局有什么问题,老实说,只需将两个相同的垂直框大小调整器包含一个标签和一个文本放在一个水平框大小调整器中来实现它似乎是微不足道的(或者,你可以使用wxFlexGridSizer)。也许您应该澄清究竟是什么让您在边框中使用像素值。

答案 1 :(得分:0)

使用GridSizer进行类似的布局。

import wx

class Example(wx.Frame):

    def __init__(self, parent, title):
        super(Example, self).__init__(parent, title=title, 
            size=(450, 250))
        self.InitUI()
        self.Centre()
        self.Show()     

    def InitUI(self):
        vbox = wx.BoxSizer(wx.VERTICAL)
        gs = wx.GridSizer(4, 4, 1, 1)

        gs.AddMany( [
            (wx.StaticText(self), wx.EXPAND),
            (wx.StaticText(self), wx.EXPAND),
            (wx.StaticText(self, label='Email'), 0, wx.EXPAND),
            (wx.StaticText(self, label='Password'), 0, wx.EXPAND),
            (wx.StaticText(self), wx.EXPAND),
            (wx.StaticText(self), wx.EXPAND),
            (wx.TextCtrl(self), 0, ),
            (wx.TextCtrl(self), 0, ),
             ])

        vbox.Add(gs)
        self.SetSizer(vbox)

if __name__ == '__main__':

    app = wx.App()
    Example(None, title='Login')
    app.MainLoop()