假设您有一个 3 行 1 列的 GridLayout。第一行和最后一行将是标签,中间行将包含图像。
调整图像大小以使其具有固定高度(可能与标签高度可能相同也可能不同)并且其宽度与布局宽度相同的最佳方法是什么?是否可以在 kivy 中执行此操作,或者是否需要引入其他一些模块,例如 PIL,并使用图像缓冲区?仅创建一个以图像为背景的非绑定按钮是否合理(因此,让 kivy 负责调整大小),还是这个解决方案有问题?谢谢。
假设您有一个 3 行 1 列的 GridLayout。第一行和最后一行将是标签,中间行将包含图像。
调整图像大小以使其具有固定高度(可能与标签高度可能相同也可能不同)并且其宽度与布局宽度相同的最佳方法是什么?是否可以在 kivy 中执行此操作,或者是否需要引入其他一些模块,例如 PIL,并使用图像缓冲区?仅创建一个以图像为背景的非绑定按钮是否合理(因此,让 kivy 负责调整大小),还是这个解决方案有问题?谢谢。
调整图像大小以使其具有固定高度(可能与标签高度可能相同也可能不同)并且其宽度与布局宽度相同的最佳方法是什么?
我不确定你在这里问什么。你在谈论图像小部件吗?你可以这样做
Image:
source: 'whatever'
size_hint_y: None # Tells the layout to ignore the size_hint in y dir
height: dp(40) # The fixed height you want
您还可以通过查看Image 小部件的属性来控制不同的图像缩放可能性(拉伸、保持比例等) 。
是否可以在 kivy 中执行此操作,或者是否需要引入其他一些模块,例如 PIL,并使用图像缓冲区?仅创建一个以图像为背景的非绑定按钮是否合理(因此,让 kivy 负责调整大小),还是这个解决方案有问题?
即使我误解了你的问题,我认为你想要的任何东西都应该在 kivy 中很容易做到。我不认为您的按钮解决方案可以解决您的问题,或者您为什么认为它会解决您的问题 - 您仍然需要提供有关 Image 小部件大小的说明以使其缩放,但是您没有获得任何东西从把它放在一个按钮。并且按钮的 background_image 属性的任何缩放都可以在没有 Button 的情况下轻松完成 - 如上所述,您可以使用 Image 小部件的不同属性控制纵横比缩放等。
除了@inclement的答案
Image:
source: './data/icon.png'
allow_stretch: True
keep_ratio: True
size_hint_y: None
size_hint_x: None
width: self.parent.width
height: self.parent.width/self.image_ratio
使用这些属性,您可以缩放图像并将图像放置到框上而没有任何间隙。图像的宽度固定为父窗口小部件的宽度,高度根据图像的比例自动计算。