日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Qt設置窗體(QWidget)透明度的方法總結_C 語言

作者:音視頻開發老舅 ? 更新時間: 2022-12-14 編程語言

1. 設置窗體的背景色

在構造函數里添加代碼,需要添加頭文件qpalette或qgui

QPalette pal = palette(); 
pal.setColor(QPalette::Background, QColor(0x00,0xff,0x00,0x00)); 
setPalette(pal);

通過設置窗體的背景色來實現,將背景色設置為全透。

效果: 窗口整體透明,但窗口控件不透明,QLabel控件只是字顯示,控件背景色透明; 窗體客戶區完全透明。

2. 使用函數

setWindowFlags(Qt::Dialog | Qt::FramelessWindowHint);//去掉標題欄
setAttribute(Qt::WA_TranslucentBackground, true);//設置窗口背景透明

同樣在構造函數中,效果和第一種方法相同。

3. 窗口及其上面的控件都半透明

setWindowOpacity(0.7);

這個函數可以分10個等級調整透明度,配合QSlider控件可以做成控制條 效果:窗口及控件都半透明。

自己注釋:

直接設置setWindowOpacity函數應該不起作用,需要設置窗體的屬性:

this->setAttribute(Qt::WA_WState_WindowOpacitySet);

4. 窗口整體不透明,局部透明

在Paint事件中使用Clear模式繪圖。

void TestWindow::paintEvent( QPaintEvent* )
{ 
    QPainter p(this);
    p.setCompositionMode( QPainter::CompositionMode_Clear );
    p.fillRect( 10, 10, 300, 300, Qt::SolidPattern ); 
}

試驗效果:繪制區域全透明。如果繪制區域有控件不會影響控件。

5. 使用qss樣式表設置窗體透明

QWidget* widget = new QWidget();
widget->setObjectName("wid");
widget->setStyleSheet("QWidget#wid{background-color: rgba(255,0,0,0.5);}");
widget->show();

rgba(255,255,255,1)中參數解釋:

  • r【read】 表示:紅色,范圍:0-255,
  • g【green】表示:綠色,范圍:0-255,
  • b【blue】 表示:藍色,范圍:0-255,
  • a【alpha】表示:透明度,范圍:0-1,0表示全透明, 1表示不透明;

補充: 如果QWidget 的子類窗口采用setStyleSheet 設置背景色無效,需要加上setAttribute(Qt::WA_StyledBackground);

目的是脫離父窗口的樣式。

6. 設置窗體顏色漸變

(1)漸變顏色設置有:qlineargradient(線性漸變顏色設置),qradialgradient(輻射漸變),qconicalgradient(圓錐形漸變)。

漸變方式 解釋
QLinearGradient: 顯示從起點到終點的漸變。
QRadialGradient: 以圓心為中心顯示漸變
QConicalGradient: 圍繞一個中心點顯示漸變
QGradient::PadSpread : 填充區域內最接近的停止顏色。這是默認的
QGradient::RepeatSpread : 在區域外繼續重復填充
QGradient::ReflectSpread : 在區域外反射填充

(2)漸變過程:x1->x2 從左向右漸變;y1->y2 從上向下漸變。如果只有x相等,則表示垂直線性漸變,如果只有y相等,則表示平行線性漸變,否則就是斜角線性漸變。

(3)左右漸變

QLabel#label{
                background-color: qlineargradient(x1:0, y1:0, x2:1, y2:0,
                stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));
            }

效果:

(4)上下漸變

QLabel#label{
                background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,
                stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));
            }

效果:

(5)左右上下 漸變

QLabel#label{
                background-color: qlineargradient(x1:0, y1:0, x2:1, y2:1,
                stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));
            }

效果:

(6)x1,x2,y1,y2都是設置成0或者1,顏色都一樣是紅色

QLabel#label{
                background-color: qlineargradient(x1:1, y1:1, x2:1, y2:1,
                stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));
            }

效果:

(7)增加多個漸變點

QLabel#label{
                background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:0,
                stop:0 rgba(255,0,0,1),stop:0.5 rgba(0,255,0,1),stop:1 rgba(0,0,255,1));
            }

效果:

(8)輻射漸變

以圓心為中心顯示漸變。(cx, cy)是中點,半徑(radius)是以中點為圓心的圓的半徑,(fx, fy)是漸變的起點。

QLabel#label{
        background-color: qradialgradient(spread:pad, cx:0.5, cy:0.5, radius:0.5, fx:0.5, fy:0.5,
        stop:0 rgba(105, 105, 0, 255),
        stop:0.19397 rgba(0, 55, 55, 255),
        stop:0.202312 rgba(80, 80, 0, 255),
        stop:0.495514 rgba(0, 105, 105, 255),
        stop:0.504819 rgba(0, 188, 188, 255),
        stop:0.79 rgba(0, 195, 195, 255),
        stop:1 rgba(0, 158, 158, 255));
}

效果:

(9)圓錐形漸變

在(cx, cy)坐標上以角度(angle)為中心顯示漸變。

QLabel#label{
            background-color: qconicalgradient(cx:0.5, cy:0.5, angle:0,
            stop:0 rgba(0, 255, 0, 255), stop:0.373979 rgba(0, 255, 0, 255),
            stop:0.373991 rgba(33, 30, 255, 255), stop:0.624018 rgba(33, 30, 255, 255),
            stop:0.624043 rgba(255, 0, 0, 255), stop:1 rgba(255, 0, 0, 255));
            }

效果:

原文鏈接:https://blog.csdn.net/m0_60259116/article/details/127887533

欄目分類
最近更新