| | |
| | | } |
| | | RECT currentWindowRect{}; |
| | | ::GetWindowRect(hwnd, ¤tWindowRect); |
| | | auto newWindowX = activeMonitorRect.left + (currentWindowRect.left - currentMonitorRect.left); |
| | | auto newWindowX = |
| | | activeMonitorRect.left + (currentWindowRect.left - currentMonitorRect.left); |
| | | auto newWindowY = activeMonitorRect.top + (currentWindowRect.top - currentMonitorRect.top); |
| | | ::SetWindowPos(hwnd, nullptr, newWindowX, newWindowY, RECT_WIDTH(currentWindowRect), RECT_HEIGHT(currentWindowRect), SWP_NOACTIVATE | SWP_NOSIZE | SWP_NOZORDER | SWP_NOOWNERZORDER); |
| | | ::SetWindowPos(hwnd, nullptr, newWindowX, newWindowY, RECT_WIDTH(currentWindowRect), |
| | | RECT_HEIGHT(currentWindowRect), |
| | | SWP_NOACTIVATE | SWP_NOSIZE | SWP_NOZORDER | SWP_NOOWNERZORDER); |
| | | } |
| | | |
| | | static inline void bringWindowToFront(HWND hwnd) { |
| | |
| | | // First try to send a message to the current foreground window to check whether |
| | | // it is currently hanging or not. |
| | | if (!::SendMessageTimeoutW(oldForegroundWindow, WM_NULL, 0, 0, |
| | | SMTO_BLOCK | SMTO_ABORTIFHUNG | SMTO_NOTIMEOUTIFNOTHUNG, 1000, nullptr)) { |
| | | SMTO_BLOCK | SMTO_ABORTIFHUNG | SMTO_NOTIMEOUTIFNOTHUNG, 1000, |
| | | nullptr)) { |
| | | // The foreground window hangs, can't activate current window. |
| | | return; |
| | | } |
| | |
| | | // We won't be able to change a window's Z order if it's not our own window, |
| | | // so we use this small technique to pretend the foreground window is ours. |
| | | ::AttachThreadInput(windowThreadProcessId, currentThreadId, TRUE); |
| | | QWK_USED struct Cleaner { |
| | | Cleaner(DWORD idAttach, DWORD idAttachTo) : m_idAttach(idAttach), m_idAttachTo(idAttachTo) {} |
| | | ~Cleaner() { |
| | | ::AttachThreadInput(m_idAttach, m_idAttachTo, FALSE); |
| | | } |
| | | private: |
| | | Q_DISABLE_COPY(Cleaner) |
| | | DWORD m_idAttach; |
| | | DWORD m_idAttachTo; |
| | | } cleaner{ windowThreadProcessId, currentThreadId }; |
| | | |
| | | [[maybe_unused]] const auto &cleaner = |
| | | qScopeGuard([windowThreadProcessId, currentThreadId]() { |
| | | ::AttachThreadInput(windowThreadProcessId, currentThreadId, FALSE); // |
| | | }); |
| | | |
| | | ::BringWindowToTop(hwnd); |
| | | // Activate the window too. This will force us to the virtual desktop this |
| | | // window is on, if it's on another virtual desktop. |
| | |
| | | const auto &key = *static_cast<const QString *>(args[0]); |
| | | const auto &newVar = *static_cast<const QVariant *>(args[1]); |
| | | const auto &oldVar = *static_cast<const QVariant *>(args[2]); |
| | | |
| | | |
| | | if (key == QStringLiteral("no-frame-shadow")) { |
| | | if (newVar.toBool()) { |
| | | // TODO: set off |
| | |
| | | // Terminal does, however, later I found that if we choose a proper |
| | | // color, our homemade top border can almost have exactly the same |
| | | // appearance with the system's one. |
| | | |
| | | [[maybe_unused]] const auto &hitTestRecorder = qScopeGuard([this, result]() { |
| | | lastHitTestResult = getHitWindowPart(int(*result)); // |
| | | }); |