问题描述
所以,我认为这张照片说明了一切。工具提示应具有黑色文本颜色和浅灰色背景。好吧,如果您仔细观察,背景为浅灰色。但是文本是白色的,最重要的是,显示了已启用按钮的图标。这不应该!其他默认按钮(没有图标)将正确显示工具提示。 我试图用opacity(不同的值)和rgba(211,211,211,0/255)解决这个问题,但是没有任何效果。 这是一个众所周知的问题吗?我的系统是Windows 10 64位,我使用Qt Creator 4.12.2(社区)和Qt 5.12.9 MinGW 64位编译器。
#include "mainwindow.h"
#include <QApplication>
int main(int argc,char *argv[])
{
QApplication a(argc,argv);
MainWindow w;
w.setStyleSheet("QToolTip { background-color: lightgrey; "
"color: black; "
"border: none } "
"QWidget { color: lightblue; "
"background-color: #404040 }");
w.show();
return a.exec();
}
该按钮的样式表如下:
ui -> Cmdsave -> setStyleSheet(" :disabled { color: white; "
"border-image: url(:/miscRsc/misc_icons/filesave_128x128_disabled) 3 10 3 10; "
"border-top: 3px transparent; "
"border-bottom: 3px transparent; "
"border-right: 10px transparent; "
"border-left: 10px transparent } "
":enabled { color: white; "
"border-image: url(:/miscRsc/misc_icons/filesave_128x128) 3 10 3 10; "
"border-top: 3px transparent; "
"border-bottom: 3px transparent; "
"border-right: 10px transparent; "
"border-left: 10px transparent } "
" :pressed { color: white; "
"border-image: url(:/miscRsc/misc_icons/filesave_128x128_pressed.png) 2 9 2 9; border-top: 2px transparent; "
"border-bottom: 2px transparent; "
"border-right: 9px transparent; "
"border-left: 9px transparent }");
解决方法
现在,我们离问题和解决方案越来越近。 通过在设置应用程序样式之后设置按钮样式,工具提示将继承按钮的样式-特别是,它继承按钮的边框图像,这就是为什么您在工具提示中看到按钮的边框图像的原因。 您可以通过使用后代选择器设置按钮的样式来避免这种情况(我简化了样式):
QPushButton:disabled { border-image: url(:/folder.png) 3 10 3 10; border: 3px transparent }
QPushButton:enabled { border-image: url(:/folder.png) 3 10 3 10; border: 3px transparent }
QPushButton:pressed { border-image: url(:/folder.png) 3 10 3 10; border: 2px transparent }