在Qt / C ++

时间:2016-11-15 21:20:13

标签: c++ qt cross-platform desktop-application screen-resolution

Windows和其他桌面操作系统中的

始终是显示设置中的组合框,显示所有可用的显示分辨率。

我需要Qt或C ++中的这种组合框,而且我被卡住了。

我在这里找到了一个C#方法:How to list available video modes using C#?

我找到了一种C ++方法:How to Detect Maximize event on multi-monitor system

MSDN在EnumDisplaySettingsEx function文档中说,可以通过遍历参数iModeNum来获取所有显示分辨率:

  

图形模式索引从零开始。要获取所有显示设备图形模式的信息,请对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

1 个答案:

答案 0 :(得分:0)

Qt不提供任何具有此类信息的API。您可以通过QScreen:geometry()获取给定屏幕的当前分辨率。但是没有Qt方法可以获得可用分辨率列表,也无法切换它们。

您需要查找有关它的特定于平台的问题,并询问它们是否不存在。一个问题应该涵盖一个平台。