跳转至

§1.2 实现一个简单的界面

字数 577 个   代码 33 行   图片 4 张   阅读时间 2 分钟   访问量

本节不对 maliang 的具体使用做详细讲解,这里只是给大家提供一个简单程序体验一下 maliang

以最简单的登录窗口为例,说明一下使用 maliang 搭建图形界面的流程是怎样的。

一、登录窗口

1.1 构建窗口

运行以下命令以构建一个标题为 “登录” 并且居中窗口

1
2
3
4
5
import maliang

root = maliang.Tk(title="登录")
root.center()
root.mainloop()

maliang 是支持暗色模式的,如果您装有 darkdetect 可选依赖包,则 maliang 不仅仅会将界面渲染成暗色,窗口也会更改为暗色模式。

特别注意:窗口的暗色模式可能不生效

third-party:第三方包功能

窗口本身的暗色模式在部分操作系统上可能不会生效(如部分 Linux 系统),但窗口内部的控件等的暗色模式是可以修改的。关于窗口的暗色模式,模式的检测与第三方包 albertosottile/darkdetect 有关,模式的支持与操作系统及相关第三方包有关,下面是对应关系:

1.2 创建画布

maliang 的宗旨就是,一切都是通过画布“画”出来的,你可以把画布当作网页的页面,每一页就是一个画布实例。使用 Canvas 来创建画布。

1
2
3
4
5
6
7
8
9
import maliang

root = maliang.Tk(title="登录")
root.center()

cv = maliang.Canvas(auto_zoom=True, keep_ratio="min", free_anchor=True)
cv.place(width=1280, height=720, x=640, y=360, anchor="center")

root.mainloop()

1.3 创建控件

创建一些控件来实现登录窗口。

import maliang

root = maliang.Tk(title="登录")
root.center()

cv = maliang.Canvas(auto_zoom=True, keep_ratio="min", free_anchor=True)
cv.place(width=1280, height=720, x=640, y=360, anchor="center")

maliang.Text(cv, (640, 200), text="账 号 登 录", fontsize=48, anchor="center")

maliang.Text(cv, (450, 300), text="账号", anchor="nw")
maliang.InputBox(cv, (450, 340), (380, 50), placeholder="点击输入账号")
maliang.Text(cv, (450, 400), text="密码", anchor="nw")
maliang.InputBox(cv, (450, 440), (380, 50), show="●", placeholder="点击输入密码")

maliang.Button(cv, (450, 540), (180, 50), text="注 册")
maliang.Button(cv, (650, 540), (180, 50), text="登 录")

root.mainloop()

这样就完成了一个没有功能的登录界面。你可以在此时尝试着更改操作系统颜色模式,看看该窗口的颜色模式会不会跟随改变。(1)

  1. 💡你也可以在页面顶栏试着切换网站的主题(点击图标 来切换),看看不同主题下程序运行的效果
图1 教程环境下的运行结果

温馨提示:界面外观与系统有关

对于不同的操作系统,maliang 构建出来的界面的外观不一定相同,若没有强制指定 maliang 的系统变量,maliang 会自动获取当前系统类型,并根据类型绘制不同的界面外观。如在 Windows10 和 Windows11 中的界面就不相同,Windows10 的界面更符合 Windows10 风格(如下):

light dark