0

0

使用 Flet 刷新动态更新的图片

花韻仙語

花韻仙語

发布时间:2025-09-14 23:14:00

|

736人浏览过

|

来源于php中文网

原创

使用 flet 刷新动态更新的图片

本文将介绍在使用 Flet 框架开发应用时,如何实现动态更新图片的功能。当图片文件在操作系统层面被替换,但文件名保持不变时,传统的 page.update() 方法可能无法正确刷新图片显示。本文将提供一种解决方案,通过重新读取图片文件并将其转换为 base64 编码,从而强制 Flet 重新加载最新的图片内容,实现动态更新。

在 Flet 应用中动态更新图片,尤其是在图片内容由外部程序实时修改的情况下,可能会遇到一些挑战。当图片文件名保持不变,但图片内容被外部程序更新时,直接使用 ft.Image 组件和 page.update() 方法可能无法立即反映最新的图片内容。这是因为 Flet 可能会缓存图片,导致即使文件内容已更改,显示的仍然是旧版本。

以下是一种解决方案,通过重新读取图片文件并将其转换为 base64 编码,然后更新 ft.Image 组件的 src_base64 属性,从而强制 Flet 重新加载最新的图片内容。

示例代码:

import numpy as np
import base64
import flet as ft
from flet import Image
from io import BytesIO
from PIL import Image as image

def main(page: ft.Page):
    image_path = r"Python\\plate_0.jpg"  # 图片文件路径
    pil_photo = image.open(image_path)  # 使用 Pillow 打开图片
    arr = np.asarray(pil_photo)  # 将图片转换为 NumPy 数组
    pil_img = image.fromarray(arr)  # 从 NumPy 数组创建图片对象
    buff = BytesIO()  # 创建一个内存缓冲区
    pil_img.save(buff, format="JPEG")  # 将图片保存到缓冲区

    image_string = base64.b64encode(buff.getvalue()).decode('utf-8')  # 将缓冲区内容编码为 base64 字符串
    image1 = Image(src_base64=image_string)  # 创建 Image 组件,使用 base64 字符串作为源

    page.window_width = 375
    page.window_height = 300

    def updateTest(e):
        nonlocal image1 # allow to modify image1
        image_path = r"Python\\plate_0.jpg"  # 重新读取图片文件路径

        pil_photo = image.open(image_path)  # 重新打开图片
        arr = np.asarray(pil_photo)
        pil_img = image.fromarray(arr)
        buff = BytesIO()
        pil_img.save(buff, format="JPEG")

        newstring = base64.b64encode(buff.getvalue()).decode("utf-8")  # 重新编码为 base64 字符串
        image1.src_base64 = newstring  # 更新 Image 组件的 src_base64 属性

        image1.update()  # 更新 Image 组件

    page.add(
        ft.Row(controls=[image1], alignment='center'),
        ft.Row(controls=[ft.TextButton("Test", on_click=updateTest)], alignment='center')
    )

ft.app(target=main)

代码解释:

网奇.NET网络商城系统
网奇.NET网络商城系统

系统优势: 1、 使用全新ASP.Net+c#和三层结构开发. 2、 可生成各类静态页面(html,htm,shtm,shtml和.aspx) 3、 管理后台风格模板自由选择,界面精美 4、 风格模板每月更新多套,还可按需定制 5、 独具的缓存技术加快网页浏览速度 6、 智能销售统计,图表分析 7、 集成国内各大统计系统 8、 多国语言支持,内置简体繁体和英语 9、 UTF-8编码,可使用于全球

下载
  1. 导入必要的库: 导入 numpy, base64, flet, io, 和 PIL 库。
  2. 读取图片并转换为 base64:
    • 使用 PIL.Image.open() 打开图片文件。
    • 使用 numpy.asarray() 将图片转换为 NumPy 数组。
    • 使用 PIL.Image.fromarray() 从 NumPy 数组创建图片对象。
    • 使用 io.BytesIO() 创建一个内存缓冲区。
    • 使用 pil_img.save() 将图片保存到缓冲区,指定格式为 "JPEG"。
    • 使用 base64.b64encode() 将缓冲区内容编码为 base64 字符串,并使用 decode('utf-8') 解码为 UTF-8 字符串。
  3. 创建 ft.Image 组件: 使用 base64 字符串作为 src_base64 属性的值,创建一个 ft.Image 组件。
  4. 定义更新图片的函数 updateTest():
    • 在该函数中,重新执行步骤 2,读取最新的图片文件并转换为 base64 字符串。
    • 更新 ft.Image 组件的 src_base64 属性为新的 base64 字符串。
    • 调用 image1.update() 方法,更新 ft.Image 组件,使其显示最新的图片内容。
  5. 添加组件到页面: 将 ft.Image 组件和一个 ft.TextButton 组件添加到页面上。点击按钮时,会调用 updateTest() 函数,更新图片。

注意事项:

  • 确保安装了必要的库:pip install flet Pillow numpy。
  • 将 image_path 变量设置为实际的图片文件路径。
  • 这种方法每次更新图片都需要重新读取文件和编码,可能会影响性能。如果需要频繁更新图片,可以考虑使用其他方法,例如使用 ft.ImageProvider 或使用网络流。
  • 确保图片文件格式是 PIL 支持的格式。
  • 在 updateTest 函数中,需要重新声明 image_path 变量,以确保每次都读取最新的文件。

总结:

通过将图片文件转换为 base64 编码,并更新 ft.Image 组件的 src_base64 属性,可以实现动态更新图片的功能,即使图片文件名保持不变。这种方法简单易懂,适用于大多数场景。但是,需要注意性能问题,并根据实际情况选择合适的更新策略。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

339

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

411

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

756

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

345

2025.07.23

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

621

2023.11.24

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 11.6万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号