始终是显示设置中的组合框,显示所有可用的显示分辨率。在Windows和其他桌面操作系统中确定Qt/C++中的可用显示分辨率
我需要这种Qt或C++组合框,我卡住了。
我发现了一个C#的做法在这里:How to list available video modes using C#?
我发现了一个C++的方法:
: How to Detect Maximize event on multi-monitor systemMSDN,所有的显示器分辨率可通过遍历参数iModeNum获得EnumDisplaySettingsEx function实况中说:
图形模式索引从零开始。要获取所有显示设备的图形模式的信息,请按如下方式对EnumDisplaySettingsEx进行一系列调用:为第一个调用设置iModeNum为零,并为每个后续调用将iModeNum增加1。继续调用该函数,直到返回值为零。
我已经修改了C++的方法来获得在Windows中我的目标:
#include <QCoreApplication>
#include <windows.h>
#include <stdio.h>
#define DEFAULT_DISPLAY_WIDTH 0
#define DEFAULT_DISPLAY_HEIGHT 0
#define DEFAULT_DISPLAY_FREQUENCY 60
#define DEFAULT_DISPLAY_SOURCE 0
struct DisplayResolution
{
DisplayResolution(int _width = DEFAULT_DISPLAY_WIDTH,
int _height = DEFAULT_DISPLAY_HEIGHT,
int _frequency = DEFAULT_DISPLAY_FREQUENCY,
int _defaultSource = DEFAULT_DISPLAY_SOURCE)
{
width = _width;
height = _height;
frequency = _frequency;
defaultSource = _defaultSource;
}
int width;
int height;
int frequency;
int defaultSource;
};
typedef std::vector<DisplayResolution>::iterator DisplayResolutionIterator;
std::vector<DisplayResolution> getAvailableDisplayResolutions()
{
DISPLAY_DEVICE disp;
DISPLAY_DEVICE adapter;
DEVMODE mode;
std::vector<DisplayResolution> displayResolutions;
int i = 0, j = 0, display_count = 0, k = 0;
// Initialize win32 structs.
memset(&disp, 0, sizeof(DISPLAY_DEVICE));
disp.cb = sizeof(DISPLAY_DEVICE);
memset(&adapter, 0, sizeof(DISPLAY_DEVICE));
adapter.cb = sizeof(DISPLAY_DEVICE);
memset(&mode, 0, sizeof(DEVMODE));
mode.dmSize = sizeof(DEVMODE);
//memset(the_displays, 0, sizeof(the_displays));
// adapter loop:
while(EnumDisplayDevices(NULL, i, &adapter, 0))
{ // multiple displays on single adapter loop:
j = 0;
qDebug() << (TCHAR*)&adapter.DeviceName;
while(EnumDisplayDevices((TCHAR*)&adapter.DeviceName, j, &disp, 0))
{
// The device must be active, attached to desktop and not a mirroring device.
if((disp.StateFlags & DISPLAY_DEVICE_ACTIVE)
&& (disp.StateFlags & DISPLAY_DEVICE_ATTACHED_TO_DESKTOP)
&& !(disp.StateFlags & DISPLAY_DEVICE_MIRRORING_DRIVER))
{
// read display settings.
k = 0;
while(EnumDisplaySettingsEx((TCHAR*)&adapter.DeviceName, k, &mode, 0))
{
displayResolutions.push_back(DisplayResolution(mode.dmPelsWidth,
mode.dmPelsHeight,
mode.dmDisplayFrequency,
mode.dmDefaultSource));
// Reset
memset(&mode, 0, sizeof(DEVMODE));
mode.dmSize = sizeof(DEVMODE);
++display_count;
++k;
}
}
// Reset
memset(&disp, 0, sizeof(DISPLAY_DEVICE));
disp.cb = sizeof(DISPLAY_DEVICE);
++j;
}
// Reset
memset(&adapter, 0, sizeof(DISPLAY_DEVICE));
adapter.cb = sizeof(DISPLAY_DEVICE);
++i;
}
return displayResolutions;
}
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
std::vector<DisplayResolution> displayResolutions = getAvailableDisplayResolutions();
DisplayResolutionIterator it = displayResolutions.begin();
DisplayResolutionIterator itEnd = displayResolutions.end();
for(it; it != itEnd; ++it)
{
printf("Resolution: ");
printf("%i x %i", (*it).width, (*it).height);
printf(" (%iHz)", (*it).frequency);
printf(" @Source:%i", (*it).defaultSource);
printf("\n");
}
return a.exec();
}
希望它可以帮助人们在Windows读这篇文章,但Unix的?
我知道Qt中的一种方法,但这只会通过QDesktopWidget::availableGeometry收集当前的显示分辨率。
有Qt的方法来接收所有可用的显示分辨率?
亲切的问候,
Pixtar
如果你在X11上运行,那么就有X特定的机制。对于其他一切,你需要一个特定于后端的方法。 –
所以你的意思是像[XOpenDisplay](https://linux.die.net/man/3/xopendisplay)和[DefaultScreenOfDisplay](https://linux.die.net/man/3/defaultscreenofdisplay)。据我了解 - 这将使我只能访问当前的显示分辨率,但不能获得所有可用的分辨率。 – Pixtar
这只能给你当前的分辨率。无论如何,这是一个单独的问题 - 也许搜索,你会发现它已经问及回答。 –