ChangeDisplaySettingsExA-Funktion (winuser.h)
Die ChangeDisplaySettingsEx-Funktion ändert die Einstellungen des angegebenen Anzeigegeräts in den angegebenen Grafikmodus.
Syntax
LONG ChangeDisplaySettingsExA(
[in] LPCSTR lpszDeviceName,
[in] DEVMODEA *lpDevMode,
HWND hwnd,
[in] DWORD dwflags,
[in] LPVOID lParam
);
Parameter
[in] lpszDeviceName
Ein Zeiger auf eine null-beendete Zeichenfolge, die das Anzeigegerät angibt, dessen Grafikmodus sich ändert. Nur anzeigegerätenamen, die von EnumDisplayDevices zurückgegeben werden, sind gültig. Weitere Informationen zu den Namen, die diesen Anzeigegeräten zugeordnet sind, finden Sie unter EnumDisplayDevices .
Der lpszDeviceName-Parameter kann NULL sein. Ein NULL-Wert gibt das Standardanzeigegerät an. Das Standardgerät kann bestimmt werden, indem Sie EnumDisplayDevices aufrufen und auf das flag DISPLAY_DEVICE_PRIMARY_DEVICE überprüfen.
[in] lpDevMode
Ein Zeiger auf eine DEVMODE-Struktur , die den neuen Grafikmodus beschreibt. Wenn lpDevModeNULL ist, werden alle derzeit in der Registrierung befindlichen Werte für die Anzeigeeinstellung verwendet. Das Übergeben von NULL für den parameter lpDevMode und 0 für den dwFlags-Parameter ist die einfachste Möglichkeit, nach einer Änderung des dynamischen Modus in den Standardmodus zurückzukehren.
Das dmSize-Element muss in die Größe der DEVMODE-Struktur in Bytes initialisiert werden. Das dmDriverExtra-Element muss initialisiert werden, um die Anzahl der Bytes privater Treiberdaten nach der DEVMODE-Struktur anzugeben. Darüber hinaus können Sie eines der folgenden Member der DEVMODE-Struktur verwenden.
Mitglied | Bedeutung |
---|---|
dmBitsPerPel | Bit pro Pixel |
dmPelsWidth | Pixelbreite |
dmPelsHeight | Pixelhöhe |
dmDisplayFlags | Modusflags |
dmDisplayFrequency | Modushäufigkeit |
dmPosition | Position des Geräts in einer Konfiguration mit mehreren Monitoren. |
Zusätzlich zur Verwendung eines oder mehrerer der vorherigen DEVMODE-Member müssen Sie auch einen oder mehrere der folgenden Werte im dmFields-Member festlegen, um die Anzeigeeinstellungen zu ändern.
Wert | Bedeutung |
---|---|
DM_BITSPERPEL | Verwenden Sie den Wert dmBitsPerPel . |
DM_PELSWIDTH | Verwenden Sie den Wert dmPelsWidth . |
DM_PELSHEIGHT | Verwenden Sie den Wert dmPelsHeight . |
DM_DISPLAYFLAGS | Verwenden Sie den Wert dmDisplayFlags . |
DM_DISPLAYFREQUENCY | Verwenden Sie den Wert dmDisplayFrequency . |
DM_POSITION | Verwenden Sie den DmPosition-Wert . |
hwnd
Reserviert; muss NULL sein.
[in] dwflags
Gibt an, wie der Grafikmodus geändert werden soll. Dieser Parameter kann einen der folgenden Werte annehmen.
Wert | Bedeutung |
---|---|
|
Der Grafikmodus für den aktuellen Bildschirm wird dynamisch geändert. |
|
Der Modus ist temporärer Natur.
Wenn Sie zu und von einem anderen Desktop wechseln, wird dieser Modus nicht zurückgesetzt. |
|
Die Einstellungen werden im Bereich globale Einstellungen gespeichert, sodass sie sich auf alle Benutzer auf dem Computer auswirken. Andernfalls werden nur die Einstellungen für den Benutzer geändert. Dieses Flag ist nur gültig, wenn es mit dem CDS_UPDATEREGISTRY-Flag angegeben wird. |
|
Die Einstellungen werden in der Registrierung gespeichert, werden aber nicht wirksam. Dieses Flag ist nur gültig, wenn es mit dem CDS_UPDATEREGISTRY-Flag angegeben wird. |
|
Die Einstellungen sollten geändert werden, auch wenn die angeforderten Einstellungen mit den aktuellen Einstellungen identisch sind. |
|
Dieses Gerät wird zum primären Gerät. |
|
Das System testet, ob der angeforderte Grafikmodus festgelegt werden kann. |
|
Der Grafikmodus für den aktuellen Bildschirm wird dynamisch geändert, und der Grafikmodus wird in der Registrierung aktualisiert. Die Modusinformationen werden im BENUTZERprofil gespeichert. |
|
Wenn festgelegt, ist der lParam-Parameter ein Zeiger auf eine VIDEOPARAMETERS-Struktur . |
|
Aktiviert Einstellungen für unsichere Grafikmodi. |
|
Deaktiviert Einstellungen für unsichere Grafikmodi. |
Wenn Sie CDS_TEST angeben, kann eine Anwendung bestimmen, welche Grafikmodi tatsächlich gültig sind, ohne dass sich das System in sie ändert.
Wenn CDS_UPDATEREGISTRY angegeben ist und es möglich ist, den Grafikmodus dynamisch zu ändern, werden die Informationen in der Registrierung gespeichert und DISP_CHANGE_SUCCESSFUL zurückgegeben. Wenn es nicht möglich ist, den Grafikmodus dynamisch zu ändern, werden die Informationen in der Registrierung gespeichert und DISP_CHANGE_RESTART zurückgegeben.
Wenn CDS_UPDATEREGISTRY angegeben ist und die Informationen nicht in der Registrierung gespeichert werden konnten, wird der Grafikmodus nicht geändert und DISP_CHANGE_NOTUPDATED zurückgegeben.
[in] lParam
Wenn dwFlagsCDS_VIDEOPARAMETERS ist, ist lParam ein Zeiger auf eine VIDEOPARAMETERS-Struktur . Andernfalls muss lParamNULL sein.
Rückgabewert
Die ChangeDisplaySettingsEx-Funktion gibt einen der folgenden Werte zurück.
Rückgabecode | Beschreibung |
---|---|
|
Die Einstellungsänderung war erfolgreich. |
|
Die Einstellungsänderung war nicht erfolgreich, da das System DualView-fähig ist. |
|
Ein ungültiger Satz von Flags wurde übergeben. |
|
Der Grafikmodus wird nicht unterstützt. |
|
Ein ungültiger Parameter wurde übergeben. Dies kann ein ungültiges Flag oder eine Kombination aus Flags umfassen. |
|
Fehler beim Anzeigetreiber für den angegebenen Grafikmodus. |
|
Einstellungen können nicht in die Registrierung geschrieben werden. |
|
Der Computer muss neu gestartet werden, damit der Grafikmodus funktioniert. |
Hinweise
Um sicherzustellen, dass die an ChangeDisplaySettingsEx übergebene DEVMODE-Struktur gültig ist und nur werte enthält, die vom Anzeigetreiber unterstützt werden, verwenden Sie den devmode, der von der EnumDisplaySettings-Funktion zurückgegeben wird.
Wenn Sie einem System mit mehreren Monitoren programmgesteuert einen Anzeigemonitor hinzufügen, legen Sie DEVMODE.dmFields auf DM_POSITION fest, und geben Sie (in DEVMODE.dmPosition) für den hinzuzufügenden Monitor eine Position an, die an mindestens ein Pixel des Anzeigebereichs eines vorhandenen Monitors angrenzt. Um den Monitor zu trennen, legen Sie DEVMODE.dmFields auf DM_POSITION aber DEVMODE.dmPelsWidth und DEVMODE.dmPelsHeight auf Null fest. Weitere Informationen finden Sie unter Mehrere Anzeigemonitore.
Wenn der Anzeigemodus dynamisch geändert wird, wird die meldung WM_DISPLAYCHANGE mit den folgenden Nachrichtenparametern an alle ausgeführten Anwendungen gesendet.
Parameter | Bedeutung |
---|---|
wParam | Neue Bits pro Pixel |
LOWORD(lParam) | Neue Pixelbreite |
HIWORD(lParam) | Neue Pixelhöhe |
Um die Einstellungen für mehrere Anzeige gleichzeitig zu ändern, rufen Sie zuerst ChangeDisplaySettingsEx für jedes Einzelne Gerät auf, um die Registrierung zu aktualisieren, ohne die Änderungen anzuwenden. Rufen Sie dann ChangeDisplaySettingsEx erneut mit einem NULL-Gerät auf, um die Änderungen anzuwenden. Gehen Sie beispielsweise wie folgt vor, um die Einstellungen für zwei Anzeigen zu ändern:
ChangeDisplaySettingsEx (lpszDeviceName1, lpDevMode1, NULL, (CDS_UPDATEREGISTRY | CDS_NORESET), NULL);
ChangeDisplaySettingsEx (lpszDeviceName2, lpDevMode2, NULL, (CDS_UPDATEREGISTRY | CDS_NORESET), NULL);
ChangeDisplaySettingsEx (NULL, NULL, NULL, 0, NULL);
DPI-Virtualisierung
Diese API ist nicht an der DPI-Virtualisierung beteiligt. Die angegebene Eingabe bezieht sich immer auf physische Pixel und steht nicht im Zusammenhang mit dem aufrufenden Kontext.Hinweis
Der winuser.h-Header definiert ChangeDisplaySettingsEx als Alias, der die ANSI- oder Unicode-Version dieser Funktion basierend auf der Definition der UNICODE-Präprozessorkonstante automatisch auswählt. Das Mischen der Verwendung des codierungsneutralen Alias mit Code, der nicht Codierungsneutral ist, kann zu Nichtübereinstimmungen führen, die zu Kompilierungs- oder Laufzeitfehlern führen. Weitere Informationen finden Sie unter Konventionen für Funktionsprototypen.
Anforderungen
Anforderung | Wert |
---|---|
Unterstützte Mindestversion (Client) | Windows 2000 Professional [nur Desktop-Apps] |
Unterstützte Mindestversion (Server) | Windows 2000 Server [nur Desktop-Apps] |
Zielplattform | Windows |
Kopfzeile | winuser.h (windows.h einschließen) |
Bibliothek | User32.lib |
DLL | User32.dll |
APIs | ext-ms-win-ntuser-sysparams-ext-l1-1-1 (eingeführt in Windows 10, Version 10.0.14393) |