Refactor editor windowing and update renderer regression
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
#pragma once
|
||||
|
||||
#include "Platform/Win32/Windowing/EditorWindowManager.h"
|
||||
#include "Platform/Win32/Windowing/EditorWindow.h"
|
||||
#include "Platform/Win32/Windowing/EditorWindowHostConfig.h"
|
||||
#include "Windowing/Host/EditorWindowHostInterfaces.h"
|
||||
|
||||
#include <XCEditor/Workspace/UIEditorWorkspaceController.h>
|
||||
|
||||
@@ -16,41 +18,55 @@ class EditorWindow;
|
||||
class EditorWindowContentController;
|
||||
class EditorWindowContentFactory;
|
||||
class EditorWindowLifecycleCoordinator;
|
||||
class EditorWindowSystem;
|
||||
class EditorUtilityWindowCoordinator;
|
||||
class EditorWindowWorkspaceCoordinator;
|
||||
struct EditorUtilityWindowDescriptor;
|
||||
|
||||
class EditorWindowHostRuntime final {
|
||||
class EditorWindowHostRuntime final : public EditorWindowHost {
|
||||
public:
|
||||
using CreateParams = EditorWindowManager::CreateParams;
|
||||
|
||||
EditorWindowHostRuntime(
|
||||
EditorWindowHostConfig hostConfig,
|
||||
std::filesystem::path repoRoot,
|
||||
EditorContext& editorContext,
|
||||
EditorWindowSystem& windowSystem,
|
||||
EditorWindowContentFactory& contentFactory);
|
||||
~EditorWindowHostRuntime();
|
||||
|
||||
EditorWindow* CreateEditorWindow(
|
||||
std::unique_ptr<EditorWindowContentController> contentController,
|
||||
const CreateParams& params);
|
||||
const EditorWindowCreateParams& params);
|
||||
EditorWindow* CreateWorkspaceWindow(
|
||||
UIEditorWorkspaceController workspaceController,
|
||||
const CreateParams& params);
|
||||
const EditorWindowCreateParams& params) override;
|
||||
EditorWindow* CreateUtilityWindow(
|
||||
const EditorUtilityWindowDescriptor& descriptor,
|
||||
const CreateParams& params);
|
||||
const EditorWindowCreateParams& params) override;
|
||||
void BindLifecycleCoordinator(EditorWindowLifecycleCoordinator& lifecycleCoordinator);
|
||||
void HandlePendingNativeWindowCreated(HWND hwnd);
|
||||
|
||||
EditorWindow* FindWindow(HWND hwnd);
|
||||
const EditorWindow* FindWindow(HWND hwnd) const;
|
||||
EditorWindow* FindWindow(std::string_view windowId);
|
||||
const EditorWindow* FindWindow(std::string_view windowId) const;
|
||||
EditorHostWindow* FindWindowById(std::string_view windowId) override;
|
||||
const EditorHostWindow* FindWindowById(std::string_view windowId) const override;
|
||||
EditorWindow* FindPrimaryWindow();
|
||||
const EditorWindow* FindPrimaryWindow() const;
|
||||
|
||||
bool HasWindows() const;
|
||||
std::vector<EditorHostWindow*> GetWindows() override;
|
||||
std::vector<const EditorHostWindow*> GetWindows() const override;
|
||||
std::wstring_view GetPrimaryWindowTitle() const override;
|
||||
bool TryGetCursorScreenPoint(EditorWindowScreenPoint& outPoint) const override;
|
||||
EditorWindowScreenRect ResolveFloatingPlacement(
|
||||
const EditorWindowScreenPoint& screenPoint,
|
||||
int preferredWidth,
|
||||
int preferredHeight) const override;
|
||||
EditorHostWindow* FindWindowFromScreenPoint(
|
||||
const EditorWindowScreenPoint& screenPoint) override;
|
||||
const EditorHostWindow* FindWindowFromScreenPoint(
|
||||
const EditorWindowScreenPoint& screenPoint) const override;
|
||||
void ReapDestroyedWindows() override;
|
||||
std::string DescribeWindows() const override;
|
||||
void RenderAllWindows(
|
||||
bool globalTabDragActive,
|
||||
EditorWindowWorkspaceCoordinator& workspaceCoordinator,
|
||||
@@ -72,22 +88,24 @@ public:
|
||||
return m_repoRoot;
|
||||
}
|
||||
|
||||
std::vector<std::unique_ptr<EditorWindow>>& GetWindows() {
|
||||
std::vector<std::unique_ptr<EditorWindow>>& GetWindowStorage() {
|
||||
return m_windows;
|
||||
}
|
||||
|
||||
const std::vector<std::unique_ptr<EditorWindow>>& GetWindows() const {
|
||||
const std::vector<std::unique_ptr<EditorWindow>>& GetWindowStorage() const {
|
||||
return m_windows;
|
||||
}
|
||||
|
||||
void LogRuntimeTrace(std::string_view channel, std::string_view message) const;
|
||||
void LogRuntimeTrace(std::string_view channel, std::string_view message) const override;
|
||||
|
||||
private:
|
||||
friend class EditorWindowLifecycleCoordinator;
|
||||
EditorWindow* FindWindowByIdImpl(std::string_view windowId);
|
||||
const EditorWindow* FindWindowByIdImpl(std::string_view windowId) const;
|
||||
|
||||
EditorWindowHostConfig m_hostConfig = {};
|
||||
std::filesystem::path m_repoRoot = {};
|
||||
EditorContext& m_editorContext;
|
||||
EditorWindowSystem& m_windowSystem;
|
||||
EditorWindowContentFactory& m_contentFactory;
|
||||
std::vector<std::unique_ptr<EditorWindow>> m_windows = {};
|
||||
EditorWindow* m_pendingCreateWindow = nullptr;
|
||||
|
||||
Reference in New Issue
Block a user