rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(一)基本代码

Cargo.toml

[dependencies]
eframe = "0.32.1"
egui = "0.32.1"

‌启动函数一:run_simple_native

  • 简化版入口函数,适用于快速原型开发
  • 仅需提供应用标题和 UI 渲染闭包即可运行
  • 典型使用场景:单面板工具、简单演示程序
// 导入egui核心库和eframe框架(eframe是egui的本地窗口封装)
use eframe::egui;// 主函数返回Result类型以处理可能的错误
fn main() -> eframe::Result<()> {// 配置原生窗口参数let options = eframe::NativeOptions::default();eframe::run_simple_native("My egui App", options, move |ctx, _frame| {egui::CentralPanel::default().show(ctx, |ui| {ui.heading("Hello from egui 0.32.1!");           // 添加一级标题ui.label("This is a simple window in Ubuntu.");  // 添加普通文本标签});})
}

启动函数二:‌run_native

  • 完整功能入口,支持自定义应用生命周期管理
  • 需要实现eframe::App trait的结构体
  • 典型使用场景:复杂应用、需要持久化状态的项目
// 导入egui核心库和eframe框架(eframe是egui的本地窗口封装)
use eframe::egui;// 主函数返回Result类型以处理可能的错误
fn main() -> Result<(), eframe::Error> {let options = eframe::NativeOptions {   // 配置窗口的初始参数// 设置窗口初始大小为400x300像素viewport: egui::ViewportBuilder::default().with_inner_size([400.0, 300.0]),..Default::default()                // 其他参数保持默认值};// 启动原生窗口应用eframe::run_native("My egui App",                                // 窗口标题options,                                      // 传入配置选项Box::new(|_cc| Ok(Box::<MyApp>::default())),  // 创建应用实例的闭包,_cc包含创建上下文信息)
}// 定义应用的主要结构体
struct MyApp{}// 为MyApp实现Default trait以提供默认初始化
impl Default for MyApp {fn default() -> Self {Self                // 返回空结构体实例}
}// 为MyApp实现eframe::App trait定义应用行为
impl eframe::App for MyApp {// 每帧调用的更新函数fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) {egui::CentralPanel::default().show(ctx, |ui| {       // 创建中央面板(egui的主要布局组件)ui.heading("Hello from egui 0.32.1!");           // 添加一级标题ui.label("This is a simple window in Ubuntu.");  // 添加普通文本标签});}
}

选择建议

  1. 优先选择run_simple_native当:

    • 开发临时性工具
    • 无需复杂状态管理
    • 快速验证UI设计
  2. 必须使用run_native当:

    • 需要保存用户配置
    • 实现多窗口交互
    • 处理文件I/O等系统操作

两者底层均基于相同的egui渲染引擎,性能差异可以忽略。对于WebAssembly目标,对应存在run_simple_webrun_web变体。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/919908.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/919908.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

离线优先与冲突解决:ABP vNext + PWA 的边缘同步

&#x1f6f0;️ 离线优先与冲突解决&#xff1a;ABP vNext PWA 的边缘同步 &#x1f4da; 目录&#x1f6f0;️ 离线优先与冲突解决&#xff1a;ABP vNext PWA 的边缘同步0. 环境 &#x1f680;1. 场景与目标&#xff08;痛点→指标&#xff09;&#x1f3af;2. 架构与时序 …

Slither 审计自己写的智能合约

作为区块链开发者&#xff0c;写完合约之后最重要的一步就是 检查代码有没有漏洞。一旦部署到链上出了问题&#xff0c;不仅修复麻烦&#xff0c;还可能直接造成资金损失。 Slither 是一款非常好用的自动化审计工具&#xff0c;可以帮你快速找出大部分常见风险。这篇文章专门讲…

Python万里长征6(非教程)pandas筛选数据三基础、三核心、三高级

文章目录一、背景二、布尔索引2.1 总结三、进阶核心用法&#xff08;实用高效&#xff09;3.1 多条件组合3.2 字符串表达式&#xff08;类似SQL&#xff09;3.3 针对字符串的正则匹配四、高级方法&#xff08;依赖基础&#xff09;4.1 函数应用&#xff08;如apply()或lambda&a…

阿里云上部署nuxt开发的项目(SSG和SSR混合渲染)

1.项目说明及配置 // nuxt.config.ts export default defineNuxtConfig({// ... 其他配置// Nitro 引擎让你可以非常精细地为每个页面定义渲染策略nitro: {// 预设取决于你的部署平台,例如 vercel, netlify, static 等,或者node-serverpreset: vercel, // 这里以 Vercel 为例…

RWA加密金融高峰论坛星链品牌全球发布 —— 稳定币与Web3的香港新篇章

随着全球数字金融不断演进&#xff0c;稳定币&#xff08;Stablecoin&#xff09;与真实世界资产&#xff08;RWA&#xff09;已成为连接传统金融与Web3世界的核心通道。行业投研报告预计&#xff0c;RWA市场规模将在未来五年突破10万亿美元&#xff0c;而稳定币正加速进入跨境…

玩转Vue3高级特性:Teleport、Suspense与自定义渲染

玩转Vue3高级特性&#xff1a;Teleport、Suspense与自定义渲染 掌握Vue3革命性渲染特性&#xff0c;构建更灵活强大的前端应用 一、高级渲染特性全景概览 Vue3引入了三大革命性渲染特性&#xff0c;彻底改变了开发体验&#xff1a; 特性 解决的问题 典型应用场景 Teleport DOM结…

Qt/C++开发监控GB28181系统/录像文件回放/自动播放下一个录像文件/倍速回放/录像文件下载

一、前言说明 之前录像文件的回放功能已经是好的&#xff0c;后面用户提出来一个新的合理的需求&#xff0c;那就是播放完上一个录像文件&#xff0c;希望自动播放下一个文件&#xff0c;之前是播放完成后就关闭了&#xff0c;需要手动双击录像文件才会再次播放&#xff0c;这…

Kali Linux 发布重构版Vagrant镜像:通过命令行快速部署预配置DebOS虚拟机

Kali Linux团队宣布对其Vagrant镜像构建流程进行重大升级&#xff0c;通过改用DebOS系统替代原有的HashiCorp Packer工具&#xff0c;显著简化了预配置虚拟机的开发与部署流程。此次更新还附带实用速查表&#xff0c;帮助安全从业者快速上手。技术架构革新Vagrant box是可通过命…

关于链式二叉树的几道OJ题目

今天笔者带领读者做几道链式二叉树OJ题目&#xff0c;希望读者和笔者一起思考&#xff01; 1.965. 单值二叉树 - 力扣&#xff08;LeetCode&#xff09; 这道题思路不难想&#xff0c;首先知道单值二叉树的定义&#xff1a;所有结点的值都相同&#xff0c;传入的是第一个根节…

【ECharts】2. ECharts 性能优化

动态(按需)加载异步子组件 之前说过 ECharts 如何封装&#xff0c;今天来讲一讲 ECharts 如何做性能优化。 对于之前 ECharts 的封装子组件&#xff0c;我们可以使用 component 动态组件的方式进行渲染&#xff0c;并传参。 并且使用 import 动态导入搭配 defineAsyncCompon…

如何创建自己的 Minecraft 世界

步骤1&#xff1a;准备虚拟服务器运行以下命令来更新系统的软件包列表并应用所有待处理的升级&#xff1a;sudo apt update sudo apt upgrade -y您的系统已更新完毕&#xff0c;您已准备好进行下一步。第 2 步&#xff1a;安装依赖项并创建安全用户LinuxGSM 需要一些软件才能正…

vue中监听页面滚动位置

vue中监听页面滚动位置问题描述实现代码1. 获取页面被卷起的高度2. 监听滚动事件问题描述 页面滚动到指定位置时&#xff0c;展示侧边栏导航。 实现代码 1. 获取页面被卷起的高度 使用 e.target.scrollTop可以获取到页面向上滚动了多少像素&#xff0c;代码如下&#xff1a;…

docker:compose

docker三剑客&#xff1a;compose、swarm、machinemachine是在不同环境&#xff08;不同的操作系统平台上安装&#xff09;下部署docker的compose是做容器编排的swarm是做docker集群管理的Compose 简介口任务&#xff08; task &#xff09; &#xff1a; 一个容器被称为一个任…

GaussDB 数据库架构师修炼(十八) SQL引擎-计划管理-SQL PATCH

1 业务背景GaussDB的优化器生成计划不优的情况下&#xff0c;对DBA调优过程中不对业务sql修改场景下&#xff0c;提供3种计划管理&#xff0c;分别为plan hint,sql patch,spm。2 sql patch的使用场景在发现查询语句的执行计划、执行方式未达预期的场景下&#xff0c;可以通过创…

函数式编程从入门到精通

1.概述1.1为什么学&#xff1f;* 能够看懂公司里的代码 * 大数量下处理集合效率高 * 代码可读性高 * 消灭嵌套地狱//查询未成年作家评分在70分以上的书籍&#xff0c;由于流的影响所以作家和书籍可能会重复出现&#xff0c;所以要去重public void test1() {List<Book> bo…

Overleaf 中文报错和中文不显示问题的解决方案

Overleaf是一个很方便的在线latex编辑工具。但在最初使用Overleaf的时候&#xff0c;是不是有很多小伙伴会遇到模板中中文报错或者中文不显示的问题呢&#xff1f; 本文将带你一步步解决这个问题~ 中文报错 在点击重新编译按钮后&#xff0c;中文报错问题一般会有如下图红框显示…

前后端联调场景以及可能会遇到的问题

一、异地和在一起办公的方式 首先&#xff0c;在一起办公&#xff08;同局域网&#xff09;的情况&#xff0c;最常用的应该是直接使用后端的局域网 IP 进行联调&#xff0c;因为同一网络内设备可以直接通信。步骤方面&#xff0c;需要后端提供 IP 和端口&#xff0c;前端配置…

【T113自制板卡】1 - 原理图说明

文章目录1、前言2、板卡资源总览3、电源3.1、板卡供电3.2、电源方案4、OTG接口5、调试串口6、用户LED7、FLASH8、按键9、BLE MESH10、Wi-Fi11、MIC12、喇叭接口13、MIPI接口1、前言 这几天跟着小智学长的课程画了一块t113的板子。本文将描述该板卡的硬件说明。 2、板卡资源总…

WiFi有网络但是电脑连不上网是怎么回事?该怎么解决?

有时候&#xff0c;咱们用电脑上网&#xff0c;打开WiFi一看&#xff0c;信号满格&#xff0c;状态栏显示已连接&#xff0c;本来想着可以愉快地看个番、查个资料、玩个游戏了&#xff0c;结果一打开浏览器&#xff0c;直接完犊子了&#xff0c;网页都打不开。这时候再看状态&a…

【golang】制作linux环境+golang的Dockerfile | 如何下载golang镜像源

一、关于如何下载docker images 这里需要大家自行科学上网如果没有话&#xff0c;下面可以使用我自行打包的golang 的docker images 注意科学上网要开启TUN模式二、golang镜像源 1、阿里云公开镜像 如果找不到golang包的小伙伴可以使用我的公开阿里镜像docker pull registry.cn…