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

网站推广建设期东莞教育团购网站建设

网站推广建设期,东莞教育团购网站建设,做运营常用的网站,小说网站排行榜前十名说在前面 rust新手,egui没啥找到啥教程,这里自己记录下学习过程环境:windows11 22H2rust版本:rustc 1.71.1egui版本:0.22.0eframe版本:0.22.0上一篇:这里 panel是啥 panel是ui上的一块区域&…

说在前面

  • rust新手,egui没啥找到啥教程,这里自己记录下学习过程
  • 环境:windows11 22H2
  • rust版本:rustc 1.71.1
  • egui版本:0.22.0
  • eframe版本:0.22.0
  • 上一篇:这里

panel是啥

  • panel是ui上的一块区域,比如我们打开CSDN的markdown编辑器,它大致上可以划分成四(五)块 (当然实际实现上这四块区域可能不是并列的) ,那我们就可以用四个panel来实现它:

    • 最顶层的文章标题
    • 次顶层的菜单栏
    • 左侧的编辑区域
    • 右侧的预览区域
      在这里插入图片描述
  • panel有点类似于html中的div元素,但是功能上没有div那么强 (初步感觉哈)

使用方式

  • 在前面几节中,我们已经初步了解了panel的基本使用,这里我们来看一个综合的使用用例

  • 假设我们要实现vscode的布局,应该怎样去实现呢?先来看下vscode的功能区,当然还有一个在最上面的菜单栏
    在这里插入图片描述

  • 现在我们来尝试实现一下 (可以直接在前面几节的template上进行)

    fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) {egui::TopBottomPanel::top("Menu Bar").show(ctx, |ui| {ui.vertical_centered(|ui|{ui.heading("Menu Bar");});});egui::TopBottomPanel::bottom("Status Bar").show(ctx, |ui| {ui.vertical_centered(|ui|{ui.heading("Status Bar");});});egui::SidePanel::left("Activity Bar").show(ctx, |ui| {ui.horizontal_centered(|ui|{ui.label("Activity Bar");});});egui::SidePanel::left("Side Bar").show(ctx, |ui| {ui.horizontal_centered(|ui|{ui.label("Side Bar");});});egui::TopBottomPanel::bottom("Panel").show(ctx, |ui| {ui.vertical_centered(|ui|{ui.heading("Panel");});});egui::CentralPanel::default().show(ctx, |ui|{ui.vertical_centered(|ui|{ui.heading("Editor");});});
    }
    

    结果为:
    在这里插入图片描述

  • 大致的区域划分是差不多的,但是各个区域的大小不太对,我们可以稍微调整下

    fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) {egui::TopBottomPanel::top("Menu Bar").show(ctx, |ui| {ui.vertical_centered(|ui| {ui.heading("Menu Bar");});});egui::TopBottomPanel::bottom("Status Bar").show(ctx, |ui| {ui.vertical_centered(|ui| {ui.heading("Status Bar");});});egui::SidePanel::left("Activity Bar").max_width(40.0).resizable(false).show(ctx, |ui| ui.add(egui::Label::new("Activity Bar")));egui::SidePanel::left("Side Bar").default_width(1000.0).width_range(200.0..=2000.0).resizable(true).show(ctx, |ui| {ui.text_edit_singleline(&mut "hi");});egui::TopBottomPanel::bottom("Panel").default_height(200.0).resizable(false).show(ctx, |ui| {ui.add(egui::TextEdit::multiline(&mut "Panel").desired_rows(10));});egui::CentralPanel::default().show(ctx, |ui| {ui.heading("Editor");});
    }
    

    其结果为:
    在这里插入图片描述

    代码上,除了定义panel的宽高外,还添加了一些text_edit;这是因为panel的实际宽高是和其内部的元素相关的
    比如一个SidePanel,如果其内部仅有一个label,即使你设置了resizable属性,它的宽度也没法动态变化

    pub fn resizable(self, resizable: bool) -> Self

    • Can panel be resized by dragging the edge of it?
    • Default is true.
    • If you want your panel to be resizable you also need a widget in it that takes up more space as you resize it

window decorations

  • 对比vscode我们可以看到还有一点小不同:
    在这里插入图片描述

  • vscode中的图标、菜单栏都是在一块的,而我们的demo app则是分成了两块

  • 如果我们想要和vscode一致应该怎样实现呢?

  • 首先将eframe的decorations去掉

    let mut native_options = eframe::NativeOptions::default();
    native_options.decorated = false;let ret = eframe::run_native("demo app",native_options,Box::new(|cc| Box::new(demo_app::TemplateApp::new(cc))),
    );
    
  • 然后需要自己实现整个frame,具体可以参考这里,相对比较麻烦,其效果如图:
    在这里插入图片描述

  • 感觉效果不太行,这里就不展开了

panel内部的区域划分

  • 在使用panel时,可能会遇到panel内部需要继续划分的情况,这个时候应该怎样处理呢?
    egui::SidePanel::left("Side Bar").default_width(1000.0).width_range(200.0..=2000.0).resizable(true).show(ctx, |ui| {egui::TopBottomPanel::bottom("AB bottom").show_inside(ui, |ui| {ui.label("bottom");});ui.text_edit_singleline(&mut "Side Bar");});
    
    使用show_inside方法即可
    在这里插入图片描述

参考

  • panel
http://www.yayakq.cn/news/341756/

相关文章:

  • 做时时网站要多少钱大学网站开发的流程图
  • 金乡网站建设公司文字转视频软件app
  • 中国建设工程监理协会网站中国建设银行网站口
  • 做网站前期预算科技感办公室设计
  • element ui做的网站人工智能培训机构哪个好
  • 目前热门的网站建设语言p2p借贷网站建设
  • 成都网站工作室中国建筑装饰网注册用户名
  • 彩票网站开发注意事情河北中保建设集团网站首页
  • 做淘宝客的网站怎么备案seo资源网
  • 模板网站和插件有哪些电商网站开发平台pi netwo
  • 陕西省建设监理协会证书查询网站wordpress归档
  • 大良建设网站东莞网站没计
  • 家用宽带怎么做网站 访问外贸大型门户网站制作
  • 房山网站建设优化seo如何自己创造游戏
  • 南头外贸网站建设济南百度爱采购
  • 枣庄网站建设价格h5网站如何做
  • 网站设计说明书范文网站建设与开发
  • 本地网站建设多少钱信息大全云原神官方网站正版下载
  • 加强对网站建设在百度上做个网站要多少钱
  • 县城网站怎么做破解wordpress的密码
  • 苍南做网站哪里找苏州吴中区建设局网站
  • 手机网站开发软件有哪些谷歌网站管理员账号
  • 网站设计论文结论机械设备网站建设
  • 有哪些网站可以免费做推广公司软件定制开发
  • 颐高养生园网站建设深圳网站建设做一个公司网站要多少钱
  • 做京东网站的摘要如何做网页或网站
  • 网站策划书市场分析取名字的网站 优帮云
  • 衡阳市网站建设全网霸屏整合营销推广
  • 传奇网站怎么做做网站怎么去进行链接
  • 网站备案空壳韶关新闻最新消息