当前位置:   article > 正文

《Python+Kivy(App开发)从入门到实践》自学笔记:StackLayout布局

stacklayout

章节目录与知识点总揽

2.9 StackLayout布局

        StackLayout布局——堆栈布局

        在此布局中,只要不超过布局的范围,就可以进行垂直或水平地排列子项,且各个小部件的大小可以不必相同。StackLayout布局可以通过orentation属性制定布局方向。默认为“lr-tb”。

        解释:

                l、r、t、b都为单词首字母:

                        l ——left           表示左

                        r ——right        表示右

                        t ——top          表示上

                        b ——bottom   表示下

                        ‘lr’表示从左到右,'rl'表示从右到左;‘tb’表示自上到下,'bt'表示自下而上。因此orientation属性共有8个属性:

                        按行排列:‘lr-tb’、‘lr-bt’、‘rl-tb’、‘rl-bt’;

                        按列排列:‘tb-lr’、‘bt-lr’、‘tb-rl’、‘bt-rl’。

2.9.1 使用步骤

        1.新建一个main.py文件

        2.导入App类以及相关的包,例如:StackLayout、Button

        3.创建一个类让它继承App类。

        4.在该类内实现build()方法

        5.编写具体的布局或布局类,让其继承StackLayout类。

        6.在build()方法结尾返回具体的布局或布局类。

        7.通过run()方法运行实例。


 
2.9.2 在py内引用StackLayout布局

        新建main.py文件,使用for循环生成25个按钮,内容如下:

  1. from kivy.app import App
  2. from kivy.uix.button import Button
  3. from kivy.uix.stacklayout import StackLayout
  4. from kivy.graphics import Rectangle, Color
  5. class StackLayoutWidget(StackLayout):
  6. def __init__(self,**kwargs):
  7. super().__init__(*kwargs)
  8. #设置背景色,可忽略
  9. with self.canvas:
  10. Color(1,1,1,1)
  11. self.rect = Rectangle(pos=self.pos,size=self.size)
  12. self.bind(pos=self.update_rect,size=self.update_rect)
  13. #自动生成25个按钮,分别以0-24命名,每一个按钮间隔5
  14. for i in range(25):
  15. btn = Button(text=str(i),width=40+i*5,size_hint=(None,0.15))
  16. self.add_widget(btn)
  17. def update_rect(self,*args):
  18. self.rect.pos = self.pos
  19. self.rect.size = self.size
  20. class StackApp(App):
  21. def build(self):
  22. return StackLayoutWidget()
  23. if __name__ == '__main__':
  24. StackApp().run()

        运行main.py,一次排列生成了25个按钮,结果如下图:

7a7e6c0ddb234ee1bce2aabf422a68d3.png

2.9.3 在kv内使用StackLayout布局

        更改main.py文件内容如下:

  1. from kivy.app import App
  2. from kivy.uix.stacklayout import StackLayout
  3. class StackLayoutWidget(StackLayout):
  4. def __init__(self,**kwargs):
  5. super().__init__(**kwargs)
  6. class StackApp(App):
  7. def build(self):
  8. return StackLayoutWidget()
  9. if __name__ == '__main__':
  10. StackApp().run()

        根据StackApp类名,新建一个stack.kv文件,内容如下:

  1. <StackLayoutWidget>:
  2. orientation:'lr-tb'
  3. canvas:
  4. Color:
  5. rgba:[1,1,1,1]
  6. Rectangle:
  7. size:self.size
  8. pos:self.pos
  9. Button:
  10. text:'B1'
  11. size_hint:[.2,.1]
  12. Button:
  13. text:'B2'
  14. size_hint:[.2,.1]
  15. Button:
  16. text:'B3'
  17. size_hint:[.2,.1]
  18. Button:
  19. text:'B4'
  20. size_hint:[.2,.1]
  21. Button:
  22. text:'B5'
  23. size_hint:[.2,.1]
  24. Button:
  25. text:'B6'
  26. size_hint:[.2,.1]
  27. Button:
  28. text:'B7'
  29. size_hint:[.2,.1]
  30. Button:
  31. text:'B8'
  32. size_hint:[.2,.1]
  33. Button:
  34. text:'B9'
  35. size_hint:[.2,.1]

        运行结果如下图:

c3cc1bca31e64a46a5e775068006f783.png

 2.9.4 布局的基本属性

        除去布局方向orientation外,StackLayout还可以使用padding和spacing属性来控制布局和部件、部件和部件之间的距离。StackLayout布局还会根据子部件来自动设置一些属性,例如:minimum_height最低高度、minimum_width最小宽度、minimum_size最小尺寸(同时设置最低高度和最小宽度)

padding属性可以接受以下三种参属形式:

        [padding_left,padding_top,padidng_right,padidng_bottom],例如默认的[0,0,0,0],分别代表着与左、上、右、下四个方向的边距都为0。
        [padding_horizontl,padding_vertical]分别代表水平和垂直两个方向的间距。
        [padding]代表四周的间距


Spacing属性可以接受以下两种参数形式:
        [spacing_horizontal,spacing_vertical]分表代表水平和垂直两个方向的间距。
        [spacing]代表四周的间距。

        在stack.kv文件中加入spacing和padding属性,具体代码如下:

  1. <StackLayoutWidget>:
  2. orientation:'lr-tb'
  3. padding:[20,10]
  4. spacing:[20,10]
  5. canvas:
  6. Color:
  7. rgba:[1,1,1,1]
  8. Rectangle:
  9. size:self.size
  10. pos:self.pos
  11. Button:
  12. text:'B1'
  13. size_hint:[.2,.1]
  14. Button:
  15. text:'B2'
  16. size_hint:[.2,.1]
  17. Button:
  18. text:'B3'
  19. size_hint:[.2,.1]
  20. Button:
  21. text:'B4'
  22. size_hint:[.2,.1]
  23. Button:
  24. text:'B5'
  25. size_hint:[.2,.1]
  26. Button:
  27. text:'B6'
  28. size_hint:[.2,.1]
  29. Button:
  30. text:'B7'
  31. size_hint:[.2,.1]
  32. Button:
  33. text:'B8'
  34. size_hint:[.2,.1]
  35. Button:
  36. text:'B9'
  37. size_hint:[.2,.1]

        运行结果如下:

71b127c7effe495998aa1bb515db62c8.png
       

上一篇:ScatterLayout布局

下一篇:​ 动手实践——计时器:基本布局 ​

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/334655
推荐阅读
相关标签
  

闽ICP备14008679号