다음을 통해 공유


ChangeDisplaySettingsW 함수(winuser.h)

ChangeDisplaySettings 함수는 기본 디스플레이 디바이스의 설정을 지정된 그래픽 모드로 변경합니다.

지정된 디스플레이 디바이스의 설정을 변경하려면 ChangeDisplaySettingsEx 함수를 사용합니다.

참고 Windows 8 이상 대상으로 디자인한 앱은 더 이상 픽셀당 32비트(bpp) 미만의 디스플레이 모드를 쿼리하거나 설정할 수 없습니다. 이러한 작업은 실패합니다. 이러한 앱에는 Windows 8 대상으로 하는 호환성 매니페스트가 있습니다. Windows 8 여전히 Windows 8 매니페스트 없이 빌드된 데스크톱 앱에 대해 8비트 및 16비트 색 모드를 지원합니다. Windows 8 이러한 모드를 에뮬레이트하지만 여전히 32비트 색 모드로 실행됩니다.
 

구문

LONG ChangeDisplaySettingsW(
  [in] DEVMODEW *lpDevMode,
  [in] DWORD    dwFlags
);

매개 변수

[in] lpDevMode

새 그래픽 모드를 설명하는 DEVMODE 구조체에 대한 포인터입니다. lpDevModeNULL이면 현재 레지스트리에 있는 모든 값이 표시 설정에 사용됩니다. lpDevMode 매개 변수에 대해 NULL을 전달하고 dwFlags 매개 변수에 대해 0을 전달하는 것이 동적 모드 변경 후 기본 모드로 돌아가는 가장 쉬운 방법입니다.

DEVMODEdmSize 멤버는 DEVMODE 구조체의 크기(바이트)로 초기화되어야 합니다. DEVMODE 구조 다음에 개인 드라이버 데이터의 바이트 수를 나타내려면 DEVMODEdmDriverExtra 멤버를 초기화해야 합니다. 또한 DEVMODE 구조체의 다음 멤버를 모두 사용할 수 있습니다.

멤버 의미
dmBitsPerPel 픽셀당 비트 수
dmPelsWidth 픽셀 너비
dmPelsHeight 픽셀 높이
dmDisplayFlags 모드 플래그
dmDisplayFrequency 모드 빈도
dmPosition 다중 모니터 구성에서 디바이스의 위치입니다.
 

앞의 DEVMODE 멤버 중 하나 이상을 사용하는 것 외에도 dmFields 멤버에서 다음 값 중 하나 이상을 설정하여 표시 설정을 변경해야 합니다.

의미
DM_BITSPERPEL dmBitsPerPel 값을 사용합니다.
DM_PELSWIDTH dmPelsWidth 값을 사용합니다.
DM_PELSHEIGHT dmPelsHeight 값을 사용합니다.
DM_DISPLAYFLAGS dmDisplayFlags 값을 사용합니다.
DM_DISPLAYFREQUENCY dmDisplayFrequency 값을 사용합니다.
DM_POSITION dmPosition 값을 사용합니다.

[in] dwFlags

그래픽 모드를 변경하는 방법을 나타냅니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.

의미
0
현재 화면의 그래픽 모드가 동적으로 변경됩니다.
CDS_FULLSCREEN
모드는 본질적으로 일시적입니다.

다른 데스크톱으로 변경하면 이 모드가 다시 설정되지 않습니다.

CDS_GLOBAL
설정은 컴퓨터의 모든 사용자에게 영향을 주도록 전역 설정 영역에 저장됩니다. 그렇지 않으면 사용자에 대한 설정만 수정됩니다. 이 플래그는 CDS_UPDATEREGISTRY 플래그로 지정된 경우에만 유효합니다.
CDS_NORESET
설정은 레지스트리에 저장되지만 적용되지 않습니다. 이 플래그는 CDS_UPDATEREGISTRY 플래그로 지정된 경우에만 유효합니다.
CDS_RESET
요청된 설정이 현재 설정과 동일한 경우에도 설정을 변경해야 합니다.
CDS_SET_PRIMARY
이 디바이스는 기본 디바이스가 됩니다.
CDS_TEST
시스템은 요청된 그래픽 모드를 설정할 수 있는지 테스트합니다.
CDS_UPDATEREGISTRY
현재 화면의 그래픽 모드가 동적으로 변경되고 레지스트리에서 그래픽 모드가 업데이트됩니다. 모드 정보는 USER 프로필에 저장됩니다.
 

CDS_TEST 지정하면 시스템이 해당 그래픽 모드로 변경되지 않고도 애플리케이션에서 실제로 유효한 그래픽 모드를 확인할 수 있습니다.

CDS_UPDATEREGISTRY 지정하고 그래픽 모드를 동적으로 변경할 수 있는 경우 정보가 레지스트리에 저장되고 DISP_CHANGE_SUCCESSFUL 반환됩니다. 그래픽 모드를 동적으로 변경할 수 없는 경우 정보가 레지스트리에 저장되고 DISP_CHANGE_RESTART 반환됩니다.

CDS_UPDATEREGISTRY 지정하고 정보를 레지스트리에 저장할 수 없는 경우 그래픽 모드가 변경되지 않고 DISP_CHANGE_NOTUPDATED 반환됩니다.

반환 값

ChangeDisplaySettings 함수는 다음 값 중 하나를 반환합니다.

반환 코드 설명
DISP_CHANGE_SUCCESSFUL
설정 변경에 성공했습니다.
DISP_CHANGE_BADDUALVIEW
시스템이 DualView를 사용할 수 있으므로 설정 변경에 실패했습니다.
DISP_CHANGE_BADFLAGS
잘못된 플래그 집합이 전달되었습니다.
DISP_CHANGE_BADMODE
그래픽 모드는 지원되지 않습니다.
DISP_CHANGE_BADPARAM
잘못된 매개 변수가 전달되었습니다. 여기에는 잘못된 플래그 또는 플래그 조합이 포함될 수 있습니다.
DISP_CHANGE_FAILED
디스플레이 드라이버가 지정된 그래픽 모드에 실패했습니다.
DISP_CHANGE_NOTUPDATED
레지스트리에 설정을 쓸 수 없습니다.
DISP_CHANGE_RESTART
그래픽 모드가 작동하려면 컴퓨터를 다시 시작해야 합니다.

설명

ChangeDisplaySettings에 전달된 DEVMODE 구조체가 유효하고 디스플레이 드라이버에서 지원하는 값만 포함하도록 하려면 EnumDisplaySettings 함수에서 반환된 DEVMODE를 사용합니다.

표시 모드가 동적으로 변경되면 다음 메시지 매개 변수를 사용하여 실행 중인 모든 애플리케이션에 WM_DISPLAYCHANGE 메시지가 전송됩니다.

매개 변수 의미
wParam 픽셀당 새 비트
LOWORD(lParam) 새 픽셀 너비
HIWORD(lParam) 새 픽셀 높이
 

DPI 가상화

이 API는 DPI 가상화에 참여하지 않습니다. 지정된 입력은 항상 물리적 픽셀의 측면에서 이며 호출 컨텍스트와 관련이 없습니다.

참고

winuser.h 헤더는 CHANGEDisplaySettings를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 winuser.h(Windows.h 포함)
라이브러리 User32.lib
DLL User32.dll
API 세트 ext-ms-win-ntuser-sysparams-ext-l1-1-1(Windows 10 버전 10.0.14393에 도입됨)

추가 정보

ChangeDisplaySettingsEx

CreateDC

Devmode

디바이스 컨텍스트 함수

디바이스 컨텍스트 개요

EnumDisplayDevices

EnumDisplaySettings

WM_DISPLAYCHANGE