TabStrip.cpp 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. /*
  2. GWEN
  3. Copyright (c) 2010 Facepunch Studios
  4. See license in Gwen.h
  5. */
  6. #include "Gwen/Gwen.h"
  7. #include "Gwen/Skin.h"
  8. #include "Gwen/Controls/TabStrip.h"
  9. #include "Gwen/Controls/TabControl.h"
  10. #include "Gwen/Controls/Highlight.h"
  11. #include "Gwen/DragAndDrop.h"
  12. #include "Gwen/Utility.h"
  13. using namespace Gwen;
  14. using namespace Gwen::Controls;
  15. GWEN_CONTROL_CONSTRUCTOR( TabStrip )
  16. {
  17. m_TabDragControl = NULL;
  18. m_bAllowReorder = false;
  19. }
  20. bool TabStrip::DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* /*pPackage*/, int x, int y )
  21. {
  22. Gwen::Point LocalPos = CanvasPosToLocal( Gwen::Point( x, y ) );
  23. Base* el = DragAndDrop::SourceControl;
  24. TabButton* pButton = el? el->DynamicCastTabButton() : 0;
  25. TabControl* pTabControl = GetParent()? GetParent()->DynamicCastTabControl() : 0;
  26. if ( pTabControl && pButton )
  27. {
  28. if ( pButton->GetTabControl() != pTabControl )
  29. {
  30. // We've moved tab controls!
  31. pTabControl->AddPage( pButton );
  32. }
  33. }
  34. Base* DroppedOn = GetControlAt( LocalPos.x, LocalPos.y );
  35. if ( DroppedOn )
  36. {
  37. Gwen::Point DropPos = DroppedOn->CanvasPosToLocal( Gwen::Point( x, y ) );
  38. DragAndDrop::SourceControl->BringNextToControl( DroppedOn, DropPos.x > DroppedOn->Width() / 2 );
  39. }
  40. else
  41. {
  42. DragAndDrop::SourceControl->BringToFront();
  43. }
  44. return true;
  45. }
  46. bool TabStrip::DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* pPackage )
  47. {
  48. if ( !m_bAllowReorder )
  49. return false;
  50. if ( pPackage->name == "TabButtonMove" )
  51. return true;
  52. return false;
  53. }
  54. void TabStrip::Layout( Skin::Base* skin )
  55. {
  56. Gwen::Point pLargestTab( 5, 5 );
  57. int iNum = 0;
  58. for ( Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter )
  59. {
  60. if (!*iter)
  61. continue;
  62. TabButton* pButton = (*iter)->DynamicCastTabButton();
  63. if ( !pButton ) continue;
  64. pButton->SizeToContents();
  65. Margin m;
  66. int iActive = pButton->IsActive() ? 0 : 2;
  67. int iNotFirst = iNum > 0 ? -1 : 0;
  68. int iControlOverhang = -3;
  69. if ( m_iDock == Pos::Top )
  70. {
  71. m.top = iActive;
  72. m.left = iNotFirst;
  73. m.bottom = iControlOverhang;
  74. pButton->Dock( Pos::Left );
  75. }
  76. if ( m_iDock == Pos::Left )
  77. {
  78. m.left = iActive * 2;
  79. m.right = iControlOverhang;
  80. m.top = iNotFirst;
  81. pButton->Dock( Pos::Top );
  82. }
  83. if ( m_iDock == Pos::Right )
  84. {
  85. m.right = iActive * 2;
  86. m.left = iControlOverhang;
  87. m.top = iNotFirst;
  88. pButton->Dock( Pos::Top );
  89. }
  90. if ( m_iDock == Pos::Bottom )
  91. {
  92. m.bottom = iActive;
  93. m.left = iNotFirst;
  94. m.top = iControlOverhang;
  95. pButton->Dock( Pos::Left );
  96. }
  97. pLargestTab.x = Utility::Max( pLargestTab.x, pButton->Width() );
  98. pLargestTab.y = Utility::Max( pLargestTab.y, pButton->Height() );
  99. pButton->SetMargin( m );
  100. iNum++;
  101. }
  102. if ( m_iDock == Pos::Top || m_iDock == Pos::Bottom )
  103. SetSize( Width(), pLargestTab.y );
  104. if ( m_iDock == Pos::Left || m_iDock == Pos::Right )
  105. SetSize( pLargestTab.x, Height() );
  106. BaseClass::Layout( skin );
  107. }
  108. void TabStrip::DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ )
  109. {
  110. if ( m_TabDragControl )
  111. {
  112. Debug::Msg( "ERROR! TabStrip::DragAndDrop_HoverEnter\n" );
  113. }
  114. m_TabDragControl = new ControlsInternal::Highlight( this );
  115. m_TabDragControl->SetMouseInputEnabled( false );
  116. m_TabDragControl->SetSize( 3, Height() );
  117. }
  118. void TabStrip::DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* /*pPackage*/ )
  119. {
  120. delete m_TabDragControl;
  121. m_TabDragControl = NULL;
  122. }
  123. void TabStrip::DragAndDrop_Hover( Gwen::DragAndDrop::Package* /*pPackage*/, int x, int y )
  124. {
  125. Gwen::Point LocalPos = CanvasPosToLocal( Gwen::Point( x, y ) );
  126. Base* DroppedOn = GetControlAt( LocalPos.x, LocalPos.y );
  127. if ( DroppedOn && DroppedOn != this )
  128. {
  129. Gwen::Point DropPos = DroppedOn->CanvasPosToLocal( Gwen::Point( x, y ) );
  130. m_TabDragControl->SetBounds( Gwen::Rect( 0, 0, 3, Height() ) );
  131. m_TabDragControl->BringToFront();
  132. m_TabDragControl->SetPos( DroppedOn->X() - 1, 0 );
  133. if ( DropPos.x > DroppedOn->Width() / 2 )
  134. {
  135. m_TabDragControl->MoveBy( DroppedOn->Width()-1, 0 );
  136. }
  137. m_TabDragControl->Dock( Pos::None );
  138. }
  139. else
  140. {
  141. m_TabDragControl->Dock( Pos::Left );
  142. m_TabDragControl->BringToFront();
  143. }
  144. }
  145. void TabStrip::SetTabPosition( int iPos )
  146. {
  147. Dock( iPos );
  148. }