QT Quick Designer Пользовательские компоненты пустые? - PullRequest
1 голос
/ 09 августа 2011

Я провожу некоторое тестирование QT Quick, чтобы посмотреть, смогу ли я использовать его в качестве замены графического интерфейса для старых файлов Ui.В некоторых примерах я заметил, что пользовательские компоненты будут заполнять вид библиотеки.Мне удалось это сделать (по-видимому, они должны быть в подкаталоге файла qml, который их использует?).Однако эти компоненты не отображаются в окне дизайна Qt Quick.На самом деле нечего захватывать или манипулировать.После запуска программы они отображаются правильно.

У кого-нибудь есть решение?Мой источник ниже

import QtQuick 1.0
import Chips 1.0

Item {
    width: 100
    height: 62
    Chip
    {

    }
}

chip.cpp

#include "Chip.h"

#include <QtGui>


Chip::Chip(QDeclarativeItem *parent)
    : QDeclarativeItem(parent)
{
    x = 0;
    y = 0;
    color = QColor(0, 200, 0);
    setFlags(ItemIsSelectable | ItemIsMovable);
    setFlag(QGraphicsItem::ItemHasNoContents, false);
    setAcceptsHoverEvents(true);
}


//Chip::Chip(const QColor &color, int x, int y, QDeclarativeItem *parent)
//    : QDeclarativeItem(parent)
//{
//    this->x = x;
//    this->y = y;
//    this->color = color;
//    setZValue((x + y) % 2);

//    setFlags(ItemIsSelectable | ItemIsMovable);
//    setFlag(QGraphicsItem::ItemHasNoContents, false);
// setAcceptsHoverEvents(true);
//}

QRectF Chip::boundingRect() const
{
    return QRectF(0, 0, 110, 70);
}

QPainterPath Chip::shape() const
{
    QPainterPath path;
    path.addRect(14, 14, 82, 42);
    return path;
}

void Chip::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
{
    Q_UNUSED(widget);

    QColor fillColor = (option->state & QStyle::State_Selected) ? color.dark(150) : color;
    if (option->state & QStyle::State_MouseOver)
        fillColor = fillColor.light(125);

    const qreal lod = option->levelOfDetailFromTransform(painter->worldTransform());
    if (lod < 0.2) {
        if (lod < 0.125) {
            painter->fillRect(QRectF(0, 0, 110, 70), fillColor);
            return;
        }

        QBrush b = painter->brush();
        painter->setBrush(fillColor);
        painter->drawRect(13, 13, 97, 57);
        painter->setBrush(b);
        return;
    }

    QPen oldPen = painter->pen();
    QPen pen = oldPen;
    int width = 0;
    if (option->state & QStyle::State_Selected)
        width += 2;

    pen.setWidth(width);
    QBrush b = painter->brush();
    painter->setBrush(QBrush(fillColor.dark(option->state & QStyle::State_Sunken ? 120 : 100)));

    painter->drawRect(QRect(14, 14, 79, 39));
    painter->setBrush(b);

    if (lod >= 1) {
        painter->setPen(QPen(Qt::gray, 1));
        painter->drawLine(15, 54, 94, 54);
        painter->drawLine(94, 53, 94, 15);
        painter->setPen(QPen(Qt::black, 0));
    }

    // Draw text
    if (lod >= 2) {
        QFont font("Times", 10);
        font.setStyleStrategy(QFont::ForceOutline);
        painter->setFont(font);
        painter->save();
        painter->scale(0.1, 0.1);
        painter->drawText(170, 180, QString("Model: VSC-2000 (Very Small Chip) at %1x%2").arg(x).arg(y));
        painter->drawText(170, 200, QString("Serial number: DLWR-WEER-123L-ZZ33-SDSJ"));
        painter->drawText(170, 220, QString("Manufacturer: Chip Manufacturer"));
        painter->restore();
    }

    // Draw lines
    QVarLengthArray<QLineF, 36> lines;
    if (lod >= 0.5) {
        for (int i = 0; i <= 10; i += (lod > 0.5 ? 1 : 2)) {
            lines.append(QLineF(18 + 7 * i, 13, 18 + 7 * i, 5));
            lines.append(QLineF(18 + 7 * i, 54, 18 + 7 * i, 62));
        }
        for (int i = 0; i <= 6; i += (lod > 0.5 ? 1 : 2)) {
            lines.append(QLineF(5, 18 + i * 5, 13, 18 + i * 5));
            lines.append(QLineF(94, 18 + i * 5, 102, 18 + i * 5));
        }
    }
    if (lod >= 0.4) {
        const QLineF lineData[] = {
            QLineF(25, 35, 35, 35),
            QLineF(35, 30, 35, 40),
            QLineF(35, 30, 45, 35),
            QLineF(35, 40, 45, 35),
            QLineF(45, 30, 45, 40),
            QLineF(45, 35, 55, 35)
        };
        lines.append(lineData, 6);
    }
    painter->drawLines(lines.data(), lines.size());

    // Draw red ink
    if (stuff.size() > 1) {
        QPen p = painter->pen();
        painter->setPen(QPen(Qt::red, 1, Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
        painter->setBrush(Qt::NoBrush);
        QPainterPath path;
        path.moveTo(stuff.first());
        for (int i = 1; i < stuff.size(); ++i)
            path.lineTo(stuff.at(i));
        painter->drawPath(path);
        painter->setPen(p);
    }
}

void Chip::mousePressEvent(QGraphicsSceneMouseEvent *event)
{
    QGraphicsItem::mousePressEvent(event);
    update();
}

void Chip::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
{
    if (event->modifiers() & Qt::ShiftModifier) {
        stuff << event->pos();
        update();
        return;
    }
    QGraphicsItem::mouseMoveEvent(event);
}

void Chip::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
{
    QGraphicsItem::mouseReleaseEvent(event);
    update();
}

QColor Chip::getColor() const
{
    return color;
}

int Chip::getX() const
{
    return x;
}

int Chip::getY() const
{
    return y;
}

void Chip::setColor(const QColor &color)
{
    this->color = color;
}

void Chip::setX(const int &x)
{
    this->x = x;
}

void Chip::setY(const int &y)
{
    this->y = y;
}

chip.h

#ifndef CHIP_H
#define CHIP_H

#include <QtGui/QColor>
#include <QDeclarativeItem>

class Chip : public QDeclarativeItem
{
    Q_OBJECT
    Q_PROPERTY(int x READ getX WRITE setX)
    Q_PROPERTY(int y READ getY WRITE setY)
    Q_PROPERTY(QColor color READ getColor WRITE setColor)

public:
    Chip(QDeclarativeItem *parent = 0);
    Chip(const QColor &color, int x, int y);

    QRectF boundingRect() const;

    QColor getColor() const;
    int getX() const;
    int getY() const;

    void setColor(const QColor &color);
    void setX(const int &x);
    void setY(const int &y);

    QPainterPath shape() const;
    void paint(QPainter *painter, const QStyleOptionGraphicsItem *item, QWidget *widget);

protected:
    void mousePressEvent(QGraphicsSceneMouseEvent *event);
    void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
    void mouseReleaseEvent(QGraphicsSceneMouseEvent *event);

private:
    int x, y;
    QColor color;
    QList<QPointF> stuff;
};

#endif

В ходе моего исследования этой проблемы я узнал, что вы можете добавитьпользовательские виджеты для QT Designer.Возможно, мне придется это проверить, прежде чем я приму решение.Любая помощь будет оценена, спасибо.

Ответы [ 2 ]

1 голос
/ 06 февраля 2012

ОБНОВЛЕНИЕ: декабрь / 2015

Вы должны пометить его как «поддерживаемый»

В документации четко указано , что вы должны явно пометитькак поддерживается, в противном случае вы получите пустые поля.

Элементы неподдерживаемого плагина не отображаются в Qt Quick Designer, но они по-прежнему доступны в виде пустых полей, и свойства можно редактировать.

Чтобы сделать это, вы должны построить его как плагин, а затем включить ключевое слово designersupported в файл qmldir в той же папке, где находится общий объект / dll плагина.Это белый список, и марионетка Qt Creator будет доверять вашему коду, будьте уверены, что не будете выполнять долгих операций или вылетать, иначе вы разбьете марионетку и сделаете дизайнер бесполезным.


Старый и устаревший ответ ниже

То же самое происходит со мной.Это похоже на ошибку в QtCreator.Я копался в коде элемента Rectangle QML и не нашел никаких специальных инструкций.Таким образом, QtCreator должен иметь жестко запрограммированный код или что-то в этом роде.Смотрите это: http://developer.qt.nokia.com/forums/viewthread/2555

0 голосов
/ 21 марта 2014

Они пустые, пользовательские компоненты, созданные с помощью C ++, показать нельзя, но они отлично работают при запуске вашего приложения.В Qt добавлена ​​ошибка, позволяющая это сделать, но теперь она имеет низкий приоритет, поскольку требует внутренних изменений Qt.

Обновление:

Совсем недавно, после некоторыхВ ходе обсуждения была создана задача для реализации механизма затенения пользовательских компонентов, и она была помечена как P1, приятно !.См. этот отчет об ошибке , они даже добавили патч в процессе разработки, который вы можете протестировать.Это патч для Qt, поэтому мы можем (или нет) быть ближе к тому, чтобы он был внутри Qt 5.4, и тогда Qt Creator получит эту поддержку.Помните, что у Qt есть цикл выпуска 6 месяцев, так что это может быть не так далеко.Пожалуйста, зарегистрируйтесь и проголосуйте за это, если вам это нужно.

...