- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我现在已经奋斗了几个小时,只是为了能够在 Kivy 中自定义 TabbedPanel 的样式。这是我的代码:
#: import Utils kivy.utils
BoxLayout:
spacing: 0
padding: 0
canvas:
Color:
rgb: Utils.get_color_from_hex("#1b262d")[:3]
Rectangle:
size: self.size
TabbedPanel:
do_default_tab: False
tab_width: self.size[0] / 2
canvas:
Color:
rgb: Utils.get_color_from_hex("#00ff00")[:3]
Rectangle:
size: self.size
TabbedPanelItem:
background_color: Utils.get_color_from_hex("#1b262d")
text: "PAST"
background_down: ""
background_normal: ""
BoxLayout:
orientation: "vertical"
canvas:
Color:
rgb: Utils.get_color_from_hex("#1b262d")[:3]
Rectangle:
size: self.size
pos: self.pos
BoxLayout:
padding: [10, 12, 10, 12]
spacing: 5
size_hint_y: 0.1
TextInput:
background_color: Utils.get_color_from_hex("#303E46")
foreground_color: [1, 1, 1, 1]
size_hint_x: 0.2
padding: [10, ( self.height - self.line_height ) / 2]
text: "DATES"
TextInput:
size_hint_x: 0.15
padding: [10, ( self.height - self.line_height ) / 2]
text: "TEST"
TextInput:
size_hint_x: 0.2
padding: [10, ( self.height - self.line_height ) / 2]
text: "CAT"
TextInput:
size_hint_x: 0.15
padding: [10, ( self.height - self.line_height ) / 2]
text: "SORT BY"
TextInput:
size_hint_x: 0.15
padding: [10, ( self.height - self.line_height ) / 2]
text: "SHOW ONLY"
TextInput:
size_hint_x: 0.15
padding: [10, ( self.height - self.line_height ) / 2]
text: "SEARCH"
BoxLayout:
size_hint_y: 0.8
spacing: 10
padding: 10
orientation: "horizontal"
canvas:
Color:
rgb: Utils.get_color_from_hex("#303E46")[:3]
Rectangle:
size: self.size
pos: self.pos
Button:
size_hint_x: 0.7
text: "TEST"
Button:
size_hint_x: 0.3
text: "TESTS"
TabbedPanelItem:
background_color: Utils.get_color_from_hex("#303E46")
text: "UPCOMING"
background_down: ""
background_normal: ""
我实际上用绿色突出显示了我想要删除的部分。我不希望图片中出现这个绿色部分,也就是说我希望我的选项卡位于我的内容旁边,而没有这个奇怪的边框。
显然,如果我不强制 Canvas 为绿色,我会看到如下内容:
所以我看到我的 TabbedPanelItem 和我的内容之间有一个间隙,但我不知道如何删除它。我尝试将边框强制为0,将strip_border强制为0,更改高度我的小部件的strong>,将background_image强制为“”等,但我无法实现我想要的目的。
Kivy的专家可以帮助我吗?
提前谢谢
最佳答案
事情比我想象的更棘手......
按钮存储在 TabbedPanel
的 _tab_layout
属性内。它是 GridLayout 子类,您可以更改其 padding 属性。这是一个例子:
from kivy.app import App
from kivy.uix.floatlayout import FloatLayout
from kivy.uix.gridlayout import GridLayout
from kivy.lang import Builder
Builder.load_string('''
<StripLayoust>:
canvas:
Color:
rgba: (0, 1, 0, 1) # green
Rectangle:
size: self.size
pos: self.pos
<MainClass>:
TabbedPanel:
id: panel
do_default_tab: False
TabbedPanelItem:
text: "1"
Widget:
canvas:
Color:
rgb: 0.1, 0.3, .02
Rectangle:
size: self.size
pos: self.pos
TabbedPanelItem:
text: "2"
Widget:
canvas:
Color:
rgb: 0.7, 0.6, .02
Rectangle:
size: self.size
pos: self.pos
''')
class MainClass(FloatLayout):
def __init__(self, *args):
super(MainClass, self).__init__(*args)
self.ids["panel"]._tab_layout.padding = '2dp', '2dp', '2dp', '-2dp'
class TestApp(App):
def build(self):
return MainClass()
if __name__ == '__main__':
TestApp().run()
请注意,要删除此边框,我必须将底部填充设置为 -2dp
而不仅仅是 0dp
。为什么?好吧,事实证明,每次面板更改其 update_tabs
时,方法被调用,里面有 this cute line :
tab_layout.height = (tab_height + tab_layout.padding[1] +
tab_layout.padding[3] + dp(2))
添加 dp(2)
是硬编码的,因此我需要使用负值来抵消它。
我在这里使用下划线属性,它不是已建立的公共(public) API 的一部分,因此这种行为将来可能会改变。
关于python - Kivy:如何更改 TabbedPanel 的边框?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48485131/
我有一个带有两个选项卡的选项卡面板,当用户单击第二个选项卡上的“提交”时,我想保留在当前选项卡上,但使用新的 jsp 更改选项卡的内容。
非常感谢任何帮助。 这是一个显示问题的示例代码,当按下(“按我”)按钮并调整小部件大小( View 中出现白色框)时,TabbedPanel 会像小故障一样重新绘制(尽管事实并非如此)。 我尝试过更改
我在 sj:tabbedpanel 中有这些选项卡。我想知道激活了哪个选项卡并相应地设置隐藏字段的值。 tone ttwo
我现在已经奋斗了几个小时,只是为了能够在 Kivy 中自定义 TabbedPanel 的样式。这是我的代码: #: import Utils kivy.utils BoxLayout: spa
我在使用 Wicket 7.3 和 JQuery 2.1.4 时遇到以下问题: 在动态选项卡式面板(添加和删除选项卡)中,我想本地化选项卡标题并添加工具提示。我的代码 JQueryGenericPan
Kivy 似乎想让所有选项卡具有相同的大小。如果我想让一个选项卡比其他选项卡更宽怎么办?调整 TabbedPanelItem 的 tab_width 似乎没有效果,因此较长的文本被截断。 示例从 Ki
我是一名优秀的程序员,十分优秀!