Qml / Qt / C ++:QWidget中的QQuickView - 需要背景透明度

时间:2014-10-18 03:21:06

标签: c++ qt qml

我试图让我的容器中有一个qquickview,它是透明的,只显示没有背景的QML文件中的元素。

有没有更好的方法来实现这个?这是相关的代码,你可以看到我已经注释了将QML添加到它,以便唯一的攻击者是包含QQuickView的QWidget

QML将仅使用文本制作类似于Apple“Cover Flow”的菜单。我只希望它生成的文本可见。

目前它有一个坚实的白色背景。

QQuickView *view = new QQuickView();
QWidget *container = QWidget::createWindowContainer(view, this);
container->setObjectName("wrappingContainer");
container->setMinimumSize(1000, 240);
container->setMaximumSize(1000, 240);
container->setFocusPolicy(Qt::TabFocus);

//view->setSource(QUrl("qrc:/qml/wrappingMenu.qml"));
ui->testLayout->addWidget(container);

3 个答案:

答案 0 :(得分:5)

尝试QQuickWidget

#include <QtWidgets>
#include <QQuickWidget>

class Widget : public QWidget
{
    Q_OBJECT
public:
    Widget() {
        setStyleSheet("background-color: 'grey';");
        mQQuickWidget = new QQuickWidget(QUrl(QStringLiteral("main.qml")), this);
        mQQuickWidget->setResizeMode(QQuickWidget::SizeRootObjectToView);
        mQQuickWidget->setAttribute(Qt::WA_AlwaysStackOnTop);
        mQQuickWidget->setClearColor(Qt::transparent);
        mQQuickWidget->resize(400, 400);
        mQQuickWidget->raise();
    }
private:
    QQuickWidget *mQQuickWidget;
};

int main(int argc, char** argv)
{
    QApplication app(argc, argv);
    Widget widget;
    widget.resize(400, 400);
    widget.show();
    return app.exec();
}

#include "main.moc"

main.qml:

import QtQuick 2.2

Item {
    Text {
        text: "Qt Quick Text"
        font.pixelSize: 32
        anchors.centerIn: parent
    }
}

enter image description here

答案 1 :(得分:1)

我怀疑是否可以对QQuickView中嵌入的QWidget进行此操作。但是你可以有一个透明的QQuickView,如:

QQuickView view;

view.setSurfaceType(QSurface::OpenGLSurface);

QSurfaceFormat format;
format.setAlphaBufferSize(8);
format.setRenderableType(QSurfaceFormat::OpenGL);

view.setFormat(format);
view.setColor(QColor(Qt::transparent));
view.setClearBeforeRendering(true);

view.setFlags(Qt::FramelessWindowHint);

view.setSource(QStringLiteral("qrc:/qml/wrappingMenu.qml"));

view.show();

答案 2 :(得分:0)

你可以这样做:

QQuickView view;
view.setColor(Qt::transparent);
view.setSource("main.qml");