Windows: как получить разрешение камер? - PullRequest
2 голосов
/ 05 декабря 2010

Таким образом, чтобы получить список камер и позволить пользователю выбрать одну (C ++, Boost, dshow, windows), я использую такой код:

#include "StdAfx.h"
#include "list.h"
#include <windows.h>
#include <dshow.h>
#include <boost/lexical_cast.hpp>

HRESULT CamerasList::EnumerateDevices( REFGUID category, IEnumMoniker **ppEnum )
{
    // Create the System Device Enumerator.
    ICreateDevEnum *pDevEnum;
    HRESULT hr = CoCreateInstance(CLSID_SystemDeviceEnum, NULL,  
        CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&pDevEnum));

    if (SUCCEEDED(hr))
    {
        // Create an enumerator for the category.
        hr = pDevEnum->CreateClassEnumerator(category, ppEnum, 0);
        if (hr == S_FALSE)
        {
            hr = VFW_E_NOT_FOUND;  // The category is empty. Treat as an error.
        }
        pDevEnum->Release();
    }
    return hr;
}

int CamerasList::SelectFromList()
{   int i = 0;
    int SelectedIndex;
    IEnumMoniker *pEnum;
    printf("\nLet us select video device\n");
    printf("Available Capture Devices are:\n");
    HRESULT hr;
    hr = EnumerateDevices(CLSID_VideoInputDeviceCategory, &pEnum);
    if (SUCCEEDED(hr))
    {
        IMoniker *pMoniker = NULL;

        while (pEnum->Next(1, &pMoniker, NULL) == S_OK)
        {
            IPropertyBag *pPropBag;
            HRESULT hr = pMoniker->BindToStorage(0, 0, IID_PPV_ARGS(&pPropBag));
            if (FAILED(hr))
            {
                pMoniker->Release();
                continue;  
            } 

            VARIANT var;
            VariantInit(&var);

            // Get description or friendly name.
            hr = pPropBag->Read(L"Description", &var, 0);
            if (FAILED(hr))
            {
                hr = pPropBag->Read(L"FriendlyName", &var, 0);
            }
            if (SUCCEEDED(hr))
            {
                std::cout << i;
                printf(") %S\n", var.bstrVal);
                i++;
                VariantClear(&var); 
            }

            hr = pPropBag->Write(L"FriendlyName", &var);

            pPropBag->Release();
            pMoniker->Release();

        }
        SelectedIndex = 999;
    if (i <= 0)
    {
        cout <<"No devices found. \n " << endl;
        //cout <<"Please restart application."  << endl;
        //cin.get();
        //Sleep(999999);
    return 999;

    }else if(i == 1){
            cout <<"Default device will be used\n" << std::endl;
            SelectedIndex = 0;
        }else{
        while(SelectedIndex > i-1 || SelectedIndex < 0)
        {
            try{        
            std::string s;
            std::getline( cin, s, '\n' );
            SelectedIndex =  boost::lexical_cast<int>(s);
            }
            catch(std::exception& e){
                std::cout <<"please input index from 0 to " << i-1 << std::endl;
                SelectedIndex = 999;
            }
        }}
        pEnum->Release();
    }else
    {
        printf("no Video Devices found. \n") ;
        //cout <<"Please restart application."  << endl;
        //cin.get();
        //Sleep(999999);
        return 999;
    }
    return SelectedIndex;
}

Мне нужно как-то получить список поддерживаемых разрешений камеры для выбранной камеры. Как это сделать?

Ответы [ 2 ]

4 голосов
/ 05 декабря 2010

Предполагая, что вы добавили фильтр источника захвата к графику: Один из методов - получить интерфейс IAMStreamConfig выходного контакта фильтра захвата, а затем вызвать IAMStreamConfig :: GetNumberOfCapabilities, чтобы получить числоВозможности форматирования, поддерживаемые устройством.Вы можете перебирать все форматы, вызывая IAMStreamConfig :: GetStreamCaps с соответствующими индексами.

3 голосов
/ 28 марта 2013

Вы можете получить поддерживаемые разрешения, не добавляя источник захвата в график фильтра. Вам нужно

Вот как перечислить типы мультимедиа с помощью перечислителя типов медиа

AM_MEDIA_TYPE* mediaType = NULL;
VIDEOINFOHEADER* videoInfoHeader = NULL;
while (S_OK == mediaTypesEnumerator->Next(1, &mediaType, NULL))
{
    if ((mediaType->formattype == FORMAT_VideoInfo) &&
        (mediaType->cbFormat >= sizeof(VIDEOINFOHEADER)) &&
        (mediaType->pbFormat != NULL))
    {
        videoInfoHeader = (VIDEOINFOHEADER*)mediaType->pbFormat;
        videoInfoHeader->bmiHeader.biWidth;  // Supported width
        videoInfoHeader->bmiHeader.biHeight; // Supported height
    }
    FreeMediaType(*mediaType);
}
...