Refactor controls in Find & Replace dialog to improve compatibility with HiDPI

Close #14948
pull/14980/head
ozone10 2024-04-04 20:58:18 +02:00 committed by Don Ho
parent fc52cd3f4f
commit 5b8e13ab9b
2 changed files with 103 additions and 105 deletions

View File

@ -1336,72 +1336,6 @@ intptr_t CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARA
SendMessage(hComboBox, WM_SETFONT, (WPARAM)CreateFontIndirect(&lf), MAKELPARAM(true, 0)); SendMessage(hComboBox, WM_SETFONT, (WPARAM)CreateFontIndirect(&lf), MAKELPARAM(true, 0));
} }
RECT arc{};
::GetWindowRect(::GetDlgItem(_hSelf, IDCANCEL), &arc);
_markClosePos.bottom = _findInFilesClosePos.bottom = _replaceClosePos.bottom = _findClosePos.bottom = arc.bottom - arc.top;
_markClosePos.right = _findInFilesClosePos.right = _replaceClosePos.right = _findClosePos.right = arc.right - arc.left;
POINT p{};
p.x = arc.left;
p.y = arc.top;
::ScreenToClient(_hSelf, &p);
p = getTopPoint(::GetDlgItem(_hSelf, IDCANCEL), !_isRTL);
_replaceClosePos.left = p.x;
_replaceClosePos.top = p.y;
p = getTopPoint(::GetDlgItem(_hSelf, IDREPLACEALL), !_isRTL);
_findInFilesClosePos.left = p.x;
_findInFilesClosePos.top = p.y;
p = getTopPoint(::GetDlgItem(_hSelf, IDC_REPLACE_OPENEDFILES), !_isRTL);
_markClosePos.left = p.x;
_markClosePos.top = p.y;
p = getTopPoint(::GetDlgItem(_hSelf, IDCANCEL), !_isRTL);
_findClosePos.left = p.x;
_findClosePos.top = p.y + 10;
::GetWindowRect(::GetDlgItem(_hSelf, IDD_RESIZE_TOGGLE_BUTTON), &arc);
long resizeButtonW = arc.right - arc.left;
long resizeButtonH = arc.bottom - arc.top;
_collapseButtonPos.bottom = _uncollapseButtonPos.bottom = resizeButtonW;
_collapseButtonPos.right = _uncollapseButtonPos.right = resizeButtonH;
::GetWindowRect(::GetDlgItem(_hSelf, IDC_TRANSPARENT_GRPBOX), &arc);
p = getTopPoint(::GetDlgItem(_hSelf, IDC_TRANSPARENT_GRPBOX), !_isRTL);
_collapseButtonPos.left = p.x + (arc.right - arc.left) + dpiManager.scaleX(10);
_collapseButtonPos.top = p.y + (arc.bottom - arc.top) - resizeButtonH + dpiManager.scaleX(10);
::GetWindowRect(::GetDlgItem(_hSelf, IDCCOUNTALL), &arc);
p = getTopPoint(::GetDlgItem(_hSelf, IDCCOUNTALL), !_isRTL);
_uncollapseButtonPos.left = p.x + (arc.right - arc.left) + dpiManager.scaleX(8);
_uncollapseButtonPos.top = p.y + dpiManager.scaleY(2);
// in selection check
RECT checkRect;
::GetWindowRect(::GetDlgItem(_hSelf, IDC_IN_SELECTION_CHECK), &checkRect);
_countInSelCheckPos.bottom = _replaceInSelCheckPos.bottom = checkRect.bottom - checkRect.top;
_countInSelCheckPos.right = _replaceInSelCheckPos.right = checkRect.right - checkRect.left;
p = getTopPoint(::GetDlgItem(_hSelf, IDC_IN_SELECTION_CHECK), !_isRTL);
_countInSelCheckPos.left = _replaceInSelCheckPos.left = p.x;
_countInSelCheckPos.top = _replaceInSelCheckPos.top = p.y;
POINT countP = getTopPoint(::GetDlgItem(_hSelf, IDCCOUNTALL), !_isRTL);
// in selection Frame
RECT frameRect;
::GetWindowRect(::GetDlgItem(_hSelf, IDC_REPLACEINSELECTION), &frameRect);
_countInSelFramePos.bottom = _replaceInSelFramePos.bottom = frameRect.bottom - frameRect.top;
_countInSelFramePos.right = _replaceInSelFramePos.right = frameRect.right - frameRect.left;
p = getTopPoint(::GetDlgItem(_hSelf, IDC_REPLACEINSELECTION), !_isRTL);
_countInSelFramePos.left = _replaceInSelFramePos.left = p.x;
_countInSelFramePos.top = _replaceInSelFramePos.top = p.y;
_countInSelFramePos.top = countP.y - dpiManager.scaleY(10);
_countInSelFramePos.bottom = dpiManager.scaleY(80 - 3);
NativeLangSpeaker *pNativeSpeaker = (NppParameters::getInstance()).getNativeLangSpeaker(); NativeLangSpeaker *pNativeSpeaker = (NppParameters::getInstance()).getNativeLangSpeaker();
generic_string searchButtonTip = pNativeSpeaker->getLocalizedStrFromID("shift-change-direction-tip", TEXT("Use Shift+Enter to search in the opposite direction.")); generic_string searchButtonTip = pNativeSpeaker->getLocalizedStrFromID("shift-change-direction-tip", TEXT("Use Shift+Enter to search in the opposite direction."));
@ -2350,31 +2284,27 @@ intptr_t CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARA
case IDD_RESIZE_TOGGLE_BUTTON: case IDD_RESIZE_TOGGLE_BUTTON:
{ {
RECT rc = { 0, 0, 0, 0}; RECT rc{};
getWindowRect(rc); getWindowRect(rc);
int w = rc.right - rc.left; LONG w = rc.right - rc.left;
POINT p{};
p.x = rc.left;
p.y = rc.top;
bool& isLessModeOn = NppParameters::getInstance().getNppGUI()._findWindowLessMode; bool& isLessModeOn = NppParameters::getInstance().getNppGUI()._findWindowLessMode;
isLessModeOn = !isLessModeOn; isLessModeOn = !isLessModeOn;
long dlgH = isLessModeOn ? _lesssModeHeight : _initialWindowRect.bottom; long dlgH = isLessModeOn ? _lesssModeHeight : _initialWindowRect.bottom;
RECT& buttonRc = isLessModeOn ? _uncollapseButtonPos : _collapseButtonPos;
DIALOG_TYPE dlgT = getCurrentStatus();
calcAndSetCtrlsPos(dlgT, true);
// For unknown reason, the original default width doesn't make the status bar moveed // For unknown reason, the original default width doesn't make the status bar moveed
// Here we use a dirty workaround: increase 1 pixel so WM_SIZE message will be triggered // Here we use a dirty workaround: increase 1 pixel so WM_SIZE message will be triggered
if (w == _initialWindowRect.right) if (w == _initialWindowRect.right)
w += 1; w += 1;
::MoveWindow(_hSelf, p.x, p.y, w, dlgH, FALSE); // WM_SIZE message to call resizeDialogElements - status bar will be reposition correctly. ::SetWindowPos(_hSelf, nullptr, 0, 0, w, dlgH, SWP_NOMOVE | SWP_NOZORDER | SWP_NOREDRAW); // WM_SIZE message to call resizeDialogElements - status bar will be reposition correctly.
::MoveWindow(::GetDlgItem(_hSelf, IDD_RESIZE_TOGGLE_BUTTON), buttonRc.left + _deltaWidth, buttonRc.top, buttonRc.right, buttonRc.bottom, TRUE);
// Reposition the status bar // Reposition the status bar
const UINT flags = SWP_NOMOVE | SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOCOPYBITS | SWP_DRAWFRAME; constexpr UINT flags = SWP_NOMOVE | SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOCOPYBITS | SWP_FRAMECHANGED;
::GetClientRect(_statusBar.getHSelf(), &rc); ::GetClientRect(_statusBar.getHSelf(), &rc);
::SetWindowPos(_statusBar.getHSelf(), 0, 0, 0, rc.right + _deltaWidth, rc.bottom, flags); ::SetWindowPos(_statusBar.getHSelf(), nullptr, 0, 0, w, rc.bottom, flags);
DIALOG_TYPE dlgT = getCurrentStatus();
hideOrShowCtrl4reduceOrNormalMode(dlgT); hideOrShowCtrl4reduceOrNormalMode(dlgT);
@ -3532,10 +3462,7 @@ void FindReplaceDlg::showFindDlgItem(int dlgItemID, bool isShow /* = true*/)
void FindReplaceDlg::enableReplaceFunc(bool isEnable) void FindReplaceDlg::enableReplaceFunc(bool isEnable)
{ {
_currentStatus = isEnable?REPLACE_DLG:FIND_DLG; _currentStatus = isEnable ? REPLACE_DLG : FIND_DLG;
RECT *pClosePos = isEnable ? &_replaceClosePos : &_findClosePos;
RECT *pInSelectionFramePos = isEnable ? &_replaceInSelFramePos : &_countInSelFramePos;
RECT *pInSectionCheckPos = isEnable ? &_replaceInSelCheckPos : &_countInSelCheckPos;
enableFindInFilesControls(false, false); enableFindInFilesControls(false, false);
enableMarkAllControls(false); enableMarkAllControls(false);
@ -3561,10 +3488,7 @@ void FindReplaceDlg::enableReplaceFunc(bool isEnable)
showFindDlgItem(IDC_FINDALL_CURRENTFILE, !isEnable); showFindDlgItem(IDC_FINDALL_CURRENTFILE, !isEnable);
gotoCorrectTab(); gotoCorrectTab();
calcAndSetCtrlsPos(_currentStatus);
::MoveWindow(::GetDlgItem(_hSelf, IDCANCEL), pClosePos->left + _deltaWidth, pClosePos->top, pClosePos->right, pClosePos->bottom, TRUE);
::MoveWindow(::GetDlgItem(_hSelf, IDC_IN_SELECTION_CHECK), pInSectionCheckPos->left + _deltaWidth, pInSectionCheckPos->top, pInSectionCheckPos->right, pInSectionCheckPos->bottom, TRUE);
::MoveWindow(::GetDlgItem(_hSelf, IDC_REPLACEINSELECTION), pInSelectionFramePos->left + _deltaWidth, pInSelectionFramePos->top, pInSelectionFramePos->right, pInSelectionFramePos->bottom, TRUE);
TCHAR label[MAX_PATH] = { '\0' }; TCHAR label[MAX_PATH] = { '\0' };
_tab.getCurrentTitle(label, MAX_PATH); _tab.getCurrentTitle(label, MAX_PATH);
@ -4376,12 +4300,101 @@ void FindReplaceDlg::hideOrShowCtrl4reduceOrNormalMode(DIALOG_TYPE dlgT)
} }
} }
void FindReplaceDlg::calcAndSetCtrlsPos(DIALOG_TYPE dlgT, bool fromColBtn)
{
const bool isNotLessMode = !NppParameters::getInstance().getNppGUI()._findWindowLessMode;
RECT rcBtn2ndPos{};
RECT rcBtn3rdPos{};
getMappedChildRect(IDREPLACE, rcBtn2ndPos);
getMappedChildRect(IDREPLACEALL, rcBtn3rdPos);
const LONG btnGap = rcBtn3rdPos.top - rcBtn2ndPos.bottom;
constexpr UINT flags = SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOACTIVATE | SWP_NOCOPYBITS;
if (isNotLessMode)
{
const LONG btnGapDbl = 2 * btnGap;
const LONG btnGapOneHalf = 3 * btnGap / 2;
LONG yFrame = -btnGapOneHalf;
LONG hFrame = btnGapDbl;
RECT rcToUse{};
switch (dlgT)
{
case FIND_DLG:
{
getMappedChildRect(IDC_FINDALL_OPENEDFILES, rcToUse);
RECT rcBtn3rdPosLarge{};
getMappedChildRect(IDC_FINDALL_CURRENTFILE, rcBtn3rdPosLarge);
yFrame += rcBtn2ndPos.top;
hFrame += (rcBtn3rdPosLarge.bottom - rcBtn2ndPos.top);
break;
}
case REPLACE_DLG:
{
getMappedChildRect(IDC_REPLACE_OPENEDFILES, rcToUse);
yFrame += rcBtn3rdPos.top;
hFrame += (rcBtn3rdPos.bottom - rcBtn3rdPos.top);
break;
}
case FINDINFILES_DLG:
case FINDINPROJECTS_DLG:
{
rcToUse = rcBtn2ndPos;
break;
}
case MARK_DLG:
{
rcToUse = rcBtn3rdPos;
break;
}
}
::SetWindowPos(::GetDlgItem(_hSelf, IDCANCEL), nullptr, rcToUse.left, (rcToUse.bottom + btnGap), 0, 0, SWP_NOSIZE | flags);
if (dlgT == FIND_DLG || dlgT == REPLACE_DLG)
{
RECT rcCheckBtn{};
getMappedChildRect(IDC_IN_SELECTION_CHECK, rcCheckBtn);
const LONG xFrame = rcCheckBtn.left - btnGapOneHalf;
const LONG wFrame = (rcBtn2ndPos.right - rcCheckBtn.left) + btnGapDbl;
::SetWindowPos(::GetDlgItem(_hSelf, IDC_REPLACEINSELECTION), nullptr, xFrame, yFrame, wFrame, hFrame, flags);
}
}
if (fromColBtn)
{
LONG yColBtn = 0;
if (isNotLessMode)
{
RECT rcSlider{};
getMappedChildRect(IDC_PERCENTAGE_SLIDER, rcSlider);
yColBtn = rcSlider.top + btnGap;
}
else
{
yColBtn = rcBtn2ndPos.top + btnGap / 2;
}
::SetWindowPos(::GetDlgItem(_hSelf, IDD_RESIZE_TOGGLE_BUTTON), nullptr, rcBtn2ndPos.right + btnGap, yColBtn, 0, 0, SWP_NOSIZE | flags);
}
}
void FindReplaceDlg::enableFindInFilesFunc() void FindReplaceDlg::enableFindInFilesFunc()
{ {
enableFindInFilesControls(true, false); enableFindInFilesControls(true, false);
_currentStatus = FINDINFILES_DLG; _currentStatus = FINDINFILES_DLG;
gotoCorrectTab(); gotoCorrectTab();
::MoveWindow(::GetDlgItem(_hSelf, IDCANCEL), _findInFilesClosePos.left + _deltaWidth, _findInFilesClosePos.top, _findInFilesClosePos.right, _findInFilesClosePos.bottom, TRUE); calcAndSetCtrlsPos(_currentStatus);
TCHAR label[MAX_PATH]{}; TCHAR label[MAX_PATH]{};
_tab.getCurrentTitle(label, MAX_PATH); _tab.getCurrentTitle(label, MAX_PATH);
::SetWindowText(_hSelf, label); ::SetWindowText(_hSelf, label);
@ -4395,7 +4408,7 @@ void FindReplaceDlg::enableFindInProjectsFunc()
enableFindInFilesControls(true, true); enableFindInFilesControls(true, true);
_currentStatus = FINDINPROJECTS_DLG; _currentStatus = FINDINPROJECTS_DLG;
gotoCorrectTab(); gotoCorrectTab();
::MoveWindow(::GetDlgItem(_hSelf, IDCANCEL), _findInFilesClosePos.left + _deltaWidth, _findInFilesClosePos.top, _findInFilesClosePos.right, _findInFilesClosePos.bottom, TRUE); calcAndSetCtrlsPos(_currentStatus);
TCHAR label[MAX_PATH]{}; TCHAR label[MAX_PATH]{};
_tab.getCurrentTitle(label, MAX_PATH); _tab.getCurrentTitle(label, MAX_PATH);
::SetWindowText(_hSelf, label); ::SetWindowText(_hSelf, label);
@ -4431,10 +4444,7 @@ void FindReplaceDlg::enableMarkFunc()
_currentStatus = MARK_DLG; _currentStatus = MARK_DLG;
gotoCorrectTab(); gotoCorrectTab();
::MoveWindow(::GetDlgItem(_hSelf, IDCANCEL), _findInFilesClosePos.left + _deltaWidth, _findInFilesClosePos.top, _findInFilesClosePos.right, _findInFilesClosePos.bottom, TRUE); calcAndSetCtrlsPos(_currentStatus);
::MoveWindow(::GetDlgItem(_hSelf, IDC_IN_SELECTION_CHECK), _replaceInSelCheckPos.left + _deltaWidth, _replaceInSelCheckPos.top, _replaceInSelCheckPos.right, _replaceInSelCheckPos.bottom, TRUE);
::MoveWindow(::GetDlgItem(_hSelf, IDC_REPLACEINSELECTION), _replaceInSelFramePos.left + _deltaWidth, _replaceInSelFramePos.top, _replaceInSelFramePos.right, _replaceInSelFramePos.bottom, TRUE);
::MoveWindow(::GetDlgItem(_hSelf, IDCANCEL), _markClosePos.left + _deltaWidth, _markClosePos.top, _markClosePos.right, _markClosePos.bottom, TRUE);
TCHAR label[MAX_PATH]{}; TCHAR label[MAX_PATH]{};
_tab.getCurrentTitle(label, MAX_PATH); _tab.getCurrentTitle(label, MAX_PATH);

View File

@ -419,19 +419,6 @@ private :
LONG _lesssModeHeight = 0; LONG _lesssModeHeight = 0;
DIALOG_TYPE _currentStatus = DIALOG_TYPE::FIND_DLG; DIALOG_TYPE _currentStatus = DIALOG_TYPE::FIND_DLG;
RECT _findClosePos = {};
RECT _replaceClosePos = {};
RECT _findInFilesClosePos = {};
RECT _markClosePos = {};
RECT _countInSelFramePos = {};
RECT _replaceInSelFramePos = {};
RECT _countInSelCheckPos = {};
RECT _replaceInSelCheckPos = {};
RECT _collapseButtonPos = {};
RECT _uncollapseButtonPos = {};
ScintillaEditView** _ppEditView = nullptr; ScintillaEditView** _ppEditView = nullptr;
Finder *_pFinder = nullptr; Finder *_pFinder = nullptr;
@ -483,6 +470,7 @@ private :
void enableMarkAllControls(bool isEnable); void enableMarkAllControls(bool isEnable);
void enableMarkFunc(); void enableMarkFunc();
void hideOrShowCtrl4reduceOrNormalMode(DIALOG_TYPE dlgT); void hideOrShowCtrl4reduceOrNormalMode(DIALOG_TYPE dlgT);
void calcAndSetCtrlsPos(DIALOG_TYPE dlgT, bool fromColBtn = false);
void setDefaultButton(int nID) { void setDefaultButton(int nID) {
SendMessage(_hSelf, DM_SETDEFID, nID, 0L); SendMessage(_hSelf, DM_SETDEFID, nID, 0L);