refactor(new_editor): continue architecture closeout

This commit is contained in:
2026-04-15 22:47:42 +08:00
parent a458f2838c
commit dde03c5241
225 changed files with 4214 additions and 5196 deletions

View File

@@ -1,10 +1,10 @@
#include "Platform/Win32/EditorWindowManager.h"
#include "Platform/Win32/WindowManager/Internal.h"
#include "Platform/Win32/EditorWindow.h"
namespace XCEngine::UI::Editor::App {
namespace XCEngine::UI::Editor::App::Internal {
EditorWindow* EditorWindowManager::FindWindow(HWND hwnd) {
EditorWindow* EditorWindowHostRuntime::FindWindow(HWND hwnd) {
if (hwnd == nullptr) {
return nullptr;
}
@@ -18,11 +18,11 @@ EditorWindow* EditorWindowManager::FindWindow(HWND hwnd) {
return nullptr;
}
const EditorWindow* EditorWindowManager::FindWindow(HWND hwnd) const {
return const_cast<EditorWindowManager*>(this)->FindWindow(hwnd);
const EditorWindow* EditorWindowHostRuntime::FindWindow(HWND hwnd) const {
return const_cast<EditorWindowHostRuntime*>(this)->FindWindow(hwnd);
}
EditorWindow* EditorWindowManager::FindWindow(std::string_view windowId) {
EditorWindow* EditorWindowHostRuntime::FindWindow(std::string_view windowId) {
if (windowId.empty()) {
return nullptr;
}
@@ -36,11 +36,11 @@ EditorWindow* EditorWindowManager::FindWindow(std::string_view windowId) {
return nullptr;
}
const EditorWindow* EditorWindowManager::FindWindow(std::string_view windowId) const {
return const_cast<EditorWindowManager*>(this)->FindWindow(windowId);
const EditorWindow* EditorWindowHostRuntime::FindWindow(std::string_view windowId) const {
return const_cast<EditorWindowHostRuntime*>(this)->FindWindow(windowId);
}
EditorWindow* EditorWindowManager::FindPrimaryWindow() {
EditorWindow* EditorWindowHostRuntime::FindPrimaryWindow() {
for (const std::unique_ptr<EditorWindow>& window : m_windows) {
if (window != nullptr && window->IsPrimary()) {
return window.get();
@@ -50,49 +50,8 @@ EditorWindow* EditorWindowManager::FindPrimaryWindow() {
return nullptr;
}
const EditorWindow* EditorWindowManager::FindPrimaryWindow() const {
return const_cast<EditorWindowManager*>(this)->FindPrimaryWindow();
const EditorWindow* EditorWindowHostRuntime::FindPrimaryWindow() const {
return const_cast<EditorWindowHostRuntime*>(this)->FindPrimaryWindow();
}
EditorWindow* EditorWindowManager::FindTopmostWindowAtScreenPoint(
const POINT& screenPoint,
std::string_view excludedWindowId) {
if (const HWND hitWindow = WindowFromPoint(screenPoint); hitWindow != nullptr) {
const HWND rootWindow = GetAncestor(hitWindow, GA_ROOT);
if (EditorWindow* window = FindWindow(rootWindow);
window != nullptr &&
window->GetWindowId() != excludedWindowId) {
return window;
}
}
for (auto it = m_windows.rbegin(); it != m_windows.rend(); ++it) {
EditorWindow* const window = it->get();
if (window == nullptr ||
window->GetHwnd() == nullptr ||
window->GetWindowId() == excludedWindowId) {
continue;
}
RECT windowRect = {};
if (GetWindowRect(window->GetHwnd(), &windowRect) &&
screenPoint.x >= windowRect.left &&
screenPoint.x < windowRect.right &&
screenPoint.y >= windowRect.top &&
screenPoint.y < windowRect.bottom) {
return window;
}
}
return nullptr;
}
const EditorWindow* EditorWindowManager::FindTopmostWindowAtScreenPoint(
const POINT& screenPoint,
std::string_view excludedWindowId) const {
return const_cast<EditorWindowManager*>(this)->FindTopmostWindowAtScreenPoint(
screenPoint,
excludedWindowId);
}
} // namespace XCEngine::UI::Editor::App
} // namespace XCEngine::UI::Editor::App::Internal