/* * Copyright (c) Contributors to the Open 3D Engine Project. * For complete copyright and license terms please see the LICENSE at the root of this distribution. * * SPDX-License-Identifier: Apache-2.0 OR MIT * */ #include #include #include #include #include #include #include namespace PassCanvas { PassCanvasMainWindow::PassCanvasMainWindow( const AZ::Crc32& toolId, AtomToolsFramework::GraphViewSettingsPtr graphViewSettingsPtr, QWidget* parent) : Base(toolId, "PassCanvasMainWindow", parent) , m_graphViewSettingsPtr(graphViewSettingsPtr) , m_styleManager(toolId, graphViewSettingsPtr->m_styleManagerPath) { m_assetBrowser->GetSearchWidget()->SetFilterState("", AZ::RPI::StreamingImageAsset::Group, true); m_assetBrowser->GetSearchWidget()->SetFilterState("", AZ::RPI::PassAsset::Group, true); m_documentInspector = new AtomToolsFramework::AtomToolsDocumentInspector(m_toolId, this); m_documentInspector->SetDocumentSettingsPrefix("/O3DE/Atom/PassCanvas/DocumentInspector"); AddDockWidget("Inspector", m_documentInspector, Qt::RightDockWidgetArea); // Set up the toolbar that controls the viewport settings m_toolBar = new AtomToolsFramework::EntityPreviewViewportToolBar(m_toolId, this); // Create the dockable viewport widget that will be shared between all Pass Canvas documents m_passViewport = new AtomToolsFramework::EntityPreviewViewportWidget(m_toolId, this); // Initialize the entity context that will be used to create all of the entities displayed in the viewport auto entityContext = AZStd::make_shared(); entityContext->InitContext(); // Initialize the atom scene and pipeline that will bind to the viewport window to render entities and presets auto viewportScene = AZStd::make_shared( m_toolId, m_passViewport, entityContext, "PassCanvasViewportWidget", "passes/mainrenderpipeline.azasset"); // Viewport content will instantiate all of the entities that will be displayed and controlled by the viewport auto viewportContent = AZStd::make_shared(m_toolId, m_passViewport, entityContext); // The input controller creates and binds input behaviors to control viewport objects auto viewportController = AZStd::make_shared(m_toolId, m_passViewport, viewportContent); // Inject the entity context, scene, content, and controller into the viewport widget m_passViewport->Init(entityContext, viewportScene, viewportContent, viewportController); // Combine the shared toolbar in viewport into stacked widget that will be docked as a single view auto viewPortAndToolbar = new QWidget(this); viewPortAndToolbar->setLayout(new QVBoxLayout(viewPortAndToolbar)); viewPortAndToolbar->layout()->setContentsMargins(0, 0, 0, 0); viewPortAndToolbar->layout()->setMargin(0); viewPortAndToolbar->layout()->setSpacing(0); viewPortAndToolbar->layout()->addWidget(m_toolBar); viewPortAndToolbar->layout()->addWidget(m_passViewport); AddDockWidget("Viewport", viewPortAndToolbar, Qt::BottomDockWidgetArea); m_viewportSettingsInspector = new AtomToolsFramework::EntityPreviewViewportSettingsInspector(m_toolId, this); AddDockWidget("Viewport Settings", m_viewportSettingsInspector, Qt::LeftDockWidgetArea); SetDockWidgetVisible("Viewport Settings", false); m_bookmarkDockWidget = aznew GraphCanvas::BookmarkDockWidget(m_toolId, this); AddDockWidget("Bookmarks", m_bookmarkDockWidget, Qt::BottomDockWidgetArea); SetDockWidgetVisible("Bookmarks", false); AddDockWidget("MiniMap", aznew GraphCanvas::MiniMapDockWidget(m_toolId, this), Qt::BottomDockWidgetArea); SetDockWidgetVisible("MiniMap", false); GraphCanvas::NodePaletteConfig nodePaletteConfig; nodePaletteConfig.m_rootTreeItem = m_graphViewSettingsPtr->m_createNodeTreeItemsFn(m_toolId); nodePaletteConfig.m_editorId = m_toolId; nodePaletteConfig.m_mimeType = m_graphViewSettingsPtr->m_nodeMimeType.c_str(); nodePaletteConfig.m_isInContextMenu = false; nodePaletteConfig.m_saveIdentifier = m_graphViewSettingsPtr->m_nodeSaveIdentifier; m_nodePalette = aznew GraphCanvas::NodePaletteDockWidget(this, "Node Palette", nodePaletteConfig); AddDockWidget("Node Palette", m_nodePalette, Qt::LeftDockWidgetArea); AZ::IO::FixedMaxPath resolvedPath; AZ::IO::FileIOBase::GetInstance()->ReplaceAlias(resolvedPath, m_graphViewSettingsPtr->m_translationPath.c_str()); const AZ::IO::FixedMaxPathString translationFilePath = resolvedPath.LexicallyNormal().FixedMaxPathString(); if (m_translator.load(QLocale::Language::English, translationFilePath.c_str())) { if (!qApp->installTranslator(&m_translator)) { AZ_Warning("PassCanvas", false, "Error installing translation %s!", translationFilePath.c_str()); } } else { AZ_Warning("PassCanvas", false, "Error loading translation file %s", translationFilePath.c_str()); } // Set up style sheet to fix highlighting in the node palette AzQtComponents::StyleManager::setStyleSheet(this, QStringLiteral(":/GraphView/GraphView.qss")); OnDocumentOpened(AZ::Uuid::CreateNull()); } void PassCanvasMainWindow::OnDocumentOpened(const AZ::Uuid& documentId) { Base::OnDocumentOpened(documentId); m_documentInspector->SetDocumentId(documentId); } void PassCanvasMainWindow::ResizeViewportRenderTarget(uint32_t width, uint32_t height) { QSize requestedViewportSize = QSize(width, height) / devicePixelRatioF(); QSize currentViewportSize = m_passViewport->size(); QSize offset = requestedViewportSize - currentViewportSize; QSize requestedWindowSize = size() + offset; resize(requestedWindowSize); AZ_Assert( m_passViewport->size() == requestedViewportSize, "Resizing the window did not give the expected viewport size. Requested %d x %d but got %d x %d.", requestedViewportSize.width(), requestedViewportSize.height(), m_passViewport->size().width(), m_passViewport->size().height()); [[maybe_unused]] QSize newDeviceSize = m_passViewport->size(); AZ_Warning( "Pass Canvas", static_cast(newDeviceSize.width()) == width && static_cast(newDeviceSize.height()) == height, "Resizing the window did not give the expected frame size. Requested %d x %d but got %d x %d.", width, height, newDeviceSize.width(), newDeviceSize.height()); } void PassCanvasMainWindow::LockViewportRenderTargetSize(uint32_t width, uint32_t height) { m_passViewport->LockRenderTargetSize(width, height); } void PassCanvasMainWindow::UnlockViewportRenderTargetSize() { m_passViewport->UnlockRenderTargetSize(); } void PassCanvasMainWindow::PopulateSettingsInspector(AtomToolsFramework::InspectorWidget* inspector) const { m_passCanvasCompileSettingsGroup = AtomToolsFramework::CreateSettingsPropertyGroup( "Pass Canvas Settings", "Pass Canvas Settings", { AtomToolsFramework::CreateSettingsPropertyValue( "/O3DE/Atom/PassCanvas/CreateDefaultDocumentOnStart", "Create Untitled Graph Document On Start", "Create a default, untitled graph document when Pass Canvas starts", true) }); inspector->AddGroup( m_passCanvasCompileSettingsGroup->m_name, m_passCanvasCompileSettingsGroup->m_displayName, m_passCanvasCompileSettingsGroup->m_description, new AtomToolsFramework::InspectorPropertyGroupWidget( m_passCanvasCompileSettingsGroup.get(), m_passCanvasCompileSettingsGroup.get(), azrtti_typeid())); inspector->AddGroup( "Graph View Settings", "Graph View Settings", "Configuration settings for the graph view interaction, animation, and other behavior.", new AtomToolsFramework::InspectorPropertyGroupWidget( m_graphViewSettingsPtr.get(), m_graphViewSettingsPtr.get(), m_graphViewSettingsPtr->RTTI_Type())); Base::PopulateSettingsInspector(inspector); } void PassCanvasMainWindow::OnSettingsDialogClosed() { AtomToolsFramework::SetSettingsObject("/O3DE/Atom/GraphView/ViewSettings", m_graphViewSettingsPtr); Base::OnSettingsDialogClosed(); } AZStd::string PassCanvasMainWindow::GetHelpUrl() const { return "https://docs.o3de.org/docs/atom-guide/look-dev/tools/"; } } // namespace PassCanvas #include