簡體   English   中英

Qt quick 2 paint方法沒有被調用

[英]Qt quick 2 paint method doesn't get called

我創建了一個簡單的Qt快速應用程序,我有一個問題用QQuickPaintedItem繪圖。 如果調用了paint,我檢查了調試模式,但沒有。 無論如何這是我的代碼:

資源:

ParticleHandler::ParticleHandler(QQuickPaintedItem *parent) : QQuickPaintedItem(parent)
{
    setFlag(QQuickItem::ItemHasContents);
    particle = new Particle();
}
void ParticleHandler::paint(QPainter *painter)
{
    QPen pen = QPen(m_color);
    painter->setPen(pen);
    painter->setRenderHints(QPainter::Antialiasing, true);
    painter->drawEllipse(particle->Position.x,particle->Position.y,particle->Radius/2,particle->Radius/2);
}

標題:

ParticleHandler(QQuickPaintedItem *parent = 0);
void paint(QPainter *painter);

嘗試設置自定義項目的寬度和高度。

import QtQuick 2.0
import Fizika 1.0
Rectangle
{
  width: 360
  height: 360
  Particle
    { 
     width: 100
     height: 100
     radius: 20
     x: 100
     y: 200
     color: "red"
    }
}

沒有看到代碼的其余部分主要問題是什么並不明顯,但這是一個完全獨立的例子。 也許它會有所幫助。

#include <QGuiApplication>
#include <QPainter>
#include <QtQuick>

class PaintedItem : public QQuickPaintedItem {
    Q_OBJECT
public:
    PaintedItem(QQuickItem *parent = 0) : QQuickPaintedItem(parent) {
    }

    void paint(QPainter *painter) {
        painter->fillRect(contentsBoundingRect(), Qt::red);
    }
};

int main(int argc, char *argv[])
{
    QGuiApplication a(argc, argv);

    qmlRegisterType<PaintedItem>("mymodule", 1, 0, "PaintedItem");

    QQuickView view(QUrl("qrc:///qml/main.qml"));
    view.setResizeMode(QQuickView::SizeRootObjectToView);
    view.resize(500, 500);
    view.show();

    return a.exec();
}

#include "main.moc"

以及main.qml的內容:

import QtQuick 2.0
import mymodule 1.0

Rectangle {
    color: "black"

    PaintedItem {
        anchors.centerIn: parent
        width: 50
        height: 50
    }
}

確保在某個時刻調用update() ,這將安排重繪。

作為一個不相關的注意事項,請注意線程 - 從渲染線程中調用paint(),因此需要對particle事物進行適當的同步。

嘗試在類聲明后添加此行

QML_DECLARE_TYPE(ParticleHandler)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM