当前位置: 首页 > news >正文

<Rust>egui学习之小部件(三):如何为窗口UI元件设置布局(间隔、水平、垂直排列)?

前言
本专栏是关于Rust的GUI库egui的部件讲解及应用实例分析,主要讲解egui的源代码、部件属性、如何应用。

环境配置
系统:windows
平台:visual studio code
语言:rust
库:egui、eframe

概述
本文是本专栏的第三篇博文,主要说明如何对窗口的部件进行布局。

事实上,类似于iced,egui都提供了示例程序,本专栏的博文都是建立在官方示例程序以及源代码的基础上,进行的实例讲解。
即,本专栏的文章并非只是简单的翻译egui的官方示例与文档,而是针对于官方代码进行的实际使用,会在官方的代码上进行修改,包括解决一些问题。

系列博文链接:
1、<Rust>egui学习之小部件(一):如何在窗口及部件显示中文字符?
2、<Rust>egui学习之小部件(二):如何在egui窗口中添加按钮button以及标签label部件?

部件属性
设置间隔

我们已经知道了如何在窗口布置按钮、标签,但是我们想要按钮和标签在窗口的呈现是有设计的,比如它们之间有间隔,且可以水平或者垂直布局,如何实现呢?
egui提供了sapcing以及horizontal、vertical三种属性,我们一一来看一下。
首先我们添加几个按钮以及标签,但是没有任何布局,看一下窗口显示:
在这里插入图片描述
可以看到,默认情况的布局,这些部件都是垂直分布且挤在一起的。
现在,我们先让这些部件之间有一些间隙,使其看起来不那么局促:

ui.spacing_mut().item_spacing = egui::vec2(10.0, 30.0);

在这里插入图片描述
是不是一下子就清爽了不少,接着,我们为按钮设置布局,我们将按钮2和按钮3放在同一行:

ui.horizontal(|ui|{let btn_res2=ui.button("按钮2");if btn_res2.clicked(){ //println!("按钮2点击")self.lbltext="按钮2点击".to_string();}let btn_res3=ui.button("按钮3");if btn_res3.clicked(){ //println!("按钮3点击")self.lbltext="按钮3点击".to_string();}});

在这里插入图片描述
接下来,我们将文本1、文本2与上面的文本放到同一行,且文本1、文本2本身垂直分布:

ui.horizontal(|ui|{ui.label(format!("{}",self.lbltext));ui.vertical(|ui|{ui.label("文本1");ui.label("文本2");});});

在这里插入图片描述
我们可以看到,里面的布局是可以嵌套的。
那么,如果想要让horizontal或者vertical内部的部件之间的间隙改变的话,如何设置呢?
其实是一样,只要在其内部,添加spacing_mut即可:

  ui.horizontal(|ui|{ui.spacing_mut().item_spacing = egui::vec2(30.0, 60.0);ui.label(format!("{}",self.lbltext));ui.vertical(|ui|{ui.label("文本1");ui.label("文本2");});});

看一下实际显示:
在这里插入图片描述
当然,如果你说,我现在不想整体设置间隙,只是想在某个布局内部,设置某两个部件间的单独的间隙,如何设置呢?
可以使用add_space参数:

 ui.vertical(|ui|{ui.label("文本1");ui.add_space(30.0);ui.label("文本2");});

如上面的代码,将在这个垂直布局的两个文本之间,单独添加一个空间,值为30。

所以,我们可以结合spacing、horizontal以及vertical这三个属性,来调整布局,达到想要的效果。然后使用add_space这种来微调,当然,这种调整UI布局的方式,在涉及大量部件的时候,其实是不太方便的。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • python基础学习(最终篇)
  • 内存管理篇-17解开页表的神秘面纱-上
  • 定时器方案:时间表盘
  • Python实现蜂窝六边形的实现方法
  • 素材无水印素材网站在哪下载?高清的无水印素材资源库分享
  • AcWing 902. 最短编辑距离
  • VS Code 安装文档
  • MediaGo下载器:专业级功能,轻松应对各种下载需求!
  • 【Qt笔记】QTreeView控件详解
  • 独孤思维:打工,被老板压榨怎么办?
  • AWTK fscript 中的字符串扩展函数
  • CString类的用法以及例子
  • Java_ElasticSearch(ES)——分布式搜索引擎
  • jmeter 响应乱码
  • Django+Vue二手交易平台的设计与实现
  • Debian下无root权限使用Python访问Oracle
  • Django 博客开发教程 8 - 博客文章详情页
  • iOS仿今日头条、壁纸应用、筛选分类、三方微博、颜色填充等源码
  • Java应用性能调优
  • Nodejs和JavaWeb协助开发
  • python大佬养成计划----difflib模块
  • SegmentFault 2015 Top Rank
  • Service Worker
  • SQL 难点解决:记录的引用
  • Zepto.js源码学习之二
  • 测试如何在敏捷团队中工作?
  • 初探 Vue 生命周期和钩子函数
  • 浮动相关
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 算法---两个栈实现一个队列
  • 算法系列——算法入门之递归分而治之思想的实现
  • 在Mac OS X上安装 Ruby运行环境
  • 在weex里面使用chart图表
  • 终端用户监控:真实用户监控还是模拟监控?
  • nb
  • 《天龙八部3D》Unity技术方案揭秘
  • linux 淘宝开源监控工具tsar
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • ​云纳万物 · 数皆有言|2021 七牛云战略发布会启幕,邀您赴约
  • #565. 查找之大编号
  • #HarmonyOS:软件安装window和mac预览Hello World
  • (javascript)再说document.body.scrollTop的使用问题
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (附源码)计算机毕业设计ssm高校《大学语文》课程作业在线管理系统
  • (九)信息融合方式简介
  • (一)ClickHouse 中的 `MaterializedMySQL` 数据库引擎的使用方法、设置、特性和限制。
  • (一)Java算法:二分查找
  • (转)创业的注意事项
  • .mp4格式的视频为何不能通过video标签在chrome浏览器中播放?
  • .NET Core实战项目之CMS 第一章 入门篇-开篇及总体规划
  • .net 程序 换成 java,NET程序员如何转行为J2EE之java基础上(9)
  • .NET 发展历程
  • .net6 core Worker Service项目,使用Exchange Web Services (EWS) 分页获取电子邮件收件箱列表,邮件信息字段
  • .NET和.COM和.CN域名区别