CmEditorWindowManager.cpp 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. #include "CmEditorWindowManager.h"
  2. #include "CmEditorApplication.h"
  3. #include "CmQtEditorWindow.h"
  4. #include "CmEditorWidgetFactory.h"
  5. #include "CmWindowDockManager.h"
  6. #include "CmEditorPrefs.h"
  7. #include "CmException.h"
  8. #include "CmQtEditor.h"
  9. #include <boost/bind.hpp>
  10. namespace CamelotEditor
  11. {
  12. EditorWindowManager::EditorWindowManager()
  13. :mMaxOpenWindowId(0)
  14. { }
  15. void EditorWindowManager::registerWidgetFactory(EditorWidgetFactory* factory)
  16. {
  17. assert(factory != nullptr);
  18. mFactories[factory->getWindowName()] = factory;
  19. }
  20. void EditorWindowManager::openWidget(const QString& name, QtEditorWindow* parent)
  21. {
  22. auto iterFind = mOpenWidgets.find(name);
  23. if(iterFind != mOpenWidgets.end())
  24. return; // Widget already open
  25. EditorWidgetFactory* factory = getFactory(name);
  26. if(parent == nullptr)
  27. parent = openWindow();
  28. QtEditorWidget* widget = factory->create(parent);
  29. parent->addWidget(widget);
  30. mOpenWidgets[name] = widget;
  31. }
  32. boost::function<void()> EditorWindowManager::getOpenCallback(const QString& name)
  33. {
  34. return boost::bind(&EditorWindowManager::openWidget, this, name, nullptr);
  35. }
  36. QtEditorWindow* EditorWindowManager::openWindow(UINT32 forcedId)
  37. {
  38. if(forcedId != -1)
  39. {
  40. auto iterFindId = mOpenWindows.find(forcedId);
  41. if(iterFindId != mOpenWindows.end())
  42. CM_EXCEPT(InvalidParametersException, "Window with the specified id already exists: " + toString(forcedId));
  43. }
  44. UINT32 windowId = 0;
  45. if(forcedId != -1)
  46. windowId = -1;
  47. else
  48. windowId = mMaxOpenWindowId;
  49. mMaxOpenWindowId = windowId + 1;
  50. QtEditorWindow* window = new QtEditorWindow(gEditorApp().getMainWindow(), windowId);
  51. mOpenWindows[windowId] = window;
  52. window->onClosed.connect(boost::bind(&EditorWindowManager::windowClosed, this, _1));
  53. window->setAttribute(Qt::WA_DeleteOnClose, true);
  54. window->show();
  55. return window;
  56. }
  57. QtEditorWindow* EditorWindowManager::getOpenWindow(INT32 id) const
  58. {
  59. auto iterFind = mOpenWindows.find(id);
  60. if(iterFind == mOpenWindows.end())
  61. CM_EXCEPT(InvalidParametersException, "There is no open window with id " + toString(id) + ".");
  62. return iterFind->second;
  63. }
  64. void EditorWindowManager::restoreWindowsFromPrefs()
  65. {
  66. vector<WindowLayoutDesc>::type windowLayouts = gEditorPrefs().getWindowLayouts();
  67. UINT32 parentId = -1;
  68. bool foundDockedWindow = true;
  69. while(foundDockedWindow)
  70. {
  71. foundDockedWindow = false;
  72. for(auto iter = windowLayouts.begin(); iter != windowLayouts.end(); ++iter)
  73. {
  74. if(iter->dockState != WDS_FLOATING && iter->dockParentId == parentId)
  75. {
  76. QtEditorWindow* window = openWindow(iter->id);
  77. window->restoreFromLayoutDesc(*iter);
  78. parentId = window->getId();
  79. foundDockedWindow = true;
  80. break;
  81. }
  82. }
  83. }
  84. // Open non-docked windows
  85. for(auto iter = windowLayouts.begin(); iter != windowLayouts.end(); ++iter)
  86. {
  87. if(iter->dockState == WDS_FLOATING)
  88. {
  89. QtEditorWindow* window = openWindow(iter->id);
  90. window->restoreFromLayoutDesc(*iter);
  91. }
  92. }
  93. }
  94. void EditorWindowManager::saveWindowsToPrefs()
  95. {
  96. vector<WindowLayoutDesc>::type windowLayouts;
  97. for(auto iter = mOpenWindows.begin(); iter != mOpenWindows.end(); ++iter)
  98. {
  99. windowLayouts.push_back(iter->second->getLayoutDesc());
  100. }
  101. gEditorPrefs().setWindowLayouts(windowLayouts);
  102. }
  103. vector<QString>::type EditorWindowManager::getAvailableWindowTypes() const
  104. {
  105. vector<QString>::type types;
  106. for(auto iter = mFactories.begin(); iter != mFactories.end(); ++iter)
  107. {
  108. types.push_back(iter->first);
  109. }
  110. return types;
  111. }
  112. EditorWidgetFactory* EditorWindowManager::getFactory(const QString& name) const
  113. {
  114. auto iterFind = mFactories.find(name);
  115. if(iterFind == mFactories.end())
  116. CM_EXCEPT(InvalidParametersException, "Window with the name: \"" + name.toStdString() + "\" doesn't exist.");
  117. return iterFind->second;
  118. }
  119. void EditorWindowManager::windowClosed(QtEditorWindow* window)
  120. {
  121. assert(window != nullptr);
  122. auto iterFind = mOpenWindows.find(window->getId());
  123. if(iterFind == mOpenWindows.end())
  124. CM_EXCEPT(InternalErrorException, "Trying to close a window " + toString(window->getId()) + " that is not in the open window list.");
  125. assert(iterFind->second == window);
  126. mOpenWindows.erase(iterFind);
  127. }
  128. EditorWindowManager& gEditorWindowManager()
  129. {
  130. return EditorWindowManager::instance();
  131. }
  132. }