2
0

BsDockManagerLayout.cpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. #include "BsDockManagerLayout.h"
  2. #include "BsDockManagerLayoutRTTI.h"
  3. #include "BsEditorWidgetManager.h"
  4. namespace BansheeEngine
  5. {
  6. DockManagerLayout::Entry::Entry()
  7. :isLeaf(true), splitPosition(0), horizontalSplit(false),
  8. parent(nullptr)
  9. {
  10. children[0] = nullptr;
  11. children[1] = nullptr;
  12. }
  13. DockManagerLayout::Entry::~Entry()
  14. { }
  15. DockManagerLayout::Entry* DockManagerLayout::Entry::createLeaf(Entry* parent, UINT32 childIdx,
  16. const Vector<String>& widgetNames)
  17. {
  18. Entry* newEntry = bs_new<Entry>();
  19. newEntry->isLeaf = true;
  20. newEntry->parent = parent;
  21. if(parent != nullptr)
  22. parent->children[childIdx] = newEntry;
  23. newEntry->widgetNames = widgetNames;
  24. return newEntry;
  25. }
  26. DockManagerLayout::Entry* DockManagerLayout::Entry::createContainer(Entry* parent, UINT32 childIdx,
  27. float splitPosition, bool horizontalSplit)
  28. {
  29. Entry* newEntry = bs_new<Entry>();
  30. newEntry->isLeaf = false;
  31. newEntry->parent = parent;
  32. if(parent != nullptr)
  33. parent->children[childIdx] = newEntry;
  34. newEntry->horizontalSplit = horizontalSplit;
  35. newEntry->splitPosition = splitPosition;
  36. return newEntry;
  37. }
  38. DockManagerLayout::DockManagerLayout()
  39. :mIsMaximized(false)
  40. { }
  41. DockManagerLayout::~DockManagerLayout()
  42. {
  43. Stack<Entry*> todo;
  44. if(!mRootEntry.isLeaf)
  45. {
  46. todo.push(mRootEntry.children[0]);
  47. todo.push(mRootEntry.children[1]);
  48. }
  49. while(!todo.empty())
  50. {
  51. Entry* current = todo.top();
  52. todo.pop();
  53. if(!current->isLeaf)
  54. {
  55. todo.push(current->children[0]);
  56. todo.push(current->children[1]);
  57. }
  58. bs_delete(current);
  59. }
  60. }
  61. void DockManagerLayout::setIsMaximized(bool maximized, const Vector<String>& widgetNames)
  62. {
  63. mIsMaximized = maximized;
  64. mMaximizedWidgetNames = widgetNames;
  65. }
  66. void DockManagerLayout::pruneInvalidLeaves()
  67. {
  68. Stack<Entry*> layoutTodo;
  69. layoutTodo.push(&mRootEntry);
  70. while (!layoutTodo.empty())
  71. {
  72. Entry* curEntry = layoutTodo.top();
  73. layoutTodo.pop();
  74. if (!curEntry->isLeaf)
  75. {
  76. layoutTodo.push(curEntry->children[0]);
  77. layoutTodo.push(curEntry->children[1]);
  78. }
  79. else
  80. {
  81. for (INT32 i = 0; i < (INT32)curEntry->widgetNames.size(); i++)
  82. {
  83. if (!EditorWidgetManager::instance().isValidWidget(curEntry->widgetNames[i]))
  84. {
  85. curEntry->widgetNames.erase(curEntry->widgetNames.begin() + i);
  86. i--;
  87. }
  88. }
  89. if (curEntry->widgetNames.size() == 0)
  90. {
  91. Entry* parent = curEntry->parent;
  92. if (parent != nullptr)
  93. {
  94. Entry* newParent = parent->parent;
  95. Entry* otherChild = parent->children[0] == curEntry ? parent->children[1] : parent->children[0];
  96. if (newParent != nullptr)
  97. {
  98. if (newParent->children[0] == parent)
  99. newParent->children[0] = otherChild;
  100. else
  101. newParent->children[1] = otherChild;
  102. }
  103. otherChild->parent = newParent;
  104. bs_delete(parent);
  105. bs_delete(curEntry);
  106. }
  107. }
  108. }
  109. }
  110. for (INT32 i = 0; i < (INT32)mMaximizedWidgetNames.size(); i++)
  111. {
  112. if (!EditorWidgetManager::instance().isValidWidget(mMaximizedWidgetNames[i]))
  113. {
  114. mMaximizedWidgetNames.erase(mMaximizedWidgetNames.begin() + i);
  115. i--;
  116. }
  117. }
  118. }
  119. DockManagerLayoutPtr DockManagerLayout::clone()
  120. {
  121. std::function<void(Entry*, Entry*, Entry*)> cloneEntry = [&](Entry* toClone, Entry* parent, Entry* clone)
  122. {
  123. *clone = *toClone;
  124. clone->parent = parent;
  125. if (!toClone->isLeaf)
  126. {
  127. clone->children[0] = bs_new<Entry>();
  128. clone->children[1] = bs_new<Entry>();
  129. cloneEntry(toClone->children[0], clone, clone->children[0]);
  130. cloneEntry(toClone->children[1], clone, clone->children[1]);
  131. }
  132. };
  133. DockManagerLayoutPtr copy = bs_shared_ptr_new<DockManagerLayout>();
  134. cloneEntry(&mRootEntry, nullptr, &copy->mRootEntry);
  135. return copy;
  136. }
  137. /************************************************************************/
  138. /* RTTI */
  139. /************************************************************************/
  140. RTTITypeBase* DockManagerLayout::getRTTIStatic()
  141. {
  142. return DockManagerLayoutRTTI::instance();
  143. }
  144. RTTITypeBase* DockManagerLayout::getRTTI() const
  145. {
  146. return DockManagerLayout::getRTTIStatic();
  147. }
  148. }