首页 > 其他分享 ><Rust>egui学习之小部件(九):如何在窗口中添加下拉列表combobox部件?

<Rust>egui学习之小部件(九):如何在窗口中添加下拉列表combobox部件?

时间:2024-09-06 12:52:34浏览次数:13  
标签:combobox egui selected 部件 ui new rect

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

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

概述
本文是本专栏的第九篇博文,主要讲述下拉列表部件combobox的使用。

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

系列博客链接:
1、<Rust>egui学习之小部件(一):如何在窗口及部件显示中文字符?
2、<Rust>egui学习之小部件(二):如何在egui窗口中添加按钮button以及标签label部件?
3、<Rust>egui学习之小部件(三):如何为窗口UI元件设置布局(间隔、水平、垂直排列)?
4、<Rust>egui学习之小部件(四):如何在窗口中添加滚动条Scroll部件?
5、<Rust>egui学习之小部件(五):如何在窗口中添加图像部件?
6、<Rust>egui学习之小部件(六):如何在窗口中添加菜单栏部件?
7、<Rust>egui学习之小部件(七):如何在窗口中添加颜色选择器colorpicker部件?
8、<Rust>egui学习之小部件(八):如何在窗口中添加滑动条slider部件?

部件属性

在egui中,下拉列表combobox部件提供下拉选项,其属性如下:

#[must_use = "You should call .show*"]
pub struct ComboBox {
    id_source: Id,
    label: Option<WidgetText>,
    selected_text: WidgetText,
    width: Option<f32>,
    height: Option<f32>,
    icon: Option<IconPainter>,
    wrap_mode: Option<TextWrapMode>,
}

事实上,下拉列表形式与菜单类似,都是点击后弹出一列元素。
我们来一下combobox的典型应用,我们以三种颜色红、黄、绿为选项:

 let id=egui::Id::new("color1");
            ComboBox::new(id,"颜色框")
                    //.icon(|ui,rect,visuals,is_open,above_or_below|setuifont::filled_triangle(ui, rect, visuals, is_open, above_or_below))
                    .selected_text(format!("{:?}",self.selected))
                    .show_ui(ui, |ui|{
                        ui.selectable_value(&mut self.selected, CC::红色,RichText::new("红色").background_color(Color32::RED));
                        ui.selectable_value(&mut self.selected, CC::绿色,RichText::new("绿色").background_color(Color32::GREEN));
                        ui.selectable_value(&mut self.selected, CC::黄色,RichText::new("黄色").background_color(Color32::YELLOW));
                    });

在这里插入图片描述
其中,文字的背景色是通过richtext元素来修改的,combobox本身不提供这些属性。
不过,我们可以修改下拉框右侧的图标,即三角形箭头,这实际上是一个绘制的矢量图形,我们可以通过icon属性来更改它:

 let id=egui::Id::new("color1");
            ComboBox::new(id,"颜色框")
                    .icon(|ui,rect,visuals,is_open,above_or_below|setuifont::filled_triangle(ui, rect, visuals, is_open, above_or_below))
                    .selected_text(format!("{:?}",self.selected))
                    .show_ui(ui, |ui|{
                        ui.selectable_value(&mut self.selected, CC::红色,RichText::new("红色").background_color(Color32::RED));
                        ui.selectable_value(&mut self.selected, CC::绿色,RichText::new("绿色").background_color(Color32::GREEN));
                        ui.selectable_value(&mut self.selected, CC::黄色,RichText::new("黄色").background_color(Color32::YELLOW));
                    });

注意,此处icon的参数是一个闭包,我们为其传入了一个函数,这个函数如下:

pub fn filled_triangle(
     ui: &egui::Ui,
     rect: egui::Rect,
     visuals: &egui::style::WidgetVisuals,
     _is_open: bool,
     _above_or_below: egui::AboveOrBelow,
 ) {
     let rect = egui::Rect::from_center_size(
         rect.center(),
            egui::vec2(rect.width() * 0.6, rect.height() * 0.4),
        );
     ui.painter().add(egui::Shape::convex_polygon(
         vec![
            rect.left_top(), 
         rect.right_top(), 
         rect.center_bottom(),
         //rect.left_bottom()
         ],
         visuals.fg_stroke.color,
            visuals.fg_stroke,
     ));
 }

上面的代码绘制出来的也是一个倒三角,但是我们可以修改其绘制路径:

 ui.painter().add(egui::Shape::convex_polygon(
         vec![
            rect.left_top(), 
         rect.right_top(), 
         rect.center_bottom(),
         rect.left_bottom()
         ],

加上一个点位,就变成了四边形:
在这里插入图片描述
combobox的参数里,我们注意到selected_text的参数是一个变量,即当我们选择不同的选项后,变量保存相应的值,对应本例中,即红色、黄色、绿色三种颜色。
而show_ui表示显示出下拉列表元素,显示的具体,则依据你写的代码来。
本例中下拉菜单中的三个元素便是如此添加的。

下拉列表部件提供了可选项,且可设置变量保存实时选择的值,这样我们就可以根据变量的值的不同来编写其他逻辑了。

标签:combobox,egui,selected,部件,ui,new,rect
From: https://blog.csdn.net/normer123456/article/details/141715250

相关文章

  • shadcn/ui Combobox command 组合筛选下拉
    <Popoveropen={open}onOpenChange={setOpen}><PopoverTriggerasChild><Buttonrole="combobox"aria-expanded={open}className="w-fulljustify-betweenh-11bg-back......
  • 27 Combobox组件
    Tkinterttk.Combobox组件使用指南ttk.Combobox是Tkinter的一个高级控件,它结合了文本框和下拉列表的功能,允许用户从预定义的选项列表中选择一个值。ttk模块是Tkinter的一个扩展,提供了更现代的控件外观和行为。以下是对ttk.Combobox组件的详细说明和一个使用案例。......
  • 图伸神经网络GCN实现图内点云分类任务(物体的部件分类)
    点云分类任务数据集下载关键代码数据集结构网络模型模型训练测试模型+可视化结果可能会出现的问题pyg没有配置好懒人专属(代码链接)本项目是一个简单的使用图中点分类代码,内涵完整的网络搭建、模型训练、模型保存、模型调用、可视化、的全过程。可以帮助初学者快速熟......
  • python环境配置问题-python+pysimpleGUI
    大家好,今天接到一个客户需求,帮忙配置pycharm后,代码需要可以正常运行用户需求如下:安装库:python环境/pysimpleGUI跑通代码:环境太复杂,需要清理环境后重新配置客户的项目先卸载那些冗余、冲突的Python版本 ,重新配置新环境代码跑通!总结一下客户项目并不复杂,只是自己......
  • StringGrid单元格绑定ComboBox、DateTimePicker或窗口传值
    一、初始化控件状态procedureTForm7.FormCreate(Sender:TObject);beginwithStringGrid1dobeginColWidths[0]:=15;Cells[1,0]:='Combobox';ColWidths[1]:=100;Cells[2,0]:='DateTimePicker';ColWidths[2]:=100;......
  • GridViewComboBoxColumn设置DataTypeConverter
    GridView中的GridViewComboBoxColumn列,如果需要使用TypeConverter将非字符串类型的数据源转换为字符串进行展示,可按如下几步进行:例如,数据源为如下枚举类型:publicenumMyColor{Red,Yellow,Green}展示的时候,需要转换为汉字,先定义如下类型,作为GridViewComboBo......
  • 检测 ttk 输入小部件的文本
    我想检测tkinterttk条目小部件的文本我尝试过:importtkinterastkfromtkinterimportttktk=tk.Tk()e1=ttk.Entry(tk)ife1=="good"print("good")几乎做到了!问题是正在将ttk.Entry对象本身与字符串“good”进行比较,而不是比较其内容。要访问......
  • ipywidgets 容器小部件中的 PIL 图像
    我有一些来自某个图书馆的PIL图像,并尝试了解它发生了什么。为此,我计算一些值,调用库并查找图片。我对计算值感兴趣。我使用带有一些滑块的jupyter笔记本与库进行交互。这是我的代码的一个非常简短的示例:fromPILimportImage,ImageDrawimportipywidgets......
  • 我无法使用 PySimpleGUI 打开第三个窗口
    我无法创建第三个窗口。代码工作没有错误,但它不显示代码结束的窗口当前我正在尝试使其显示一个复选框表,供人们选择座位。我测试过它是否根本没有运行。把print放在它后面,它就会打印出来。我也尝试让它显示简单的文本,但这也不起作用。下面是代码:layout3=[[sg.Text('Tes......
  • QComboBox列表设计
    我想自定义QComboBox列表背景。当我悬停时,我需要一个圆角框。我已附上当前图片和我需要的内容。这是我的样式表代码QComboBox{border:1pxsolidblack;background-color:white;font-size:15pt;padding:1px18px1px3px;}QComboBox:......