百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Flet 界面设计1:用Column、Row和Container控件设计“计算器”

liuian 2025-02-27 15:51 17 浏览

为回应网友和粉丝咨询,本期使用 Flet 几个常用的“布局”控件,设计一个漂亮的“计算器”界面,从这个例子中,就可以掌握常用的 界面 设计技巧了。

一个真实的应用,会设计多个界面,各界面有相同的部分,这就需要界面复用了,这个下期再讲。今天主要分享 Column、Row和Container 这3个控件,用他们就足够设计一个漂亮的“计算器”了。下面,循序渐进地设计和优化界面:

循序渐进第一步:不用任何布局控件,直接用最原始的 page.add(),看看是什么样子

import flet as ft

def main(page: ft.Page):
    page.title = "我的计算器" # 定义标题
    result = ft.Text(value="0") # 计算结果存在着“文本”控件中

    # 一口气添加计算器所有按钮
    page.add(
        result,
        ft.ElevatedButton(text="AC"),
        ft.ElevatedButton(text="+/-"),
        ft.ElevatedButton(text="%"),
        ft.ElevatedButton(text="/"),
        ft.ElevatedButton(text="7"),
        ft.ElevatedButton(text="8"),
        ft.ElevatedButton(text="9"),
        ft.ElevatedButton(text="*"),
        ft.ElevatedButton(text="4"),
        ft.ElevatedButton(text="5"),
        ft.ElevatedButton(text="6"),
        ft.ElevatedButton(text="-"),
        ft.ElevatedButton(text="1"),
        ft.ElevatedButton(text="2"),
        ft.ElevatedButton(text="3"),
        ft.ElevatedButton(text="+"),
        ft.ElevatedButton(text="0"),
        ft.ElevatedButton(text="."),
        ft.ElevatedButton(text="="),
    )

ft.app(target=main)

按vscode的F5键,运行看效果如下:

直接用 page.add(),元素都在1列中,界面很丑很不合理,这显然不是我们需要的。但这也说明一个问题:就是 Flet 界面布局,默认是一个 “列”,记住这个特性。

循序渐进第二步:使用“行”布局控件Row,把以上按钮,分布在多个“行”中间。当然,控件Row 也需要 add 到根控件 page 中。Row 控件 用数组容纳子控件,务必用数组 [ ]

import flet as ft

def main(page: ft.Page):
    page.title = "我的计算器" # 定义标题
    result = ft.Text(value="0") # 计算结果存在着“文本”控件中

    # 一口气添加多个 Row 控件
    page.add(
        # Row 控件 用数组容纳子控件,务必用数组 [ ] 
        # 把计算结果单独放在一行中
        ft.Row(controls=[result,]), 
        # 把 AC、+/-、%、/   这4个按钮,放在单独一行中
        ft.Row(controls=[
                ft.ElevatedButton(text="AC"),
                ft.ElevatedButton(text="+/-"),
                ft.ElevatedButton(text="%"),
                ft.ElevatedButton(text="/"),
            ]
        ),
        # 如法炮制,把其他按钮也分组到各自单独的行中,如下:
        ft.Row(
            controls=[
                ft.ElevatedButton(text="7"),
                ft.ElevatedButton(text="8"),
                ft.ElevatedButton(text="9"),
                ft.ElevatedButton(text="*"),
            ]
        ),
        ft.Row(
            controls=[
                ft.ElevatedButton(text="4"),
                ft.ElevatedButton(text="5"),
                ft.ElevatedButton(text="6"),
                ft.ElevatedButton(text="-"),
            ]
        ),
        ft.Row(
            controls=[
                ft.ElevatedButton(text="1"),
                ft.ElevatedButton(text="2"),
                ft.ElevatedButton(text="3"),
                ft.ElevatedButton(text="+"),
            ]
        ),
        ft.Row(
             controls=[
                ft.ElevatedButton(text="0"),
                ft.ElevatedButton(text="."),
                ft.ElevatedButton(text="="),
            ]
        ),
    )

ft.app(target=main)

按vscode的F5键,运行看效果如下:

用 “行”控件Row,对按钮进行分行呈现后,美观多了,但还是不够漂亮。

循序渐进第三步:用 “列”控件Column 和 “容器”控件Container,进一步美化界面。

因为Flet的“容器”控件Container,每个只能装饰一个控件,为了可以整体装饰所有按钮,我们需要把上面的各个行,放在一个“列”控件Column中,然后Container就可以对这个Column进行装饰了。

这里用到了控件的几个通用属性:color 定义颜色,size定义文字大小,bgcolor定义背景色;特别用到了 expand 属性,每个控件expand 值的比例分配容器内的剩余空间,确保容器里面的子控件,自动适应大小。

import flet as ft

def main(page: ft.Page):

    page.title = "我的计算器" # 定义标题
    page.window_height = 380 # 定义窗口尺寸
    page.window_width  = 450

    # 计算结果存在着“文本”控件中。color定义颜色,size定义文本大小
    result = ft.Text(value="0",color='#ffffff',size=20) 

    page.add(
        ft.Container( 
            bgcolor="#000000", # 容器背景色为黑色
            width= 400, # 容器的宽、高
            height= 300,
            border_radius= ft.border_radius.all(20), # 设置容器为圆角
            padding=20, # 设置容器内边距
            # 容器的内容,一个 Column 控件
            content = ft.Column(controls= [ 
                # Column 控件的子元素,多个 Row
                # 把计算结果单独放在一行中
                ft.Row(controls=[result,]), 
                # 把 AC、+/-、%、/   这4个按钮,放在单独一行中
                ft.Row(controls=[
                        # 多个子控件,设置 expand 属性,每个控件expand 值的比例分配容器内的剩余空间
                        ft.ElevatedButton(text="AC", expand=1),
                        ft.ElevatedButton(text="+/-", expand=1),
                        ft.ElevatedButton(text="%", expand=1),
                        ft.ElevatedButton(text="/", expand=1),
                    ]
                ),
                # 如法炮制,把其他按钮也分组到各自单独的行中,如下:
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="7", expand=1),
                        ft.ElevatedButton(text="8", expand=1),
                        ft.ElevatedButton(text="9", expand=1),
                        ft.ElevatedButton(text="*", expand=1),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="4", expand=1),
                        ft.ElevatedButton(text="5", expand=1),
                        ft.ElevatedButton(text="6", expand=1),
                        ft.ElevatedButton(text="-", expand=1),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="1", expand=1),
                        ft.ElevatedButton(text="2", expand=1),
                        ft.ElevatedButton(text="3", expand=1),
                        ft.ElevatedButton(text="+", expand=1),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="0", expand=1),
                        ft.ElevatedButton(text=".", expand=1),
                        ft.ElevatedButton(text="=", expand=2), # 等号 = 的expand=2,放大一倍
                    ]
                ),
            ]
        )
    ))

ft.app(target=main)

按vscode的F5键,运行看效果如下:

循序渐进第四步:继续用控件的文本、颜色、背景色等属性,进一步美化。我们把 加减乘除等运算符,背景色设为黄色,把数字设置为暗灰色。

import flet as ft

def main(page: ft.Page):

    page.title = "我的计算器" # 定义标题
    page.window_height = 380 # 定义窗口尺寸
    page.window_width  = 450

    # 计算结果存在着“文本”控件中。color定义颜色,size定义文本大小
    result = ft.Text(value="0",color='#ffffff',size=20) 

    page.add(
        ft.Container( 
            bgcolor="#000000", # 容器背景色为黑色
            width= 400, # 容器的宽、高
            height= 300,
            border_radius= ft.border_radius.all(20), # 设置容器为圆角
            padding=20, # 设置容器内边距
            # 容器的内容,一个 Column 控件
            content = ft.Column(controls= [ 
                # Column 控件的子元素,多个 Row
                # 把计算结果单独放在一行中
                ft.Row(controls=[result,]), 
                # 把 AC、+/-、%、/ 这4个按钮,放在单独一行中
                ft.Row(controls=[
                        # 多个子控件,设置 expand 属性,每个控件expand 值的比例分配容器内的剩余空间
                        ft.ElevatedButton(text="AC", expand=1),
                        ft.ElevatedButton(text="+/-", expand=1),
                        ft.ElevatedButton(text="%", expand=1),
                        ft.ElevatedButton(text="/", expand=1, bgcolor="#ffcc00", color="#ffffff"),
                    ]
                ),
                # 如法炮制,把其他按钮也分组到各自单独的行中,如下:
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="7", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="8", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="9", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="*", expand=1, bgcolor="#ffcc00", color="#ffffff"),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="4", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="5", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="6", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="-", expand=1, bgcolor="#ffcc00", color="#ffffff"),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="1", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="2", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="3", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text="+", expand=1, bgcolor="#ffcc00", color="#ffffff"),
                    ]
                ),
                ft.Row(
                    controls=[
                        ft.ElevatedButton(text="0", expand=1, bgcolor="#999999", color="#ffffff"),
                        ft.ElevatedButton(text=".", expand=1, bgcolor="#999999", color="#ffffff"),
                        # 等号 = 的 expand=2,放大一倍
                        ft.ElevatedButton(text="=", expand=2, bgcolor="#ffcc00", color="#ffffff"), 
                    ]
                ),
            ]
        )
    ))

ft.app(target=main)

按vscode的F5键,运行看效果如下:

至此,计算器界面就算设计完毕了。还算漂亮吧?

不过有个问题:每个按钮,都在单独设置属性,而且代码重复多;那可否重用呢?当然可以。 下期我们分享如何“UI控件复用”,对“我的计算器”进行改造。

#python# #Flet #计算器# #界面设计#

相关推荐

python入门到脱坑函数—定义函数_如何定义函数python

Python函数定义:从入门到精通一、函数的基本概念函数是组织好的、可重复使用的代码块,用于执行特定任务。在Python中,函数可以提高代码的模块性和重复利用率。二、定义函数的基本语法def函数名(...

javascript函数的call、apply和bind的原理及作用详解

javascript函数的call、apply和bind本质是用来实现继承的,专业点说法就是改变函数体内部this的指向,当一个对象没有某个功能时,就可以用这3个来从有相关功能的对象里借用过来...

JS中 call()、apply()、bind() 的用法

其实是一个很简单的东西,认真看十分钟就从一脸懵B到完全理解!先看明白下面:例1obj.objAge;//17obj.myFun()//小张年龄undefined例2shows(...

Pandas每日函数学习之apply函数_apply函数python

apply函数是Pandas中的一个非常强大的工具,它允许你对DataFrame或Series中的数据应用一个函数,可以是自定义的函数,也可以是内置的函数。apply可以作用于DataF...

Win10搜索不习惯 换个设定就好了_window10搜索用不了怎么办

Windows10的搜索功能是真的方便,这点用惯了Windows10的小伙伴应该都知道,不过它有个小问题,就是Windows10虽然会自动联网搜索,但默认使用微软自家的Bing搜索引擎和Edge...

面试秘籍:call、bind、apply的区别,面试官为什么总爱问这三位?

引言你有没有发现,每次JavaScript面试,面试官总爱问你call、bind和apply的区别?好像这三个方法成了通关密码,掌握了它们,就能顺利过关。其实不难理解,面试官问这些问题,不...

记住这8招,帮你掌握“追拍“摄影技法—摄影早自习第422日

杨海英同学提问:请问叶梓老师,我练习追拍时,总也不能把运动的人物拍清晰,速度一般掌握在1/40-1/60,请问您如何把追拍拍的清晰?这跟不同的运动形式有关系吗?请您给讲讲要点,谢谢您!摄影:Damia...

[Sony] 有点残酷的测试A7RII PK FS7

都是好机!手中利器!主要是最近天天研究fs5,想知道fs5与a7rii后期匹配问题,苦等朋友的fs5月底到货,于是先拿手里现有的fs7小测一下,十九八九也能看到fs5的影子,另外也了解一下fs5k标配...

AndroidStudio_Android使用OkHttp发起Http请求

这个okHttp的使用,其实网络上有很多的案例的,但是,如果以前没用过,copy别人的直接用的话,可以发现要么导包导不进来,要么,人家给的代码也不完整,这里自己整理一下.1.引入OkHttp的jar...

ESL-通过事件控制FreeSWITCH_es事务控制

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

【调试】perf和火焰图_perf生成火焰图

简介perf是linux上的性能分析工具,perf可以对event进行统计得到event的发生次数,或者对event进行采样,得到每次event发生时的相关数据(cpu、进程id、运行栈等),利用这些...

文本检索控件也玩安卓?dtSearch Engine发布Android测试版

dtSearchEngineforLinux(原生64-bit/32-bitC++和JavaAPIs)和dtSearchEngineforWin&.NET(原生64-bi...

网站后台莫名增加N个管理员,记一次SQL注入攻击

网站没流量,但却经常被SQL注入光顾。最近,网站真的很奇怪,网站后台不光莫名多了很多“管理员”,所有的Wordpres插件还会被自动暂停,导致一些插件支持的页面,如WooCommerce无法正常访问、...

多元回归树分析Multivariate Regression Trees,MRT

多元回归树(MultivariateRegressionTrees,MRT)是单元回归树的拓展,是一种对一系列连续型变量递归划分成多个类群的聚类方法,是在决策树(decision-trees)基础...

JMETER性能测试_JMETER性能测试指标

jmeter为性能测试提供了一下特色:jmeter可以对测试静态资源(例如js、html等)以及动态资源(例如php、jsp、ajax等等)进行性能测试jmeter可以挖掘出系统最大能处...