QtQuick 2.0的透明小部件

时间:2013-07-22 07:10:29

标签: c++ qt graphics directx qml

我正在尝试使用QtQuick 2.0创建一个透明窗口。

我可以像这样创建一个透明的小部件:

class TransparentWidget : public QWidget
{
public:
    TransparentWidget(QWidget* parent)
    : QWidget(parent)
    {
        resize(QSize(500, 500));
        setAttribute(Qt::WA_TranslucentBackground);
        setWindowFlags(Qt::FramelessWindowHint);
    }

    void paintEvent(QPaintEvent * event)
    {
        QPainter painter;
        QBrush brush(Qt::cyan);
        painter.begin(this);
        painter.setRenderHint(QPainter::Antialiasing);
        painter.setBrush(brush);
        painter.drawRect(0,0,100,100);
        painter.end();
    }
};

现在我想用QQuickView做同样的事情,首先我创建它:

QQuickView view;
view.setSource(QUrl::fromLocalFile("test.qml"));
view.setResizeMode(QQuickView::SizeRootObjectToView); 

这是我的“test.qml”文件:

Rectangle
{
    width: 300;
    height: 300;
    color: "transparent";

    Rectangle
    {
        anchors.top: parent.top;
        anchors.left: parent.left;
        width: 50;
        height: 100;
        color: "lightsteelblue";
    }

    Rectangle
    {
        anchors.bottom: parent.bottom;
        anchors.right: parent.right;
        width: 50;
        height: 100;
        color: "darkgrey";
    }
}

现在我想创建一个透明的小部件,我这样做:

QWidget *p = QWidget::createWindowContainer(&view, NULL, Qt::FramelessWindowHint);
p->setAttribute(Qt::WA_TranslucentBackground);
p->show();

我使用WA_TranseculentBackground和FramelessWindowHint创建一个小部件,就像我对前一个小部件一样,但它不起作用。

比进一步深入并使用pix查看QQuickView后面的调用,我看到这一行:

pix output

现在我的问题:

1 - 为什么Qt用白色调用IDirect3DDevice9 :: clear?

2-有没有办法告诉QQuickView或QmlEngine不要绘制任何背景?

1 个答案:

答案 0 :(得分:1)

QtQuick2的透明度从Qt 5.2开始,至少对于Windows(Angle和OpenGL版本)都是如此:

创建视图:

QQuickView view;
view.setOpacity(0.9999);
view.setColor( Qt::transparent );
view.setSource( QUrl::fromLocalFile( QLatin1String( "Main.qml" ) ) );

除了setOpacity和setColor之外,不需要额外的样式/属性/标志调用。 " Main.qml"必须正确设置透明度,就像您的QML示例一样:

Rectangle {
    color: "transparent"
}