Kivy 自学笔记(一):构建基本的 Kivy 应用

2023年1月14日,更新(纠错)中。

声明:1、本文章总结自该系列视频,且为个人用笔记,转载需注明出处。2、让人不适的评论将会被删评+屏蔽。

一、main.py与.kv文件

  基本的 Kivy 应用需要一个main.py与.kv文件。main.py顾名思义,而.ky文件主要用于搭建窗口布局(类似于PyQt中的.ui文件)。虽然理论上可以在python文件中搭建窗口布局,但本着前后端分离的原则,不建议这么做。
  .kv文件应当与你的应用(类)同名且为小写,若你的应用名为TheLab或TheLabApp(此时kivy会自动忽视“App”三个字母),kivy会自动寻找main.py同路径下名为thelab.kv的文件。
  如下为一对可以运行的文件,依次名为main.py和mytask.kv。

from kivy.app import App
from kivy.uix.widget import Widget

class MainWidget(Widget):
    pass

class MyTask(App):
    pass

if __name__ == '__main__':
    MyTask().run()
MainWidget: # 启动界面

<MainWidget>:
    Button: # 按钮控件
        text: "A" # 内部字符
        size: "40dp", "40dp" # 尺寸
        pos: "50dp", "100dp" # 位置
        color: 1,0,0,1 # 颜色
    Label: # 标签控件
        text: "B"
        size: "100dp", "100dp"
        pos: "200dp", "200dp"

此时main.py运行结果应该如下图。

img1

二、补充解释

1、kivy坐标系

  此窗口应当是可以任意拖动调节大小的,且按钮A与标签B相对于左下角的位置固定。因此需要明确的是,与numpy和opencv均不同,kivy的坐标系原点为窗口左下角,向右为x轴(第一维),向上为y轴(第二维)

2、像素与dp

  为保证控件尺寸在不同像素密度的屏幕上显示大小相同,使用dp作为尺寸单位而不是像素,更加具体的区别请自行百度。格式上,使用dp的尺寸需要加单引号或双引号,而使用像素的尺寸可直接使用数字。如示例代码中的“Button”控件的尺寸,使用dp表示如下。

size: "40dp", "40dp"

而使用像素表示如下。(二者实际看起来大小可能不同)

size: 40, 40

40dp*40dp通常为手指大小。

3、颜色

  颜色分量依次为RGBA,且为浮点数0-1而不是传统的0-255,允许忽略小数点前的0。

4、绘制顺序

  一般情况下,kivy将按顺序绘制控件,这意味着若A和B的位置相同,B将被覆盖绘制在A上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值