QmlDesigner.NodeInstances: Recover positioner support

Change-Id: Ib5e891a8563bfced2af93e4a516ef8f196e8ff1e
Reviewed-by: Thomas Hartmann <Thomas.Hartmann@digia.com>
This commit is contained in:
Marco Bubke
2012-10-04 16:34:25 +02:00
parent ca48d81c28
commit fb276230fe
7 changed files with 184 additions and 10 deletions
@@ -20,6 +20,7 @@ HEADERS += $$PWD/qmlstatenodeinstance.h
HEADERS += $$PWD/qmltransitionnodeinstance.h
HEADERS += $$PWD/servernodeinstance.h
HEADERS += $$PWD/anchorchangesnodeinstance.h
HEADERS += $$PWD/positionernodeinstance.h
SOURCES += $$PWD/qt5nodeinstanceserver.cpp
SOURCES += $$PWD/qt5informationnodeinstanceserver.cpp
@@ -41,3 +42,4 @@ SOURCES += $$PWD/qmlstatenodeinstance.cpp
SOURCES += $$PWD/qmltransitionnodeinstance.cpp
SOURCES += $$PWD/servernodeinstance.cpp
SOURCES += $$PWD/anchorchangesnodeinstance.cpp
SOURCES += $$PWD/positionernodeinstance.cpp
@@ -0,0 +1,99 @@
/**************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
**
** Contact: http://www.qt-project.org/
**
**
** GNU Lesser General Public License Usage
**
** This file may be used under the terms of the GNU Lesser General Public
** License version 2.1 as published by the Free Software Foundation and
** appearing in the file LICENSE.LGPL included in the packaging of this file.
** Please review the following information to ensure the GNU Lesser General
** Public License version 2.1 requirements will be met:
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** Other Usage
**
** Alternatively, this file may be used in accordance with the terms and
** conditions contained in a signed written agreement between you and Nokia.
**
**
**************************************************************************/
#include "positionernodeinstance.h"
#include <private/qquickpositioners_p.h>
namespace QmlDesigner {
namespace Internal {
PositionerNodeInstance::PositionerNodeInstance(QQuickBasePositioner *item)
: QuickItemNodeInstance(item)
{
}
bool PositionerNodeInstance::isPositioner() const
{
return true;
}
bool PositionerNodeInstance::isResizable() const
{
return true;
}
void PositionerNodeInstance::setPropertyVariant(const QString &name, const QVariant &value)
{
if (name == "move" || name == "add")
return;
QuickItemNodeInstance::setPropertyVariant(name, value);
}
void PositionerNodeInstance::setPropertyBinding(const QString &name, const QString &expression)
{
if (name == "move" || name == "add")
return;
QuickItemNodeInstance::setPropertyBinding(name, expression);
}
PositionerNodeInstance::Pointer PositionerNodeInstance::create(QObject *object)
{
QQuickBasePositioner *positioner = qobject_cast<QQuickBasePositioner*>(object);
Q_ASSERT(positioner);
Pointer instance(new PositionerNodeInstance(positioner));
instance->setHasContent(anyItemHasContent(positioner));
positioner->setFlag(QQuickItem::ItemHasContents, true);
static_cast<QQmlParserStatus*>(positioner)->classBegin();
instance->populateResetHashes();
return instance;
}
QQuickBasePositioner *PositionerNodeInstance::positioner() const
{
Q_ASSERT(qobject_cast<QQuickBasePositioner*>(object()));
return static_cast<QQuickBasePositioner*>(object());
}
void PositionerNodeInstance::refreshPositioner()
{
bool success = QMetaObject::invokeMethod(positioner(), "prePositioning");
Q_ASSERT(success);
}
}
} // namespace QmlDesigner
@@ -0,0 +1,68 @@
/**************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
**
** Contact: http://www.qt-project.org/
**
**
** GNU Lesser General Public License Usage
**
** This file may be used under the terms of the GNU Lesser General Public
** License version 2.1 as published by the Free Software Foundation and
** appearing in the file LICENSE.LGPL included in the packaging of this file.
** Please review the following information to ensure the GNU Lesser General
** Public License version 2.1 requirements will be met:
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** Other Usage
**
** Alternatively, this file may be used in accordance with the terms and
** conditions contained in a signed written agreement between you and Nokia.
**
**
**************************************************************************/
#ifndef POSITIONERNODEINSTANCE_H
#define POSITIONERNODEINSTANCE_H
#include "quickitemnodeinstance.h"
QT_BEGIN_NAMESPACE
class QQuickBasePositioner;
QT_END_NAMESPACE
namespace QmlDesigner {
namespace Internal {
class PositionerNodeInstance : public QuickItemNodeInstance
{
public:
typedef QSharedPointer<PositionerNodeInstance> Pointer;
typedef QWeakPointer<PositionerNodeInstance> WeakPointer;
static Pointer create(QObject *objectToBeWrapped);
void setPropertyVariant(const QString &name, const QVariant &value);
void setPropertyBinding(const QString &name, const QString &expression);
bool isPositioner() const;
bool isResizable() const;
void refreshPositioner();
protected:
PositionerNodeInstance(QQuickBasePositioner *item);
QQuickBasePositioner *positioner() const;
};
} // namespace Internal
} // namespace QmlDesigner
#endif // POSITIONERNODEINSTANCE_H
@@ -113,7 +113,7 @@ void QuickItemNodeInstance::setHasContent(bool hasContent)
}
bool anyItemHasContent(QQuickItem *graphicsItem)
bool QuickItemNodeInstance::anyItemHasContent(QQuickItem *graphicsItem)
{
if (graphicsItem->flags().testFlag(QQuickItem::ItemHasContents))
return true;
@@ -343,6 +343,9 @@ void QuickItemNodeInstance::setPropertyVariant(const QString &name, const QVaria
ObjectNodeInstance::setPropertyVariant(name, value);
refresh();
if (isInPositioner())
parentInstance()->refreshPositioner();
}
void QuickItemNodeInstance::setPropertyBinding(const QString &name, const QString &expression)
@@ -468,6 +471,9 @@ void QuickItemNodeInstance::resetProperty(const QString &name)
}
ObjectNodeInstance::resetProperty(name);
if (isInPositioner())
parentInstance()->refreshPositioner();
}
void QuickItemNodeInstance::reparent(const ObjectNodeInstance::Pointer &oldParentInstance, const QString &oldParentProperty, const ObjectNodeInstance::Pointer &newParentInstance, const QString &newParentProperty)
@@ -494,6 +500,9 @@ void QuickItemNodeInstance::reparent(const ObjectNodeInstance::Pointer &oldParen
refresh();
DesignerSupport::updateDirtyNode(quickItem());
if (isInPositioner())
parentInstance()->refreshPositioner();
}
static bool isValidAnchorName(const QString &name)
@@ -117,6 +117,7 @@ protected:
void refresh();
QRectF boundingRectWithStepChilds(QQuickItem *parentItem) const;
void updateDirtyNodeRecursive(QQuickItem *parentItem) const;
static bool anyItemHasContent(QQuickItem *graphicsItem);
private: //variables
bool m_hasHeight;
@@ -37,7 +37,7 @@
#include "behaviornodeinstance.h"
#include "qmlstatenodeinstance.h"
#include "anchorchangesnodeinstance.h"
#include "positionernodeinstance.h"
#include "quickitemnodeinstance.h"
@@ -172,15 +172,10 @@ Internal::ObjectNodeInstance::Pointer ServerNodeInstance::createInstance(QObject
if (objectToBeWrapped == 0)
instance = Internal::DummyNodeInstance::create();
#if QT_VERSION >= 0x050000
else if (isSubclassOf(objectToBeWrapped, "QQuickBasePositioner"))
instance = Internal::PositionerNodeInstance::create(objectToBeWrapped);
else if (isSubclassOf(objectToBeWrapped, "QQuickItem"))
instance = Internal::QuickItemNodeInstance::create(objectToBeWrapped);
#else
else if (isSubclassOf(objectToBeWrapped, "QQmlBasePositioner"))
instance = Internal::PositionerNodeInstance::create(objectToBeWrapped);
else if (isSubclassOf(objectToBeWrapped, "QQmlItem"))
instance = Internal::QmlGraphicsItemNodeInstance::create(objectToBeWrapped);
#endif
else if (isSubclassOf(objectToBeWrapped, "QQmlComponent"))
instance = Internal::ComponentNodeInstance::create(objectToBeWrapped);
else if (objectToBeWrapped->inherits("QQmlAnchorChanges"))
@@ -66,7 +66,7 @@ void PositionerNodeInstance::setPropertyBinding(const QString &name, const QStri
}
PositionerNodeInstance::Pointer PositionerNodeInstance::create(QObject *object)
{
{
QDeclarativeBasePositioner *positioner = qobject_cast<QDeclarativeBasePositioner*>(object);
Q_ASSERT(positioner);