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

基于深度学习的视觉检测小项目(十二) 使用线条边框和渐变颜色美化界面

         到目前为止,已经建立起了基本的项目架构,样式表体系也初步具备,但是与成品的界面相比,还是差点什么。

我的界面效果图:

优秀demo的界面截图:

是的,我的界面太“平” 了,没有立体感,没有质感。

放大后的局部:

可以看到,专业的ui界面,大量使用了修饰线条和颜色渐变。

所以,这期了解一下修饰线条和颜色渐变的应用。

渐变的基础知识:Qt 的线性渐变的类QLinearGradient 学习笔记-CSDN博客,以及

Qt 的径向渐变的类QRadialGradient 学习笔记-CSDN博客

• 画面中不同的部件的交界处可以使用两条高反差的线来产生立体感

#form_top {border-bottom: 4px solid #000000;	background-color: #1c1c1c;
}
#form_top QLabel{color:#b6b6b6;
}
#form_main{border-top: 1px solid #464646;	background-color: #282828;
}

        上面的样式表设置中,顶部方框(form_top)的下边(border_bottom)用了#000000的黑色线条,而下部的form_main用了#464646的对比色作为上边(border_top),这样就在分界处产生了立体感。

显示效果:

• 使用渐变的方法来定义部件的分界线以及背景色,产生局部的立体感

以按钮为例:

将按钮的样式表定义为:

QPushButton{
border: 3px solid #000000;	
color:#adadad;
border-top: 4px solid qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #000000, stop: 1 #454545);background-color: qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #2d2d2d, stop: 1 #000000);}

 效果图:

        根据需要做出部件在各种激发状态下的显示设置:

        将部件的伪状态、自定义特性等激发条件与边框、渐变结合起来,就可以做出各种需要的显示效果:

QPushButton{
border: 3px solid #000000;	
color:#cdcdcd;
border-top: 4px solid qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #000000, stop: 1 #454545);
background-color: qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #2d2d2d, stop: 1 #000000);
}QPushButton:hover{
color:#dddddd;
background-color: qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #3d3d3d, stop: 1 #101010);
}QPushButton:pressed{
border-top: 3px solid #0d0d0d;
border-left: 3px solid #0d0d0d;
border-right: 3px solid #303030;
border-bottom: 3px solid #303030;
background-color: qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #3d3d3d, stop: 1 #101010);
}#form_top {border-bottom: 4px solid #000000;	background-color: #1c1c1c;
}#form_top QLabel{color:#b6b6b6;
}#form_main{border-top: 1px solid #464646;	background-color: #282828;
}#btn_datas{background-color: qlineargradient(x1: 1, y1: 0, x2: 1, y2: 1, stop: 0 #008bd3, stop: 1 #003e60);
}

        由于能够找到的范例并不多,以上只是我作为一个业余编程爱好者的一些粗鄙探索,也算是抛砖引玉,期望与各位同学多多交流。


http://www.mrgr.cn/news/83644.html

相关文章:

  • 数据仓库: 10- 新技术与趋势
  • 51单片机 和 STM32 的烧录方式和通信协议的区别
  • Cesium加载地形
  • vue2修改表单只提交被修改的数据的字段传给后端接口
  • AAAI2020 | Ghost | 通过幽灵网络学习可迁移的对抗样本
  • IntelliJ IDEA和MAVEN基本操作:项目和缓存存储到非C盘
  • pytest+request+yaml+allure搭建低编码调试门槛的接口自动化框架
  • 指针的进阶
  • 蓝耘:GPU算力云服务的技术探索与AIGC应用支持
  • 渗透Vulnhub-hackme靶机
  • Windows 11更新之后卡顿 (黑神话掉帧严重)问题探索
  • 聊聊AI Agent
  • windows及linux 安装 Yarn 4.x 版本
  • Linux的基础IO
  • SpringBoot之LazyInitializationBeanFactoryPostProcessor类源码学习
  • 金融项目实战 04|JMeter实现自动化脚本接口测试及持续集成
  • LLMBook 大模型数据集下载地址完整收集
  • Github配置ssh key,密钥配对错误怎么解决?
  • Open FPV VTX开源之第一次出图
  • Day05-后端Web基础——TomcatServletHTTP协议SpringBootWeb入门
  • 【AIDD药物研发】张载熙-生成式AI4药物发现
  • 《自动驾驶与机器人中的SLAM技术》ch8:基于 IESKF 的紧耦合 LIO 系统
  • 知识图谱抽取分析中,如何做好实体对齐?
  • Java List去重:Stream、HashMap与TreeSet对比分析
  • 初识Java3
  • 前端验证码实现