gpt4 book ai didi

android - 基维 : Image + Label inside dynamic buttons

转载 作者:太空宇宙 更新时间:2023-11-03 13:22:38 25 4
gpt4 key购买 nike

我想在 for 循环中创建的动态按钮内显示图像+标签。问题是它只在最后一个按钮中显示图像+标签布局。如何在所有按钮中显示它?

主.py

class HomeScreen(Screen):
grid_l = ObjectProperty(None)
top_lbl = ObjectProperty(None)

def search_btn_pressed(self):
grid = self.grid_l
grid.bind(minimum_height=grid.setter('height'),
minimum_width=grid.setter('width'))

for i in range(3):
layout = GridLayout(cols=1)
print layout
img = Image(source='kivy.png')
print img
lbl = Label(text='label')
layout.add_widget(img)
layout.add_widget(lbl)

btn1 = Button(size_hint=(1, None))
btn1.text = '%r' % i
btn1.add_widget(layout)

grid.add_widget(btn1)

.kv

#:kivy 1.7.2

<HomeScreen>:
scroll_view: scrollviewID
top_lbl: lblID
grid_l: gridlayoutID
AnchorLayout:
size_hint: 1, .1
pos_hint: {'x': 0, 'y': .9}
anchor_x: 'center'
anchor_y: 'center'
Label:
id: lblID
text: 'Button Tester'
Button:
size_hint: 1, .1
pos_hint: {'x': 0, 'y': .8}
text: 'Press me!'
on_release: root.search_btn_pressed()
ScrollView:
id: scrollviewID
orientation: 'vertical'
pos_hint: {'x': 0, 'y': 0}
size_hint: 1, .8
bar_width: '8dp'
GridLayout:
id: gridlayoutID
cols: 1
size_hint: 1, None
row_default_height: 40
row_force_default: False

screenshot

最佳答案

它实际上不仅仅显示最后一个按钮 - 它显示每个按钮,但在相同的位置。问题是 Button 不是布局,因此不执行其子项的布局。因此,每个按钮的 GridLayout0, 0 处呈现,大小为 100, 100 相对于最近的相对父级的原点(在此在这种情况下,GridLayout grid_l 因为它包含在 ScrollView 中)。

当您将小部件添加到非布局小部件时,您可以通过设置位置和大小来布局这些小部件。请注意,您必须设置实际的 pos(或 xy)和 size(或 width height) - 您不能使用 pos_hintsize_hint,因为它们仅由布局处理。

这可以使用 dynamic classes 轻松完成在 kv language :

<CustomButton@Button>:
image_source: ''
subtext: ''
GridLayout:
height: self.parent.height # match the button's height
width: 100 # set to whatever you would like
pos: self.parent.pos # match the button's position
cols: 1
Image:
source: root.image_source
Label:
text: root.subtext

要使用动态类,您需要导入 Factory :

from kivy.factory import Factory

然后,在你的循环中:

for i in range(3):
btn = Factory.CustomButton(text=str(i), size_hint=(1, None),
image_source='kivy.png', subtext='label')
grid.add_widget(btn)

最后,附注:每次调用 search_btn_pressed() 时,您都会在 grid_l 上创建新的绑定(bind)。这些绑定(bind)应该只创建一次。您可以通过将这些绑定(bind)移动到 HomeScreen.__init__() 来在 Python 中绑定(bind)一次,但同样,这在 kv 中更容易:

    GridLayout:
id: gridlayoutID
cols: 1
size_hint: 1, None
row_default_height: 40
row_force_default: False
height: self.minimum_height # bind height to minimum_height
width: self.minimum_width # bind width to minimum_width

关于android - 基维 : Image + Label inside dynamic buttons,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25197707/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com