《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

相关文章

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加