rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(二十四)窗口颜色、透明度、居中显示

一、窗口颜色和透明度

(一)效果预览

(二)透明窗体主要代码

rust 复制代码
use eframe::egui; 
use egui::Color32;

fn main() -> eframe::Result<()> {
    let options = eframe::NativeOptions {
        viewport: egui::ViewportBuilder::default() // 创建视口构建器来配置窗口
            .with_inner_size([600., 500.])   // 设置窗口初始内部尺寸为600x500像素
            .with_transparent(true),         // 允许窗口背景透明
        centered: true,                      // 窗口启动时在屏幕上居中显示
        ..Default::default()                 // 使用其他默认选项
    };

    eframe::run_simple_native("窗体颜色和透明度", options, move |ctx, _frame| {
           ctx.set_visuals(egui::Visuals {
                // 设置面板填充颜色为半透明色,颜色由RGB值和透明度决定
                panel_fill: Color32::from_rgba_premultiplied(
                    25,                   // 红色分量(0-255)
                    0,                    // 绿色分量(0-255)
                    55,                   // 蓝色分量(0-255)
                    76,                   // 透明度分量(0-255)
                ),
                // 保留其他视觉样式的默认设置
                ..ctx.style().visuals.clone()
            });
        egui::CentralPanel::default().show(ctx, |ui| {
            load_fonts(ctx);        // 自定义的设置中文字体函数
            ui.label("窗体内容............");
        });
    })
}

二、程序中随意调整窗口颜色和透明度

(一)效果预览

(二)控制窗口颜色和透明度的主要代码

rust 复制代码
use eframe::egui; 
use egui::Color32;

fn main() -> eframe::Result<()> {
    let options = eframe::NativeOptions {
        viewport: egui::ViewportBuilder::default() // 创建视口构建器来配置窗口
            .with_inner_size([600., 500.])         // 设置窗口初始内部尺寸为500x500像素
            .with_transparent(true),               // 允许窗口背景透明
        centered: true,                            // 窗口启动时在屏幕上居中显示
        ..Default::default()                       // 使用其他默认选项
    };

    let mut opacity = 0.3;   // 控制窗口透明度
    let mut r = 25;          // 控制红色分量
    let mut g = 0;           // 控制绿色分量
    let mut b = 55;          // 控制蓝色分量
    
    eframe::run_simple_native("窗体颜色和透明度", options, move |ctx, _frame| {
           ctx.set_visuals(egui::Visuals {
                // 设置面板填充颜色为半透明色,颜色由RGB值和透明度决定
                panel_fill: Color32::from_rgba_premultiplied(
                    r,                       // 红色分量
                    g,                       // 绿色分量
                    b,                       // 蓝色分量
                    (opacity * 255.0) as u8, // 透明度分量(将0-1范围转换为0-255范围)
                ),
                // 保留其他视觉样式的默认设置
                ..ctx.style().visuals.clone()
            });
            
        egui::CentralPanel::default().show(ctx, |ui| {
            load_fonts(ctx);      // 自定义加载字体函数
            ui.add(egui::Slider::new(&mut opacity, 0.0..=1.0).text("透明度"));
            ui.add(egui::Slider::new(&mut r, 0..=255).text("红色"));
            ui.add(egui::Slider::new(&mut g, 0..=255).text("绿色"));
            ui.add(egui::Slider::new(&mut b, 0..=255).text("蓝色"));
            ui.label(format!("当前颜色: ({}, {}, {})", r, g, b));
        });
    })
}
相关推荐
蒙奇D索大10 分钟前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
洛白白26 分钟前
“职场心态与心穷
经验分享·学习·生活·学习方法
微小冷1 小时前
Rust图形界面教程:egui基础组件的使用
后端·rust·gui·egui·button·panel·用户图形界面
_dindong1 小时前
笔试强训:Week-4
数据结构·c++·笔记·学习·算法·哈希算法·散列表
星释2 小时前
Rust 练习册 :Nucleotide Codons与生物信息学
开发语言·算法·rust
BeingACoder2 小时前
【SAA】SpringAI Alibaba学习笔记(二):提示词Prompt
java·人工智能·spring boot·笔记·prompt·saa·springai
-大头.2 小时前
Rust高级类型与零成本抽象实战
stm32·单片机·rust
Acrelhuang2 小时前
覆盖全场景需求:Acrel-1000 变电站综合自动化系统的技术亮点与应用
大数据·网络·人工智能·笔记·物联网
DKPT2 小时前
如何设置JVM参数避开直接内存溢出的坑?
java·开发语言·jvm·笔记·学习
一 乐2 小时前
智慧党建|党务学习|基于SprinBoot+vue的智慧党建学习平台(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·学习