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));
        });
    })
}
相关推荐
云边散步42 分钟前
godot2D游戏教程系列二(4)
笔记·学习·游戏开发
BORN(^-^)1 小时前
《产品经理方法论》阅读笔记
笔记·产品经理
jrlong1 小时前
DataWhale大模型基础与量化微调task4学习笔记(第 2 章:高级微调技术_RLHF 技术详解)
笔记·学习
Darkershadow1 小时前
蓝牙学习之Time Set
python·学习·蓝牙·ble·mesh
傻小胖1 小时前
13.BTC-思考-北大肖臻老师客堂笔记
笔记·区块链
好奇龙猫1 小时前
【日语学习-日语知识点小记-日本語体系構造-JLPT-N2前期阶段-第一阶段(9):単語文法】
学习
咸甜适中1 小时前
rust的docx-rs库,自定义docx模版批量生成docx文档(逐行注释)
开发语言·rust·docx·docx-rs
AI浩2 小时前
约束模型下的目标检测置信学习
学习·目标检测·目标跟踪
m0_748229992 小时前
ThinkPHP快速入门:从零到实战
c语言·开发语言·数据库·学习
風清掦2 小时前
【江科大STM32学习笔记-04】0.96寸OLED显示屏
笔记·stm32·学习