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

2023-11-06 12:20

本文主要是介绍《Python+Kivy(App开发)从入门到实践》自学笔记: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个按钮,内容如下:

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.stacklayout import StackLayout
from kivy.graphics import Rectangle, Colorclass StackLayoutWidget(StackLayout):def __init__(self,**kwargs):super().__init__(*kwargs)#设置背景色,可忽略with self.canvas:Color(1,1,1,1)self.rect = Rectangle(pos=self.pos,size=self.size)self.bind(pos=self.update_rect,size=self.update_rect)#自动生成25个按钮,分别以0-24命名,每一个按钮间隔5for i in range(25):btn = Button(text=str(i),width=40+i*5,size_hint=(None,0.15))self.add_widget(btn)def update_rect(self,*args):self.rect.pos = self.posself.rect.size = self.sizeclass StackApp(App):def build(self):return StackLayoutWidget()if __name__ == '__main__':StackApp().run()

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

7a7e6c0ddb234ee1bce2aabf422a68d3.png

2.9.3 在kv内使用StackLayout布局

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

from kivy.app import App
from kivy.uix.stacklayout import StackLayoutclass StackLayoutWidget(StackLayout):def __init__(self,**kwargs):super().__init__(**kwargs)class StackApp(App):def build(self):return StackLayoutWidget()if __name__ == '__main__':StackApp().run()

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

<StackLayoutWidget>:orientation:'lr-tb'canvas:Color:rgba:[1,1,1,1]Rectangle:size:self.sizepos:self.posButton:text:'B1'size_hint:[.2,.1]Button:text:'B2'size_hint:[.2,.1]Button:text:'B3'size_hint:[.2,.1]Button:text:'B4'size_hint:[.2,.1]Button:text:'B5'size_hint:[.2,.1]Button:text:'B6'size_hint:[.2,.1]Button:text:'B7'size_hint:[.2,.1]Button:text:'B8'size_hint:[.2,.1]Button:text:'B9'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属性,具体代码如下:

<StackLayoutWidget>:orientation:'lr-tb'padding:[20,10]spacing:[20,10]canvas:Color:rgba:[1,1,1,1]Rectangle:size:self.sizepos:self.posButton:text:'B1'size_hint:[.2,.1]Button:text:'B2'size_hint:[.2,.1]Button:text:'B3'size_hint:[.2,.1]Button:text:'B4'size_hint:[.2,.1]Button:text:'B5'size_hint:[.2,.1]Button:text:'B6'size_hint:[.2,.1]Button:text:'B7'size_hint:[.2,.1]Button:text:'B8'size_hint:[.2,.1]Button:text:'B9'size_hint:[.2,.1]

        运行结果如下:

71b127c7effe495998aa1bb515db62c8.png
       

上一篇:ScatterLayout布局

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

 

这篇关于《Python+Kivy(App开发)从入门到实践》自学笔记:StackLayout布局的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/356589

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal