我想在横幅示例中使用标题制作可重复使用的Container。(所以它就像一个自定义的GroupBox)。因此,我添加到类中的每个元素都应添加到类子容器中,而不是自身。参见下面的代码,我标记了我只想写子元素的位置。
from enaml.widgets.api import *
from enaml.layout.api import *
from enaml.styling import *
enamldef BannerSheet(StyleSheet):
Style:
element = 'Label'
style_class = 'banner'
Setter:
field = 'background'
value = ('lineargradient(x1: 0, y1:0, x2:0, y2:1, '
'stop: 0 #222222, stop: 0.5 #1A1A1A, stop: 1 #111111)')
Setter:
field = 'color'
value = '#FFFFEF'
Setter:
field = 'padding'
value = '5px'
Setter:
field = 'font'
value = '18pt Verdana'
enamldef Banner(Container):
BannerSheet:
pass
padding = 0
alias title : lbl.text
constraints = [lbl.left == left,
lbl.right == right,
con.top == lbl.bottom,
con.bottom<=bottom]
Label: lbl:
name = 'abd'
style_class = 'banner'
Container: con:
pass
enamldef DemoContainer(Container):
padding = 0
Banner: b:
title = 'Bar'
#i want children here to be put into the banner.con container.
#so e.g.
Label:
text = 'This should be below the title label"
Enaml不允许您使用声明性语法来委托小部件在层次结构中的位置(可以使用Include和过程代码来实现)。您最简单的选择是在横幅上使用一个子容器,其中包含小部件。类似于以下内容:
from enaml.widgets.api import *
enamldef BannerContainer(Container):
alias text: label.text
Label: label:
pass
enamldef Main(Window):
Container:
BannerContainer:
text = 'First Banner'
Container:
padding = 0
Field: pass
Field: pass
Field: pass
BannerContainer:
text = 'Second Banner'
Container:
padding = 0
PushButton: pass
PushButton: pass
PushButton: pass
另外,您可以子类化容器并重新实现layout_constraints方法以完成您想要的布局目的(请参见TaskDialog实现以获取示例),或使用模板和编译时for-each循环来扩展子窗口小部件(请参见高级模板示例)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句