LiteIDE主题定制教程【续】

news2024/11/24 13:41:33

摘要:本篇文章是LiteIDE主题定制教程的续作,之所以会有这篇续作,是因为在写完那篇文章之后,我在使用过程中陆续发现了一些问题,以及一些可以优化的地方,我将这些内容作为补充放到这篇文章里。所有更新都已同步到Github,可以直接食用。

下面正片开始。

下拉工具栏按钮

工具栏上的按钮除了普通按钮,还有两种特殊的下拉按钮,点击之后会弹出一个菜单。

第一种是popupMode="1"的下拉按钮,按钮本身是可点击的,有独立功能,旁边还有一个小三角,点击三角会弹出菜单,如下图所示的三个按钮就是这种类型。

第二种是popupMode="2"的下拉按钮,在按钮的右下角有一个小三角,点击按钮本身就是弹出菜单,它没有独立的功能,如下图所示的三个按钮就是这种类型。

在之前的定制中由于去掉了边框,所以第一类下拉按钮的下拉箭头的按钮本身会重叠在一起,如下图所示。

现在让我们来修复这个问题,首先将第一种下拉按钮和它的下拉箭头分开。

/* 下拉工具按钮 */
QToolButton[popupMode="1"] {
    background-color: transparent;
    padding-right: 8px;
}

然后去掉下拉箭头的边框和背景,并在菜单展开的时候让下拉箭头下移一点。

QToolButton::menu-button {
    background-color: transparent;
    border: none;
}
/* 下拉菜单展开的状态 */
QToolButton::menu-arrow:open {
    top: 1px;
}

对于第二种下拉按钮,它的下拉箭头没什么显示的必要,我们直接让它消失就好了。

QToolButton::menu-indicator {
    width: 0;
    height: 0;
}

完成以后如下图所示。

智能提示

智能提示在之前的教程中并未提及,实际上,智能提示的弹出框也是QListView,因此不要将QListView的背景色设置为透明,否则智能提示就会变成一块黑色区域。我就曾犯过这个错误,导致智能提示变成黑乎乎一片,好在我及时找到了问题的原因,并修复了这个问题。同时我们还可以通过QAbstractItemView控制智能提示中选中项的颜色,这个可以根据自己的喜好设置,如下所示。

QAbstractItemView {
    selection-background-color: qlineargradient(x1: 0, y1: 0, x2: 1, y2: 0, 
      stop: 0 #426ab3, stop: 1 transparent); /* 选中项背景色 */
    /* selection-color: #00BFFF; /* 选中项文字颜色 */
}

效果如下图。
在这里插入图片描述

隐藏菜单栏

LiteIDE并没有提供可以隐藏和显示菜单栏的选项,不过我们可以通过qss来隐藏菜单栏。

QMenuBar {
    height: 0;
}

这种隐藏方式比较麻烦的一点是当你需要显示菜单栏时需要去修改主题文件,所以根据自己的需求设置吧,如果你平时可以不用菜单栏,又觉得它碍事,那么可以用这种方式将它隐藏起来。

标签关闭按钮

代码编辑器的标签控件上有个关闭按钮,上回我们把它设计成了小圆点,并伴随一个鼠标碰触放大的效果。但是不管是活动标签还是非活动标签,它的关闭按钮都是一个样子,还不够极致,既然标签本身做了活动和非活动的区分,那么关闭按钮也可以做。

在之前的教程中,我们只设置了关闭按钮的正常状态和鼠标悬停状态,现在我们将这两种状态分别进一步细分为活动状态和非活动状态,一共四种状态。

首先我们将活动状态标签的关闭按钮设置成红色小圆点,将非活动状态标签的关闭按钮设置成灰色小圆点。

/* 标签控件:关闭按钮:非活动状态 */
QTabBar::close-button:!selected {
    background-color: #B5B5B5;      /* 背景色:灰色 */
    border: 10px solid transparent; /* 加粗边框让显示区域缩小 */
    border-radius: 8px;             /* 设置圆角 */
}
/* 标签控件:关闭按钮:活动状态 */
QTabBar::close-button:selected {
    background-color: #FA8072;      /* 背景色:红色 */
    border: 10px solid transparent; /* 加粗边框让显示区域缩小 */
    border-radius: 8px;
}

然后,在鼠标悬停的时候,将他们放大,并设置一个更深一点的颜色。

/* 标签控件:关闭按钮:鼠标悬停:活动标签 */
QTabBar::close-button:hover:selected {
    background-color: #f15b6c;
    border: 8px solid transparent; /* 将边框变细实现按钮放大效果 */
    border-radius: 8px;
}
/* 标签控件:关闭按钮:鼠标悬停:非活动标签 */
QTabBar::close-button:hover:!selected {
    background-color: #74787c;
    border: 8px solid transparent; /* 将边框变细实现按钮放大效果 */
    border-radius: 8px;
}

注意,以上关闭按钮的正常状态和鼠标悬停状态的顺序一定不要搞反。没错,我说的就是书写顺序。否则,活动标签的关闭按钮就没有鼠标悬停效果了。而对于标签本身,我们不希望选中的标签还有悬停效果,所以将hover放在了selected的前面。有时候发现效果与你预想的不符时,可以试着调一调顺序,嘻嘻。

上下分别是调整前后的图,对比下效果。

让按钮和文字跳动起来

在开始之前我们需要先了解下盒子模型,它是 一个经典的UI模型,如下图所示。

在这里插入图片描述

基本原理就是通过设置上下的padding改变内容的相对位置,通过设置上下的margin改变整体的相对位置。比如正常时我们设置按钮的margin-top为2px,鼠标进入时,margin-top恢复为0,margin-bottom设置为2px,那么按钮就会有一个上跳的效果。

QPushButton {
    background-color: #e7e7e7; /* 背景色 */
    border: none;              /* 无边框 */
    border-radius: 8px;        /* 设置圆角 */
    padding: 1px 4px 1px 4px;  /* 填充:上右下左 */
    min-width: 50px;           /* 最小宽度 */
    min-height: 16px;          /* 最小高度 */
    margin: 2px 0 0 0;         /* 下移 */
}
/* 按钮:鼠标悬停 */
QPushButton:hover {
    background-color: #d0d0d0;
    color: #00BFFF;
    margin: 0 0 2px 0; /* 上移 */
}
/* 按钮:按下 */
QPushButton:pressed {
    background-color: #C6E2FF;
    color: #464547;
    margin: 2px 0 0 0; /* 下移 */
}

对工具栏按钮,可以同样设置,之前的教程中是做了一个鼠标进入缩小的效果,我们可以改为上跳。

QToolButton {
    background: transparent;
    border: 2px solid transparent; /* 透明边框 */
    margin: 1px;    /* 边距 */
    color: #74787c; /* 文字颜色 */
    height: 10px;   /* 按钮高度 */
    border-radius: 6px; /* 圆角 */
    margin: 2px 0 0 0;  /* 下移 */
}
/* 工具按钮:鼠标悬停 */
QToolButton:hover {
    color: #00BFFF;
    /*border: none;    去掉边框,实现放大效果 */
    margin: 0 0 2px 0; /* 上移 */
}
/* 工具按钮:鼠标按下 */
QToolButton:pressed {
    background-color: none;
    /* border: none; */
    margin: 2px 0 0 0;  /* 下移 */
}

效果如下。

在这里插入图片描述


本期内容就到这里,生命不息,折腾不止。

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

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

相关文章

<Linux系统复习>文件系统的理解

一、本章重点 1、磁盘的物理结构 2、磁盘文件如何存储? 3、目录的理解 4、创建一个文件做了什么? 5、删除一个文件做了什么? 6、软连接 7、硬链接 01 磁盘的物理结构 磁盘是硬件结构唯一的机械设备,它通过磁头来进行磁盘的读写&am…

LabVIEW前面板上的字体大小取决于操作系统

LabVIEW前面板上的字体大小取决于操作系统 创建了一个VI,其前面板使用了多个标签和文本。我发现Windows 7系统上的字体大小与Windows 10系统上的字体大小不同。这导致我的前面板看起来不像我希望在计算机上看到的那模样。如何使字体在所有Windows操作系统上变得相同…

【Linux_】权限

【Linux_】权限 心有所向,日复一日,必有精进专栏:《Linux_》作者:沂沐沐目录 【Linux_】权限 前言 Linux权限的概念(是什么)? 什么是权限? Linux权限管理 文件访问者的分类&am…

npm包学习

想开发自己的的工具包,那必然要借鉴一些常用的npm包来帮我们解决一些问题,下面就罗列一些在学习vue-cli实现原理时候遇到的一些依赖包吧。 1、chalk 用途:可以修改终端输出字符的颜色,类似css的color属性,npm地址&am…

100天精通Python(数据分析篇)——第62天:pandas常用统计方法与案例

文章目录每篇前言一、常用统计方法与案例1. 求和(sum)2. 求平均值(mean)3. 求最小值(min)4. 求最大值(max)5. 求中位数(median)6. 求众数(mode&am…

jQuery网页开发案例:jQuery 其他方法--jQuery 拷贝对象,多库共存,jQuery 插件

jQuery 对象拷贝 如果想要把某个对象拷贝(合并) 给另外一个对象使用,此时可以使用 $.extend() 方法 语法: $.extend([deep], target, object1, [objectN]) 1. deep: 如果设为true 为深拷贝, 默认为false 浅拷贝 …

做减法才是真本事,别以为你很能学,做加法一点都不难

文章目录 顶级的高手才敢做减法 前言 一、做减法才是真本事 二、大数据梦想联盟活动开启 顶级的高手才敢做减法 前言 大多数人不懂,不会,不做,才是你的机会,你得行动,不能畏首畏尾 大数据等于趋势,一…

Vue中computed和watch区别

前言 vue中的computed和watch我们经常会用到,那么在什么场景下使用computed和watch,两者又有什么区别呢,傻傻分不清楚。记录一下,温故而知新! computed computed是计算属性,基于data中声明过或者父组件传递…

makkefile文件自动化编译以及基础文件命令(补)

目录makefile文件:实现自动化编译基础文件命令find(查找)grep(过滤)| (管道)关机重启文件压缩解压分步压缩解压一步压缩解压makefile文件:实现自动化编译 文件名称必须是:makefile …

【day15】每日强训编程题——查找输入整数二进制中1的个数手套

查找输入整数二进制中1的个数_牛客题霸_牛客网 这道题非常简单,就一个思路: 按位与& 任何一个数按位与上1,如果这个数二进制的最后一位是1,那么按位与的结果就是1,否则就是0 代码思路:n按位与1后往右…

【splishsplash】PBD探究

上次我们探究了PBD是如何引入plishsplash的,以及其控制流。 https://blog.csdn.net/weixin_43940314/article/details/127569870 这次我们来讲如何在自己新建的类中控制PBD刚体。 上回说到 Simulator\PositionBasedDynamicsWrapper\PBDWrapper.cpp 中的 void PBD…

AXI协议详解(6)-原子访问

原子访问 本章介绍了 AXI 协议如何实现排他访问和锁定访问机制。 它包含以下部分: 原子访问排他访问锁定访问 6.1 原子访问 为了实现原子访问权限,ARLOCK[1:0] 或 AWLOCK[1:0] 信号提供排他访问和锁定访问。 表 6-1 显示了 ARLOCK[1:0] 和 AWLOCK[1:…

3.NLP基础:文本可视化简述

1.文本可视化的流程 文本可视化依赖于自然语言处理,因此词袋模型、命名实体识别、关键词抽取、主题分析、情感分析等是较常用的文本分析技术。文本分析的过程主要包括特征提取,通过分词、抽取、归一化等操作提取出文本词汇级的内容,利用特征…

Qt 集成 FFmpeg 实现颜色格式转换

目录 1. Qt 集成 FFmpeg 1.1 下载 FFmpeg 1.2 Qt 集成 FFmpeg 1.2.1 修改 .pro 文件 1.2.2 放入 dll 文件 1.2.3 代码中使用 FFmpeg 2. 图像格式转换 3. 预览 4. 项目地址 项目需要,写个小工具来实现图像颜色格式的转换,主要的 Feature 如下&am…

百度最强中文AI作画大模型

前言 最近文生图领域的发展可谓是分生水起,这主要是得益于最近大火的扩散模型,之前笔者也写过一篇关于文本生产3D模型的文章,大家感兴趣的可以穿梭: https://zhuanlan.zhihu.com/p/570332906 今天要给大家介绍的这一篇paper是百度…

AXI协议详解(10)-非对齐传输

非对齐传输 本章介绍 AXI 协议如何处理未对齐的传输。 它包含以下部分: • 未对齐的传输 • 示例 10.1 关于未对齐传输 AXI 协议使用基于突发的寻址,这意味着每个事务由多个数据传输组成。 通常,每个数据传输都与传输大小对齐。 例如&…

Linux入门

Liunx 一计算机发展历史第一台计算机的诞生时代背景线计算机的发展线国家线时间线收束Liunx诞生操作系统简述购买云服务器以及登录增加用户总结学习的同时别忘了每天运动! 身体才是革命的本钱 计算机发展历史 第一台计算机的诞生 第一台计算机在1946年2月14日在美国…

webpack学习踩坑笔记(持续更新中...)

目录 学习内容: 1.5使用plugin 1.6 使用DevServer 学习内容: 《深入浅出webpack》 深入浅出Webpack Dive Into GitBook 因为很多内容书上已经写了,这里主要是记录一下个人看书过程中遇到的坑 1.5使用plugin 这一部分介绍了一个可以把…

vue3事件处理

获取到用户点击或者勾选的值 <li click“clici(item)” v-for"item in data" :key"id"> {{item}}</li> <script> clici(item){ } </script> v-model 实现数据的双向绑定 v-model.lazy 只有当用户提交或enter键后才触…

【数据结构】动态顺序表(C语言实现)

文章目录0. 前言1. 线性表2. 顺序表2.1 概念及结构3. 动态顺序表的实现3.1 定义结构3.2 接口函数总览3.3 初始化3.4 检查增容3.5 尾插3.6 尾删3.7 头插3.8 头删3.9 查找3.10 指定下标位置插入3.11 指定下标位置删除3.12 修改3.13 打印3.14 销毁4. 完整代码SeqList.hSeqList.cte…