QmlDesigner: Disable assigning a texture to a model with no materials

Disable apply texture to selected model option from texture editor's
toolbar when the selected model has no material. Also relevant fixes
to make sure texture assigning happens in the current state.

Fixes: QDS-8395
Change-Id: Iab2e8fce4696c6bd5d50636b4077362ba04cb8a0
Reviewed-by: Miikka Heikkinen <miikka.heikkinen@qt.io>
This commit is contained in:
Mahmoud Badri
2022-11-23 16:18:50 +02:00
parent 07e96c299a
commit 34b236e7fb
8 changed files with 44 additions and 24 deletions

View File

@@ -28,7 +28,7 @@ Rectangle {
normalColor: StudioTheme.Values.themeSectionHeadBackground
iconSize: StudioTheme.Values.bigIconFontSize
buttonSize: root.height
enabled: hasTexture && hasModelSelection && hasQuick3DImport && hasMaterialLibrary
enabled: hasTexture && hasSingleModelSelection && hasQuick3DImport && hasMaterialLibrary
onClicked: root.toolBarAction(ToolBarAction.ApplyToSelected)
tooltip: qsTr("Apply texture to selected model's material.")
}

View File

@@ -481,9 +481,9 @@ void MaterialBrowserView::instancePropertyChanged(const QList<QPair<ModelNode, P
}
}
void MaterialBrowserView::applyTextureToModel3D(const ModelNode &model3D, const ModelNode &texture)
void MaterialBrowserView::applyTextureToModel3D(const QmlObjectNode &model3D, const ModelNode &texture)
{
if (!texture.isValid() || !model3D.isValid() || !model3D.metaInfo().isQtQuick3DModel())
if (!texture.isValid() || !model3D.isValid() || !model3D.modelNode().metaInfo().isQtQuick3DModel())
return;
BindingProperty matsProp = model3D.bindingProperty("materials");
@@ -547,14 +547,13 @@ void MaterialBrowserView::applyTextureToProperty(const QString &matId, const QSt
{
QTC_ASSERT(!m_appliedTextureId.isEmpty(), return);
ModelNode mat = modelNodeForId(matId);
QmlObjectNode mat = modelNodeForId(matId);
QTC_ASSERT(mat.isValid(), return);
BindingProperty texProp = mat.bindingProperty(propName.toLatin1());
QTC_ASSERT(texProp.isValid(), return);
QmlObjectNode qmlObjNode(mat);
qmlObjNode.setBindingProperty(propName.toLatin1(), m_appliedTextureId);
mat.setBindingProperty(propName.toLatin1(), m_appliedTextureId);
closeChooseMatPropsView();
}

View File

@@ -47,7 +47,7 @@ public:
void instancesCompleted(const QVector<ModelNode> &completedNodeList) override;
void instancePropertyChanged(const QList<QPair<ModelNode, PropertyName> > &propertyList) override;
void applyTextureToModel3D(const ModelNode &model3D, const ModelNode &texture);
void applyTextureToModel3D(const QmlObjectNode &model3D, const ModelNode &texture);
void applyTextureToMaterial(const QList<ModelNode> &materials, const ModelNode &texture);
Q_INVOKABLE void updatePropsModel(const QString &matId);

View File

@@ -145,18 +145,18 @@ void TextureEditorContextObject::setHasMaterialLibrary(bool b)
emit hasMaterialLibraryChanged();
}
bool TextureEditorContextObject::hasModelSelection() const
bool TextureEditorContextObject::hasSingleModelSelection() const
{
return m_hasModelSelection;
return m_hasSingleModelSelection;
}
void TextureEditorContextObject::setHasModelSelection(bool b)
void TextureEditorContextObject::setHasSingleModelSelection(bool b)
{
if (b == m_hasModelSelection)
if (b == m_hasSingleModelSelection)
return;
m_hasModelSelection = b;
emit hasModelSelectionChanged();
m_hasSingleModelSelection = b;
emit hasSingleModelSelectionChanged();
}
void TextureEditorContextObject::setSelectedMaterial(const ModelNode &matNode)

View File

@@ -36,7 +36,8 @@ class TextureEditorContextObject : public QObject
Q_PROPERTY(bool hasAliasExport READ hasAliasExport NOTIFY hasAliasExportChanged)
Q_PROPERTY(bool hasActiveTimeline READ hasActiveTimeline NOTIFY hasActiveTimelineChanged)
Q_PROPERTY(bool hasQuick3DImport READ hasQuick3DImport WRITE setHasQuick3DImport NOTIFY hasQuick3DImportChanged)
Q_PROPERTY(bool hasModelSelection READ hasModelSelection WRITE setHasModelSelection NOTIFY hasModelSelectionChanged)
Q_PROPERTY(bool hasSingleModelSelection READ hasSingleModelSelection WRITE setHasSingleModelSelection
NOTIFY hasSingleModelSelectionChanged)
Q_PROPERTY(bool hasMaterialLibrary READ hasMaterialLibrary WRITE setHasMaterialLibrary NOTIFY hasMaterialLibraryChanged)
Q_PROPERTY(QQmlPropertyMap *backendValues READ backendValues WRITE setBackendValues NOTIFY backendValuesChanged)
@@ -91,8 +92,8 @@ public:
bool hasMaterialLibrary() const;
void setHasMaterialLibrary(bool b);
bool hasModelSelection() const;
void setHasModelSelection(bool b);
bool hasSingleModelSelection() const;
void setHasSingleModelSelection(bool b);
bool hasAliasExport() const { return m_aliasExport; }
@@ -124,7 +125,7 @@ signals:
void hasActiveTimelineChanged();
void hasQuick3DImportChanged();
void hasMaterialLibraryChanged();
void hasModelSelectionChanged();
void hasSingleModelSelectionChanged();
private:
QUrl m_specificsUrl;
@@ -148,7 +149,7 @@ private:
bool m_hasActiveTimeline = false;
bool m_hasQuick3DImport = false;
bool m_hasMaterialLibrary = false;
bool m_hasModelSelection = false;
bool m_hasSingleModelSelection = false;
ModelNode m_selectedTexture;
};

View File

@@ -451,6 +451,8 @@ void TextureEditorView::setupQmlBackend()
currentQmlBackend->contextObject()->setHasQuick3DImport(m_hasQuick3DImport);
currentQmlBackend->contextObject()->setHasMaterialLibrary(materialLibraryNode().isValid());
currentQmlBackend->contextObject()->setSpecificQmlData(specificQmlData);
bool hasValidSelection = QmlObjectNode(m_selectedModel).hasBindingProperty("materials");
currentQmlBackend->contextObject()->setHasSingleModelSelection(hasValidSelection);
m_qmlBackEnd = currentQmlBackend;
@@ -554,6 +556,11 @@ void TextureEditorView::propertiesRemoved(const QList<AbstractProperty> &propert
setValue(m_selectedTexture, property.name(), QmlObjectNode(m_selectedTexture).instanceValue(property.name()));
}
if (property.name() == "materials" && (node == m_selectedModel
|| QmlObjectNode(m_selectedModel).propertyChangeForCurrentState() == node)) {
m_qmlBackEnd->contextObject()->setHasSingleModelSelection(false);
}
dynamicPropertiesModel()->dispatchPropertyChanges(property);
}
}
@@ -598,6 +605,12 @@ void TextureEditorView::bindingPropertiesChanged(const QList<BindingProperty> &p
setValue(m_selectedTexture, property.name(), QmlObjectNode(m_selectedTexture).modelValue(property.name()));
}
if (property.name() == "materials" && (node == m_selectedModel
|| QmlObjectNode(m_selectedModel).propertyChangeForCurrentState() == node)) {
bool hasMaterials = QmlObjectNode(m_selectedModel).hasBindingProperty("materials");
m_qmlBackEnd->contextObject()->setHasSingleModelSelection(hasMaterials);
}
dynamicPropertiesModel()->dispatchPropertyChanges(property);
}
}
@@ -660,7 +673,8 @@ void TextureEditorView::selectedNodesChanged(const QList<ModelNode> &selectedNod
if (selectedNodeList.size() == 1 && selectedNodeList.at(0).metaInfo().isQtQuick3DModel())
m_selectedModel = selectedNodeList.at(0);
m_qmlBackEnd->contextObject()->setHasModelSelection(m_selectedModel.isValid());
bool hasValidSelection = QmlObjectNode(m_selectedModel).hasBindingProperty("materials");
m_qmlBackEnd->contextObject()->setHasSingleModelSelection(hasValidSelection);
}
void TextureEditorView::currentStateChanged(const ModelNode &node)

View File

@@ -69,6 +69,7 @@ public:
QVariant modelValue(const PropertyName &name) const;
bool isTranslatableText(const PropertyName &name) const;
QString stripedTranslatableText(const PropertyName &name) const;
BindingProperty bindingProperty(const PropertyName &name) const;
QString expression(const PropertyName &name) const;
bool isInBaseState() const;
bool timelineIsActive() const;

View File

@@ -256,23 +256,28 @@ QString QmlObjectNode::stripedTranslatableText(const PropertyName &name) const
return instanceValue(name).toString();
}
QString QmlObjectNode::expression(const PropertyName &name) const
BindingProperty QmlObjectNode::bindingProperty(const PropertyName &name) const
{
if (!isValid())
return {};
if (currentState().isBaseState())
return modelNode().bindingProperty(name).expression();
return modelNode().bindingProperty(name);
if (!currentState().hasPropertyChanges(modelNode()))
return modelNode().bindingProperty(name).expression();
return modelNode().bindingProperty(name);
QmlPropertyChanges propertyChanges(currentState().propertyChanges(modelNode()));
if (!propertyChanges.modelNode().hasProperty(name))
return modelNode().bindingProperty(name).expression();
return modelNode().bindingProperty(name);
return propertyChanges.modelNode().bindingProperty(name).expression();
return propertyChanges.modelNode().bindingProperty(name);
}
QString QmlObjectNode::expression(const PropertyName &name) const
{
return bindingProperty(name).expression();
}
/*!