Изменить яркость с помощью WMI

Я пробовал этот пример Windows Получение данных WMI с удаленного компьютера и этот другой Вызов метода провайдера, и оба работают правильно на моем компьютере. Однако я попытался использовать WMI для изменения яркости, и я получаю сообщение об ошибке на шаге 6, в этой части:

    //Get the Next Object from the collection
hres = pEnum->Next(WBEM_INFINITE, //Timeout
1, //No of objects requested
&pObj, //Returned Object
&ulReturned /*No of object returned*/);

pEnum является отрицательным значением.

ВАЖНО: Когда я писал этот вопрос, я пробовал на разных компьютерах, и у меня все ошибки, кроме случаев, когда я использую ноутбук. Поэтому как я могу изменить яркость монитора?

Я также понимаю, что если я иду на wbemtest.exe, на всех моих компьютерах класс WmiMonitorBrightnessMethods и метод WmiSetBrightness существуют, но только в ноутбуке есть экземпляр этого. Фактически, в компьютерах, когда я нажимаю на объект просмотра класса, я получаю это сообщение (см. Изображение)

Нет экземпляров WmiMonitorBrightnessMethodsClass

Это мой код:

#define _WIN32_DCOM

#include <iostream>
using namespace std;
#include <comdef.h>
#include <Wbemidl.h>

#pragma comment(lib, "wbemuuid.lib")

int main(int iArgCnt, char ** argv)
{
HRESULT hres;

// Step 1: --------------------------------------------------
// Initialize COM. ------------------------------------------

hres =  CoInitializeEx(0, COINIT_MULTITHREADED);
if (FAILED(hres))
{
cout << "Failed to initialize COM library. Error code = 0x"<< hex << hres << endl;
return 1;                  // Program has failed.
}

// Step 2: --------------------------------------------------
// Set general COM security levels --------------------------

hres =  CoInitializeSecurity(
NULL,
-1,                          // COM negotiates service
NULL,                        // Authentication services
NULL,                        // Reserved
RPC_C_AUTHN_LEVEL_DEFAULT,   // Default authentication
RPC_C_IMP_LEVEL_IMPERSONATE, // Default Impersonation
NULL,                        // Authentication info
EOAC_NONE,                   // Additional capabilities
NULL                         // Reserved
);if (FAILED(hres))
{
cout << "Failed to initialize security. Error code = 0x"<< hex << hres << endl;
CoUninitialize();
return 1;                      // Program has failed.
}

// Step 3: ---------------------------------------------------
// Obtain the initial locator to WMI -------------------------

IWbemLocator *pLoc = NULL;

hres = CoCreateInstance(
CLSID_WbemLocator,
0,
CLSCTX_INPROC_SERVER,
IID_IWbemLocator, (LPVOID *) &pLoc);

if (FAILED(hres))
{
cout << "Failed to create IWbemLocator object. "<< "Err code = 0x"<< hex << hres << endl;
CoUninitialize();
return 1;                 // Program has failed.
}

// Step 4: ---------------------------------------------------
// Connect to WMI through the IWbemLocator::ConnectServer method

IWbemServices *pSvc = NULL;

// Connect to the local root\wminamespace
// and obtain pointer pSvc to make IWbemServices calls.
hres = pLoc->ConnectServer(
_bstr_t(L"ROOT\\WMI"),
NULL,
NULL,
0,
NULL,
0,
0,
&pSvc
);

if (FAILED(hres))
{
cout << "Could not connect. Error code = 0x"<< hex << hres << endl;
pLoc->Release();
CoUninitialize();
return 1;                // Program has failed.
}

cout << "Connected to ROOT\\WMI namespace" << endl;// Step 5: --------------------------------------------------
// Set security levels for the proxy ------------------------

hres = CoSetProxyBlanket(
pSvc,                        // Indicates the proxy to set
RPC_C_AUTHN_WINNT,           // RPC_C_AUTHN_xxx
RPC_C_AUTHZ_NONE,            // RPC_C_AUTHZ_xxx
NULL,                        // Server principal name
RPC_C_AUTHN_LEVEL_CALL,      // RPC_C_AUTHN_LEVEL_xxx
RPC_C_IMP_LEVEL_IMPERSONATE, // RPC_C_IMP_LEVEL_xxx
NULL,                        // client identity
EOAC_NONE                    // proxy capabilities
);

if (FAILED(hres))
{
cout << "Could not set proxy blanket. Error code = 0x"<< hex << hres << endl;
pSvc->Release();
pLoc->Release();
CoUninitialize();
return 1;               // Program has failed.
}

// Step 6: --------------------------------------------------
// Call WmiSetBrightness method -----------------------------

// set up to call the Win32_Process::Create method
BSTR ClassName = SysAllocString(L"WmiMonitorBrightnessMethods");
BSTR MethodName = SysAllocString(L"WmiSetBrightness");
BSTR bstrQuery = SysAllocString(L"Select * from WmiMonitorBrightnessMethods");
IEnumWbemClassObject *pEnum = NULL;

hres = pSvc->ExecQuery(_bstr_t(L"WQL"), //Query Language
bstrQuery, //Query to Execute
WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, //Make a semi-synchronous call
NULL, //Context
&pEnum /*Enumeration Interface*/);

hres = WBEM_S_NO_ERROR;

ULONG ulReturned;
IWbemClassObject *pObj;
DWORD retVal = 0;

//Get the Next Object from the collection
hres = pEnum->Next(WBEM_INFINITE, //Timeout
1, //No of objects requested
&pObj, //Returned Object
&ulReturned /*No of object returned*/);

IWbemClassObject* pClass = NULL;
hres = pSvc->GetObject(ClassName, 0, NULL, &pClass, NULL);

IWbemClassObject* pInParamsDefinition = NULL;
hres = pClass->GetMethod(MethodName, 0, &pInParamsDefinition, NULL);

IWbemClassObject* pClassInstance = NULL;
hres = pInParamsDefinition->SpawnInstance(0, &pClassInstance);

VARIANT var1;
VariantInit(&var1);
BSTR ArgName0 = SysAllocString(L"Timeout");

V_VT(&var1) = VT_BSTR;
V_BSTR(&var1) = SysAllocString(L"0");
hres = pClassInstance->Put(ArgName0,
0,
&var1,
CIM_UINT32); //CIM_UINT64
VariantClear(&var1);

VARIANT var;
VariantInit(&var);
BSTR ArgName1 = SysAllocString(L"Brightness");

V_VT(&var2) = VT_BSTR;
V_BSTR(&var2) = SysAllocString(L"80"); //Brightness value
hres = pClassInstance->Put(ArgName1,
0,
&var2,
CIM_UINT8);
VariantClear(&var2);

// Call the method
VARIANT pathVariable;
VariantInit(&pathVariable);

hres = pSvc->ExecMethod(pathVariable.bstrVal,
MethodName,
0,
NULL,
pClassInstance,
NULL,
NULL);
VariantClear(&pathVariable);return 0;
}

0

Решение

Как заявил Амит Шакья. Изменение яркости с помощью WMI возможно только в системах, которые могут динамически устанавливать яркость (ноутбуки и некоторые устройства «все в одном»).

Тем не менее, есть функция Microsoft, которая позволяет менять яркость внешнего монитора, SetMonitorBrightness,

Увидеть Библиотека Microsoft

Я прилагаю простой пример того, как это сделать:

// Includes
#include "PhysicalMonitorEnumerationAPI.h"#include "HighLevelMonitorConfigurationAPI.h"

(…)

// Prepare variables
HMONITOR hMonitor = NULL;
HMONITOR hMonitorTest = NULL;
DWORD cPhysicalMonitors;
LPPHYSICAL_MONITOR pPhysicalMonitors = NULL;

// Get the screen
HWND hWnd = GetDesktopWindow();
hMonitor = MonitorFromWindow(hWnd, MONITOR_DEFAULTTOPRIMARY);

_BOOL success = GetNumberOfPhysicalMonitorsFromHMONITOR(hMonitor, &cPhysicalMonitors);
if(success)
{
pPhysicalMonitors = (LPPHYSICAL_MONITOR)malloc(cPhysicalMonitors* sizeof(PHYSICAL_MONITOR));
if(pPhysicalMonitors != NULL)
{
success = GetPhysicalMonitorsFromHMONITOR(hMonitor,cPhysicalMonitors, pPhysicalMonitors);
HANDLE hPhysicalMonitor = pPhysicalMonitors[0].hPhysicalMonitor;

// Set brightness to 50%
DWORD dwNewBrightness = 50;
success = SetMonitorBrightness(hPhysicalMonitor, dwNewBrightness);

// Free resources
free(pPhysicalMonitors);
}
}
1

Другие решения

Это в основном потому, что ваш компьютер не поддерживает управление яркостью через программное обеспечение. Например, в ноутбуках есть горячие клавиши, которые можно использовать для управления яркостью, если она существует, вы получите экземпляр и будете использовать его через WMI.

Чтобы быть уверенным, вы можете запустить нижеупомянутую команду в powershell. Если он вернется Не поддерживается тогда вы не можете использовать WMI для этих элементов управления.

Get-CimInstance -Namespace root/WMI -ClassName WmiMonitorBrightnessMethods

Заметка : Горячие клавиши работают через другое программное обеспечение, такое как Mobility Center и т. Д.

0

По вопросам рекламы [email protected]