From 3ba1b100f20519753b01f12f52857c9336ab2e4a Mon Sep 17 00:00:00 2001 From: Don HO Date: Fri, 24 Feb 2017 03:14:47 +0100 Subject: [PATCH] Refactoring and clean up for tab interface --- .../src/ScitillaComponent/FindReplaceDlg.cpp | 2 +- .../WinControls/PluginsAdmin/pluginsAdmin.cpp | 2 +- .../src/WinControls/TabBar/ControlsTab.h | 4 +- PowerEditor/src/WinControls/TabBar/TabBar.cpp | 117 ++++++++---------- PowerEditor/src/WinControls/TabBar/TabBar.h | 5 +- 5 files changed, 55 insertions(+), 75 deletions(-) diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp index b8a38200e..6d983f30e 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp @@ -257,7 +257,7 @@ void FindReplaceDlg::create(int dialogID, bool isRTL) RECT rect; //::GetWindowRect(_hSelf, &rect); getClientRect(rect); - _tab.init(_hInst, _hSelf, false, false, true); + _tab.init(_hInst, _hSelf, false, true); int tabDpiDynamicalHeight = NppParameters::getInstance()->_dpiManager.scaleY(13); _tab.setFont(TEXT("Tahoma"), tabDpiDynamicalHeight); diff --git a/PowerEditor/src/WinControls/PluginsAdmin/pluginsAdmin.cpp b/PowerEditor/src/WinControls/PluginsAdmin/pluginsAdmin.cpp index 8b5b21b17..f71844e75 100644 --- a/PowerEditor/src/WinControls/PluginsAdmin/pluginsAdmin.cpp +++ b/PowerEditor/src/WinControls/PluginsAdmin/pluginsAdmin.cpp @@ -196,7 +196,7 @@ void PluginsAdminDlg::create(int dialogID, bool isRTL) RECT rect; getClientRect(rect); - _tab.init(_hInst, _hSelf, false, false, true); + _tab.init(_hInst, _hSelf, false, true); int tabDpiDynamicalHeight = NppParameters::getInstance()->_dpiManager.scaleY(13); _tab.setFont(TEXT("Tahoma"), tabDpiDynamicalHeight); diff --git a/PowerEditor/src/WinControls/TabBar/ControlsTab.h b/PowerEditor/src/WinControls/TabBar/ControlsTab.h index 286fbd59c..6dc60afa3 100644 --- a/PowerEditor/src/WinControls/TabBar/ControlsTab.h +++ b/PowerEditor/src/WinControls/TabBar/ControlsTab.h @@ -50,10 +50,10 @@ public : ControlsTab() = default; virtual ~ControlsTab() = default; - virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isTraditional = false, bool isMultiLine = false) + virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isMultiLine = false) { _isVertical = isVertical; - TabBar::init(hInst, hwnd, false, isTraditional, isMultiLine); + TabBar::init(hInst, hwnd, false, isMultiLine); } void createTabs(WindowVector & winVector); diff --git a/PowerEditor/src/WinControls/TabBar/TabBar.cpp b/PowerEditor/src/WinControls/TabBar/TabBar.cpp index f07a7eba7..83f76f5f7 100644 --- a/PowerEditor/src/WinControls/TabBar/TabBar.cpp +++ b/PowerEditor/src/WinControls/TabBar/TabBar.cpp @@ -54,11 +54,11 @@ COLORREF TabBarPlus::_inactiveBgColour = RGB(192, 192, 192); HWND TabBarPlus::_hwndArray[nbCtrlMax] = {NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL}; int TabBarPlus::_nbCtrl = 0; -void TabBar::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isTraditional, bool isMultiLine) +void TabBar::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isMultiLine) { Window::init(hInst, parent); int vertical = isVertical?(TCS_VERTICAL | TCS_MULTILINE | TCS_RIGHTJUSTIFY):0; - _isTraditional = isTraditional; + _isVertical = isVertical; _isMultiLine = isMultiLine; @@ -66,7 +66,7 @@ void TabBar::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isTraditio icce.dwSize = sizeof(icce); icce.dwICC = ICC_TAB_CLASSES; InitCommonControlsEx(&icce); - int multiLine = isMultiLine ? (_isTraditional ? TCS_MULTILINE : 0) : 0; + int multiLine = isMultiLine ? TCS_MULTILINE : 0; int style = WS_CHILD | WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_VISIBLE |\ TCS_FOCUSNEVER | TCS_TABS | WS_TABSTOP | vertical | multiLine; @@ -215,48 +215,33 @@ void TabBar::reSizeTo(RECT & rc2Ajust) rowCount = TabCtrl_GetRowCount(_hSelf); TabCtrl_GetItemRect(_hSelf, 0, &rowRect); - if (_isTraditional) + + int larger = _isVertical ? rowRect.right : rowRect.bottom; + int smaller = _isVertical ? rowRect.left : rowRect.top; + int marge = 0; + + LONG_PTR style = ::GetWindowLongPtr(_hSelf, GWL_STYLE); + if (rowCount == 1) { - TabCtrl_AdjustRect(_hSelf, FALSE, &rc2Ajust); + style &= ~TCS_BUTTONS; } - else if (_isVertical) + else // (rowCount >= 2) { - LONG_PTR style = ::GetWindowLongPtr(_hSelf, GWL_STYLE); - if (rowCount == 1) - { - style &= ~TCS_BUTTONS; - } - else // (rowCount >= 2) - { - style |= TCS_BUTTONS; - } - ::SetWindowLongPtr(_hSelf, GWL_STYLE, style); - - const int marge = 3; // in TCS_BUTTONS mode, each row has few pixels higher - tabsHight = rowCount * (rowRect.right - rowRect.left + marge); - tabsHight += GetSystemMetrics(SM_CXEDGE); - - rc2Ajust.left += tabsHight; - rc2Ajust.right -= tabsHight; + style |= TCS_BUTTONS; + marge = 3; // in TCS_BUTTONS mode, each row has few pixels higher } - else //if (_isMultiLine) + + ::SetWindowLongPtr(_hSelf, GWL_STYLE, style); + tabsHight = rowCount * (larger - smaller + marge); + tabsHight += GetSystemMetrics(_isVertical ? SM_CXEDGE : SM_CYEDGE); + + if (_isVertical) + { + rc2Ajust.left += tabsHight; + rc2Ajust.right -= tabsHight; + } + else { - LONG_PTR style = ::GetWindowLongPtr(_hSelf, GWL_STYLE); - int marge = 0; - if (rowCount == 1) - { - style &= ~TCS_BUTTONS; - } - else // (rowCount >= 2) - { - style |= TCS_BUTTONS; - marge = 3; // in TCS_BUTTONS mode, each row has few pixels higher - } - - ::SetWindowLongPtr(_hSelf, GWL_STYLE, style); - tabsHight = rowCount * (rowRect.bottom - rowRect.top + marge); - tabsHight += GetSystemMetrics(SM_CYEDGE); - rc2Ajust.top += tabsHight; rc2Ajust.bottom -= tabsHight; } @@ -271,11 +256,10 @@ void TabBarPlus::destroy() } -void TabBarPlus::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isTraditional, bool isMultiLine) +void TabBarPlus::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isMultiLine) { Window::init(hInst, parent); int vertical = isVertical?(TCS_VERTICAL | TCS_MULTILINE | TCS_RIGHTJUSTIFY):0; - _isTraditional = isTraditional; _isVertical = isVertical; _isMultiLine = isMultiLine; @@ -283,7 +267,7 @@ void TabBarPlus::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isTrad icce.dwSize = sizeof(icce); icce.dwICC = ICC_TAB_CLASSES; InitCommonControlsEx(&icce); - int multiLine = isMultiLine ? (_isTraditional ? TCS_MULTILINE : 0) : 0; + int multiLine = isMultiLine ? TCS_MULTILINE : 0; int style = WS_CHILD | WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_VISIBLE | TCS_FOCUSNEVER | TCS_TABS | vertical | multiLine; @@ -322,34 +306,31 @@ void TabBarPlus::init(HINSTANCE hInst, HWND parent, bool isVertical, bool isTrad } ::SendMessage(_hSelf, TCM_SETTOOLTIPS, reinterpret_cast(_tooltips), 0); - if (!_isTraditional) - { - if (!_hwndArray[_nbCtrl]) + if (!_hwndArray[_nbCtrl]) + { + _hwndArray[_nbCtrl] = _hSelf; + _ctrlID = _nbCtrl; + } + else + { + int i = 0; + bool found = false; + for ( ; i < nbCtrlMax && !found ; ++i) + if (!_hwndArray[i]) + found = true; + if (!found) { - _hwndArray[_nbCtrl] = _hSelf; - _ctrlID = _nbCtrl; + _ctrlID = -1; + destroy(); + throw std::runtime_error("TabBarPlus::init : Tab Control error - Tab Control # is over its limit"); } - else - { - int i = 0; - bool found = false; - for ( ; i < nbCtrlMax && !found ; ++i) - if (!_hwndArray[i]) - found = true; - if (!found) - { - _ctrlID = -1; - destroy(); - throw std::runtime_error("TabBarPlus::init : Tab Control error - Tab Control # is over its limit"); - } - _hwndArray[i] = _hSelf; - _ctrlID = i; - } - ++_nbCtrl; + _hwndArray[i] = _hSelf; + _ctrlID = i; + } + ++_nbCtrl; - ::SetWindowLongPtr(_hSelf, GWLP_USERDATA, reinterpret_cast(this)); - _tabBarDefaultProc = reinterpret_cast(::SetWindowLongPtr(_hSelf, GWLP_WNDPROC, reinterpret_cast(TabBarPlus_Proc))); - } + ::SetWindowLongPtr(_hSelf, GWLP_USERDATA, reinterpret_cast(this)); + _tabBarDefaultProc = reinterpret_cast(::SetWindowLongPtr(_hSelf, GWLP_WNDPROC, reinterpret_cast(TabBarPlus_Proc))); LOGFONT LogFont; diff --git a/PowerEditor/src/WinControls/TabBar/TabBar.h b/PowerEditor/src/WinControls/TabBar/TabBar.h index 9cb4584a5..6211edc78 100644 --- a/PowerEditor/src/WinControls/TabBar/TabBar.h +++ b/PowerEditor/src/WinControls/TabBar/TabBar.h @@ -68,7 +68,7 @@ public: TabBar() : Window() {}; virtual ~TabBar() {}; virtual void destroy(); - virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isTraditional = false, bool isMultiLine = false); + virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isMultiLine = false); virtual void reSizeTo(RECT & rc2Ajust); int insertAtEnd(const TCHAR *subTabName); void activateAt(int index) const; @@ -115,7 +115,6 @@ protected: HFONT _hVerticalLargeFont = nullptr; int _ctrlID = 0; - bool _isTraditional = false; bool _isVertical = false; bool _isMultiLine = false; @@ -150,7 +149,7 @@ public : _doDragNDrop = justDoIt; }; - virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isTraditional = false, bool isMultiLine = false); + virtual void init(HINSTANCE hInst, HWND hwnd, bool isVertical = false, bool isMultiLine = false); virtual void destroy();