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

章节目录与知识点总揽

2.2 FloatLayout 布局

FloatLayout——浮动布局

        允许将子部件通过位置和尺寸放置在窗口的任意位置。在不同分辨率移动设备中,当窗口尺寸改变时,放置在窗口的子部件也会相应地调整大小和位置。不会因窗口大小的改变使布局变地一团糟。

2.2.1 使用步骤

        1.新建一个main.py文件

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

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

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

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

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

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

2.2.2 在.py内使用FloatLayout布局

        main.py代码如下:

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.floatlayout import FloatLayout
from kivy.graphics import Rectangle,Color

class FloatLayoutApp(App):
    def build(self):
        def update_rect(layout,*args):
            #设置背景尺寸,可忽略
            layout.rect.pos = layout.pos
            layout.rect.size = layout.size

        float_layout = FloatLayout()

        #设置背景颜色(可忽略)
        with float_layout.canvas:
            Color(1,1,1,1)
            float_layout.rect = Rectangle(pos=float_layout.pos,size=float_layout.size)
            float_layout.bind(pos=update_rect,size=update_rect)

        #在布局内的[300,200]处添加一个尺寸为0.3,0.2的按钮
        button = Button(text='Hello FloatLayout',size_hint=(.3,.2),pos=(300,200))
        #将按钮添加到布局内
        float_layout.add_widget(button)
        #返回布局
        return float_layout

if __name__ == '__main__':
    FloatLayoutApp().run()
        

        运行该文件,结果如下图:

7135ea3fda8e482db8627f61c72f2a4e.png

         当窗口的大小改变时,按钮的大小也会随之改变。但是位置并不会改变。因为这里给的是一个定值,如果需要位置也随之改变,需要使用pos_hint属性。

2.2.3 在kv内使用FloatLayout布局

        main.py代码如下:

from kivy.app import App
from kivy.uix.floatlayout import FloatLayout

class FloatLayoutWidget(FloatLayout):
    def __init__(self,**kwargs):
        super().__init__(*kwargs)

class FloatLayoutApp(App):
    #实现App类的build()方法(继承自App类)
    def build(self):
        return FloatLayoutWidget()

if __name__ == '__main__':
    FloatLayoutApp().run()

        floatlayout.kv代码如下:

<Button>:
	font_size:40
	size_hint:0.3,0.3

<FloatLayoutWidget>:

	canvas:
		Color:
			rgba:[1,1,1,1]
		Rectangle:
			size:self.size
			pos:self.pos
	Button:
		text:'Bt0'
		background_color:0.1,0.5,0.6,1
		pos_hint:{'x':0,'top':1}
	Button:
		text:'Bt1'
		background_color:0.1,0.5,0.6,1
		pos_hint:{'x':0.35,'y':0.3}
	Button:
		text:'Bt2'
		background_color:0.1,0.5,0.6,1
		pos_hint:{'x':.7,'bottom':0}
	Button:
		text:'Bt3'
		background_color:0.1,0.5,0.6,1
		pos_hint:{'x':.7,'top':1}
	Button:
		text:'Bt4'
		background_color:0.1,0.5,0.6,1
		pos_hint:{'x':0,'bottom':1}

        运行结果如下图:

03c358b33656425e91fb03cb071c877f.png

上一篇:大小和位置

下一篇:boxLayout布局

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python GUI设计PyQt5从入门实践.pdf》是一本介绍如何使用PyQt5库进行Python图形用户界面(GUI)设计的实践指南。该书涵盖了PyQt5库的基础知识、常用控件的使用以及高级主题,为读者提供了全面的学习和实践的机会。 这本书的目录相当全面,每章都详细介绍了相关的概念和使用技巧。第一章首先介绍了PyQt5的安装和基本的GUI编程概念,为读者打下了坚实的基础。之后,每章都介绍了不同的控件,如按钮、文本框、下拉菜单等,并演示了如何使用它们创建一个完整的GUI应用程序。作者提供了丰富的实例代码和图像以供读者参考。 此外,书中还介绍了PyQt5的高级特性,如布局管理器、信号与槽机制、多线程编程等。通过学习这些内容,读者将能够更高效地设计和开发复杂的GUI应用程序。 这本书的优势在于其实践性。每个章节都包含了大量的实例,读者可以通过这些实例来巩固所学知识,并了解如何将其应用到实际项目中。此外,书中还包含了一些实际项目的案例研究,读者可以通过模仿这些项目来提升自己的GUI设计和编程能力。 总体而言,《Python GUI设计PyQt5从入门实践.pdf》是一本很好的学习资源,适合想要学习PyQt5库的GUI设计和编程的Python开发人员。无论是初学者还是有一定经验的开发人员,都可以从这本书中获得很大的收益。希望读者可以通过这本书快速入门并掌握PyQt5的GUI设计技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

静候光阴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值