142 lines
4.6 KiB
C++
Raw Normal View History

2024-11-05 15:46:45 +08:00

2024-11-04 23:10:41 +08:00
DECLARE_API void showintab(HWND hwnd, bool show, bool tool)
2024-04-14 20:55:06 +08:00
{
2024-05-29 10:16:49 +08:00
// WS_EX_TOOLWINDOW可以立即生效WS_EX_APPWINDOW必须切换焦点才生效。但是WS_EX_TOOLWINDOW会改变窗口样式因此只对无边框窗口使用。
LONG style = GetWindowLong(hwnd, GWL_STYLE);
2024-04-14 20:55:06 +08:00
auto style_ex = GetWindowLong(hwnd, GWL_EXSTYLE);
if (show)
{
style_ex |= WS_EX_APPWINDOW;
2024-07-30 13:51:29 +08:00
// if ((style & WS_OVERLAPPEDWINDOW) != WS_OVERLAPPEDWINDOW)
2024-08-02 19:26:29 +08:00
if (tool)
style_ex &= ~WS_EX_TOOLWINDOW;
2024-04-14 20:55:06 +08:00
}
else
{
style_ex &= ~WS_EX_APPWINDOW;
2024-07-30 13:51:29 +08:00
// if ((style & WS_OVERLAPPEDWINDOW) != WS_OVERLAPPEDWINDOW)
2024-08-02 19:26:29 +08:00
if (tool)
style_ex |= WS_EX_TOOLWINDOW;
2024-08-02 18:17:49 +08:00
}
SetWindowLong(hwnd, GWL_EXSTYLE, style_ex);
}
2024-11-04 23:10:41 +08:00
DECLARE_API bool pid_running(DWORD pid)
2024-04-14 20:55:06 +08:00
{
DWORD code;
2024-11-15 08:38:25 +08:00
#ifndef WINXP
2024-06-30 20:08:02 +08:00
GetExitCodeProcess(AutoHandle(OpenProcess(PROCESS_QUERY_LIMITED_INFORMATION, FALSE, pid)), &code);
2024-11-15 08:38:25 +08:00
#else
GetExitCodeProcess(AutoHandle(OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, pid)), &code);
#endif
2024-06-30 20:08:02 +08:00
// 句柄必須具有 PROCESS_QUERY_INFORMATION 或 PROCESS_QUERY_LIMITED_INFORMATION 訪問許可權。 如需詳細資訊,請參閱 處理安全性和訪問許可權。
// Windows Server 2003 和 Windows XP 句柄必須具有 PROCESS_QUERY_INFORMATION 訪問許可權。
2024-04-14 20:55:06 +08:00
return code == STILL_ACTIVE;
// auto process = AutoHandle(OpenProcess(SYNCHRONIZE, FALSE, pid));
// DWORD ret = WaitForSingleObject(process, 0);
// return ret == WAIT_TIMEOUT;
}
struct __EnumWindowsProc
{
DWORD pid;
HWND hwnd;
};
BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam)
{
if (IsWindow(hwnd) && IsWindowEnabled(hwnd) & IsWindowVisible(hwnd))
{
auto info = (__EnumWindowsProc *)lParam;
DWORD processId;
GetWindowThreadProcessId(hwnd, &processId);
if (info->pid == processId && info->hwnd == 0)
{
info->hwnd = hwnd;
}
}
return TRUE;
}
2024-11-04 23:10:41 +08:00
DECLARE_API HWND getpidhwndfirst(DWORD pid)
2024-04-14 20:55:06 +08:00
{
__EnumWindowsProc info = {pid, 0};
EnumWindows(EnumWindowsProc, (LPARAM)&info);
return info.hwnd;
}
2024-11-04 23:10:41 +08:00
DECLARE_API bool Is64bit(DWORD pid)
2024-04-14 20:55:06 +08:00
{
SYSTEM_INFO sysinfo;
GetNativeSystemInfo(&sysinfo);
if (sysinfo.wProcessorArchitecture == 9 || sysinfo.wProcessorArchitecture == 6)
{
2024-06-30 20:08:02 +08:00
auto hprocess = AutoHandle(OpenProcess(PROCESS_QUERY_LIMITED_INFORMATION, FALSE, pid));
// 進程的控制碼。 控制碼必須具有PROCESS_QUERY_INFORMATION或PROCESS_QUERY_LIMITED_INFORMATION存取權限。 如需詳細資訊,請參閱 處理安全性和存取權限。
// Windows Server 2003 和 Windows XP 控制碼必須具有PROCESS_QUERY_INFORMATION存取權限。
2024-04-14 20:55:06 +08:00
BOOL b;
IsWow64Process(hprocess, &b);
return !b;
}
else
return false;
2024-08-02 19:26:29 +08:00
}
2024-11-04 23:10:41 +08:00
DECLARE_API void getprocesses(void (*cb)(DWORD, const wchar_t *))
2024-08-02 19:26:29 +08:00
{
std::unordered_map<std::wstring, std::vector<int>> exe_pid;
AutoHandle hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (hSnapshot == INVALID_HANDLE_VALUE)
return;
PROCESSENTRY32 pe32;
pe32.dwSize = sizeof(PROCESSENTRY32);
auto currpid = GetCurrentProcessId();
if (Process32First(hSnapshot, &pe32))
{
do
{
2024-08-03 17:46:50 +08:00
cb(pe32.th32ProcessID, pe32.szExeFile);
2024-08-02 19:26:29 +08:00
} while (Process32Next(hSnapshot, &pe32));
}
2024-10-16 15:24:38 +08:00
}
2024-11-15 03:21:30 +08:00
typedef enum MONITOR_DPI_TYPE
{
MDT_EFFECTIVE_DPI = 0,
MDT_ANGULAR_DPI = 1,
MDT_RAW_DPI = 2,
MDT_DEFAULT = MDT_EFFECTIVE_DPI
} MONITOR_DPI_TYPE;
2024-11-04 23:10:41 +08:00
DECLARE_API UINT GetMonitorDpiScaling(HWND hwnd)
2024-10-16 15:24:38 +08:00
{
HMONITOR hMonitor = MonitorFromWindow(hwnd, MONITOR_DEFAULTTONEAREST);
if (!hMonitor)
return 96;
2024-10-27 14:58:56 +08:00
auto pGetDpiForMonitor = (HRESULT(STDAPICALLTYPE *)(HMONITOR, MONITOR_DPI_TYPE, UINT *, UINT *))GetProcAddress(GetModuleHandleA("Shcore.dll"), "GetDpiForMonitor");
2024-10-16 15:24:38 +08:00
if (pGetDpiForMonitor)
{
UINT dpiX = 0;
UINT dpiY = 0;
HRESULT hr = pGetDpiForMonitor(hMonitor, MDT_EFFECTIVE_DPI, &dpiX, &dpiY);
if (FAILED(hr))
return 96;
else
return dpiX;
}
else
{
MONITORINFOEX info;
info.cbSize = sizeof(MONITORINFOEX);
if (!GetMonitorInfo(hMonitor, &info))
return 96;
HDC hdc = GetDC(NULL);
HDC hdcMonitor = CreateCompatibleDC(hdc);
HDC hdcMonitorScreen = CreateIC(TEXT("DISPLAY"), info.szDevice, NULL, 0);
int dpiX = GetDeviceCaps(hdcMonitorScreen, LOGPIXELSX);
DeleteDC(hdcMonitor);
DeleteDC(hdcMonitorScreen);
ReleaseDC(NULL, hdc);
return dpiX;
}
}