Rust GUI学习 小部件系列(一):如何在iced窗口中使用颜色选择器colorpicker

注:此文适合于对rust有一些了解的朋友
iced是一个跨平台的GUI库,用于为rust语言程序构建UI界面。
在这里插入图片描述
前言:
本系列是iced的小部件应用介绍系列,主要介绍iced、iced_aw两个库中涉及的各种小部件的使用及实例演示。

本文所介绍的是color_picker,即颜色选择器,图示如下:
在这里插入图片描述
官方示例链接:https://github.com/iced-rs/iced_aw/tree/main/examples/color_picker

工具配置

平台:windows
代码:visual studio code
语言:rust
库:iced、iced_aw
相关插件:rust-analyzer、Even better TOML、crates

代码介绍

TOML配置:
[package]
name = "colorpick"
version = "0.1.0"
edition = "2021"# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html[dependencies]
iced="0.12.1"
iced_aw={version = "0.8.0",features = ["color_picker"]}
一、建立窗口

iced中有两个窗口的样式,一是sandbox,一是application,你可以理解sandbox是能快速使用的功能简单的窗口,而application是更全面的窗口类型。

ColorPickerExample::run(Settings::default())

iced中通常用run来启动一个窗口GUI,上面的代码可以放到main函数中:

fn main() -> iced::Result {let myfont="微软雅黑";let myicon=image_to_icon("../colorpick/image/icon1.png");//ColorPickerExample::run(Settings::default())ColorPickerExample::run(Settings{window:window::Settings{size:Size{width:800.0,height:600.0},position:window::Position::Specific(Point{x:100.0,y:40.0}),icon:Some(myicon),..window::Settings::default()},default_font:Font{family:font::Family::Name(myfont),..Font::DEFAULT},..Settings::default()})
}

上面的代码,是我们进行了修改,添加了自定义字体,使其能显示中文,另外为窗口添加了图标,还修改了窗口尺寸。窗口看起来如下:
在这里插入图片描述
其中,窗口图标是利用一个自定义函数image_to_icon从图片文件获得,函数如下:

///将图片转为icon
pub fn image_to_icon(file:&str)-> Icon{let img2=image::open(file);let img2_path=match  img2 {Ok(path)=>path,Err(error)=>panic!("error is {}",error),};let img2_file=img2_path.to_rgba8();let ico2=icon::from_rgba(img2_file.to_vec(), 500, 500);let ico2_file=match ico2{Ok(file)=>file,Err(error)=>panic!("error is {}",error),};ico2_file
}
二、color_picker的使用

color_picker是iced_aw库的一个feature,默认是关闭的,所以,我们需要在toml文件里启用它:

iced_aw={version = "0.8.0",features = ["color_picker"]}

由于iced中的部件显示都是在view函数中渲染的,所以我们在view中添加color_pick:

let color_picker = color_picker(state.show_picker,state.color,but,Message::CancelColor,Message::SubmitColor,);

color_pick的官方参数定义如下:

pub fn color_picker<'a, Message, Theme, F>(show_picker: bool,color: Color,underlay: impl Into<Element<'a, Message, Theme, iced::Renderer>>,on_cancel: Message,on_submit: F,
) -> crate::ColorPicker<'a, Message, Theme>
whereMessage: 'a + Clone,Theme: 'a+ crate::style::color_picker::StyleSheet+ iced::widget::button::StyleSheet+ iced::widget::text::StyleSheet,F: 'static + Fn(Color) -> Message,
{crate::ColorPicker::new(show_picker, color, underlay, on_cancel, on_submit)
}

第一个show_picker是一个状态量,如果为true则color_picker部件在窗口显示,如果为false,则隐藏。
第二个color,即当前选择的颜色值。
第三个underlay,指的是color_picker的底层元素,用以触发color_picker,可以是一个按钮部件,本例中即是一个按钮:

let but:Button<'_, Message> = Button::new(Text::new("选择颜色")).on_press(Message::ChooseColor);

当窗口初始化时,界面显示的就是按钮,点击按钮后触发消息,将show_picker设为True,则color_picker会显示。
第四个是on_cancel,用以取消颜色选择。
第五个是on_submit,用以确认颜色选择。
color_picker如下:
在这里插入图片描述
第四个和第五个可以绑定到Message中,这样一旦触发了按钮,则相应消息会传递给update函数,在update中处理数据:

   fn update(&mut self, message: Self::Message) -> Command<Message> {match self {ColorPickerExample::Loading => {if let Message::Loaded(_) = message {*self = ColorPickerExample::Loaded(State {color: Color::from_rgba(1.0, 1.0, 1.0, 1.0),show_picker: false,})}}ColorPickerExample::Loaded(state) => match message {Message::ChooseColor => {state.show_picker = true;}Message::SubmitColor(color) => {state.color = color;state.show_picker = false;}Message::CancelColor => {state.show_picker = false;}_ => {}},}Command::none()}

可以看到,当选择了取消,则color_picker隐藏,选择了确认,则返回颜色值,同时color_picker隐藏。
而颜色值被传递,更新到变量state.color中,因为state.color被绑定到text中,所以,当我们选择任何颜色后,其值都会被更新到窗口的文本上:
在这里插入图片描述
以上就是iced中color_picker这个小部件的使用,下面是实例演示:
在这里插入图片描述

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

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

相关文章

安捷伦Agilent E5071B网络分析仪

181/2461/8938产品概述&#xff1a; Agilent E5071B 网络分析仪可为射频组件提供快速、准确的测量。与同类网络分析仪相比&#xff0c;其宽动态范围和低迹线噪声可实现更高的测试质量和吞吐量。内置 2、3 和 4 个测试端口可同时测量具有最多四个端口的组件的所有信号路径。Agi…

中国土壤厚度空间分布数据

土壤层次分为覆盖层 林溶层 淀积层 母质层&#xff0c;其中在林溶层中的最上面那层就是我们通常说的土壤厚度在这一层中&#xff0c;这一层也被称为腐殖层&#xff0c;是肥力性质最好的一层&#xff0c;植物根系和微生物也集中在这一层。至于覆盖层在森林土壤中比较常见&#x…

2024年【G3锅炉水处理】考试题及G3锅炉水处理考试报名

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 G3锅炉水处理考试题参考答案及G3锅炉水处理考试试题解析是安全生产模拟考试一点通题库老师及G3锅炉水处理操作证已考过的学员汇总&#xff0c;相对有效帮助G3锅炉水处理考试报名学员顺利通过考试。 1、【多选题】锅筒…

vivado 在远程主机上启动作业、ISE命令图、实施类别,战略描述和指令映射

在远程主机上启动作业 一旦配置了远程主机&#xff0c;使用它们启动Vivado作业就很容易了。下图显示了启动运行对话框。启动跑步时&#xff0c;选择“在远程上启动跑步”hosts或Launch在群集上运行&#xff0c;然后选择特定的群集。这些作业将使用您的要执行的预配置设置。 作业…

Leetcode70. 爬楼梯(动态规划)

Leetcode原题 Leetcode70. 爬楼梯 标签 记忆化搜索 | 数学 | 动态规划 题目描述 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f;示例 1&#xff1a;输入&#xff1a;n 2 输出&#xff1a;2 解…

阿里云服务器安装MySQL(宝塔面板)

只写关键步骤 1. 创建一个云服务器实例 2 修改密码&#xff0c;登录服务器 3. 安装宝塔面板 进入https://www.bt.cn/new/index.html 进入宝塔面板地址 4. 安装Mysql 5. 创建数据库&#xff08;可导入数据库&#xff09; 6. 测试连接数据库 打开Navicat&#xff08;或其他数据…

centos安装jdk的坑

文章目录 一、安装jdk二、查找jdk的目录三、配置JAVA_HOME 一、安装jdk 我们一般用yum search java | grep jdk查询可以安装的jdk 但是一定要注意如下图&#xff0c;必须知道jdk和jre的区别 yum install java-1.8.0-openjdk-devel.x86_64二、查找jdk的目录 用如下命令 sudo…

chrome 浏览器报错 This page will not function without javascript enabled

This page will not function without javascript enabled. Please enable javascript on your browser. 在访问公司spark history 页面时&#xff0c;发现页面加载不全&#xff0c;并提示如上报错&#xff0c;因此按照如下步骤&#xff0c;已解决问题。 在浏览器中启用 JavaS…

OpenLayers6实战,OpenLayers绘制五角星,OpenLayers绘制特殊图形,地图上画五角星

专栏目录: OpenLayers实战进阶专栏目录 前言 本章讲解如何使用OpenLayers6在地图上绘制五角星这种特殊图形的功能。 本章上一章基础上修改而成:OpenLayers6实战,OpenLayers绘制特殊图形,OpenLayers绘制四角形(菱形),OpenLayers绘制菱形 二、依赖和使用 "ol&q…

【APP_TYC】数据采集案例天眼APP查_抓包分析_②

追寻啊 你身影千年 恳请宿命怜 无尽日夜 只为见你一面 我愿化作 窗外的桑花 朝朝暮暮 都有我牵挂 无论冬雪秋沙 海角天涯 缱绻不尽 念你啊 倘若化作 林间的桑花 借一暖风 赠你梦如画 纵使悲忧如雪 一笑融化 &#x1f3b5; Joysaaaa《朝朝如念》 抓包分析 …

.NET开源免费、功能强大的 Windows 截图录屏神器

前言 今天大姚给大家分享一款.NET开源免费&#xff08;基于GPL3.0开源协议&#xff09;、功能强大、简洁灵活的 Windows 截图、录屏、Gif动图制作神器&#xff1a;ShareX。 功能特性 ShareX 是一个开源的屏幕捕捉工具&#xff0c;具有丰富的功能特性&#xff0c;包括但不限于…

洗地机好用吗?哪款型号值得推荐?看完本文你就知道

在如今社会生活节奏不断加快的情况下&#xff0c;洗地机已经成为众多家庭的必备的清洁设备&#xff0c;面对市面上种类繁多的洗地机&#xff0c;我们常常会发出感叹“洗地机好用吗&#xff1f;洗地机哪个型好用&#xff1f;”等的疑问&#xff0c;今天&#xff0c;为了帮助大家…

vue2 export default写法,computed、methods的使用

<template><div><h2>{{nameAll}}</h2><h2>{{method}}</h2><h2>{{tt()}}</h2><h2>{{firstName}}</h2><h2>更新后赋值数据&#xff1a;{{lastName}}</h2><h2>赋值数据:{{writeValue}}</h2>…

el-select动态禁用

在一个el-form表单中有5个el-form-item; 每个el-form-item是一个el-select控件&#xff1b; 这5个el-select控件遵循这样的规则&#xff0c;都是使用同一个list集合&#xff0c;如果第一个el-select选择了list中的某一项&#xff0c;那么这一项就被禁用&#xff1b;其他的el-…

YOLOv9改进策略:注意力机制 | 二阶通道注意力机制(Second-order Channel Attention,SOCA),实现单图超分效果

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文改进内容&#xff1a;CVPR_2019 SOCA注意力&#xff0c;一种基于二阶通道注意力机制&#xff0c;能够单幅图像超分辨率&#xff0c;从原理角度分析能够在小目标检测领域实现大幅涨点效果&#xff01;&#xff01;&#xff01; &am…

2024年3月腾讯云最新活动及优惠券整理汇总

随着云计算的普及&#xff0c;腾讯云作为国内领先的云计算服务提供商&#xff0c;为用户提供了丰富的产品和服务。为了帮助用户更好地了解和使用腾讯云&#xff0c;本文将为大家整理汇总2024年3月腾讯云的最新活动及优惠券信息。 1、腾讯云最新活动入口【点此直达】 2、腾讯云…

2024/03/27(C++·day3)

一、思维导图 二、完成下面类 代码 #include <cstring> #include <iostream>using namespace std;class myString { private:char *str; // 记录C风格的字符串int size; // 记录字符串的实际长度public:// 无参构造函数myString() : size(10){str new char[si…

【Linux】进程状态(R运行状态、S睡眠状态、D磁盘休眠状态、T停止状态、X死亡状态)

目录 01.运行状态 02.睡眠状态 03.磁盘睡眠状态 04.停止状态 05.死亡状态 进程的状态会随着操作系统的调度和外部事件的发生而不断地发生转换。例如&#xff0c;一个新创建的进程经过初始化后会进入就绪态&#xff0c;等待被调度执行&#xff1b;当调度器分配处理器资源给…

git clone 后如何 checkout 到 remote branch

what/why 通常情况使用git clone github_repository_address下载下来的仓库使用git branch查看当前所有分支时只能看到master分支&#xff0c;但是想要切换到其他分支进行工作怎么办❓ 其实使用git clone下载的repository没那么简单&#x1f625;&#xff0c;clone得到的是仓库…