일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Kotlin
- c#
- 연산자
- 리뷰
- 포인터
- Javascript
- 이지스퍼블리싱
- 배열
- 프로그래밍
- Windows
- doit코틀린프로그래밍
- Direct2D
- VS ERROR
- 티스토리
- CS
- c++
- Win32
- Visual Studio
- Tips강좌
- Desktop
- 백준
- c
- Programming
- Tips프로그래밍강좌
- 지식나눔강좌
- 김성엽
- 함수
- tipssoft
- 문법
- 알고리즘
Archives
- Yesterday
- Today
- Total
F.R.I.D.A.Y.
Direct2D - Resize() 본문
반응형
HwndRenderTarget의 크기를 조절하는 함수
Resize
HwndRenderTarget의 크기는 능동적으로 변경되지 않는다. 렌더링 타겟인 윈도우의 크기가 변경되면 HwndRenderTarget의 크기가 자동으로 윈도우 크기에 맞춰 조정되지 않는다는 것이다.
이렇게 렌더링 타겟의 크기는 그대로, 윈도우의 크기는 바뀌게 되면 아래와 같은 문제가 발생하곤 한다.
이 문제의 원인은 위에서 설명한 것처럼 윈도우의 클라이언트 영역 크기와 렌더링 타겟에서 인식하고 있는 영역의 크기가 서로 다르기 때문에 발생하는 문제이다.
함수 원형
HRESULT Resize(
const D2D1_SIZE_U *pixelSize
);
렌더링 타겟의 크기를 설정하는 인자 하나를 받는다.
D2D1_SIZE_U
렌더링 타겟의 크기를 설정하기 위한 인자이다.
D2D1::SizeU(width, height)
이 메서드를 이용하면 따로 D2D1_SIZE_U 구조체를 생성하지 않더라도 바로 이용할 수 있다.
사용 예제
이 함수는 WM_SIZE 메시지가 들어왔을 때 함께 넣어주면 큰 무리 없이 렌더링 타겟의 크기를 조절할 수 있다.
ID2D1HwndRenderTarget* pRT;
// ID2D1HwndRenderTarget 객체가 이미 만들어졌다고 가정한다.
LRESULT CALLBACK WindowProc(...){
switch(uMsg){
case WM_SIZE:
RECT rect;
GetClientRect(hWnd, &rect);
pRT->Resize(D2D1::SizeU(rect.right - rect.left, rect.bottom - rect.top));
return 0;
}
return DefWindowProc(...);
}
# index
728x90
반응형
'DEV > Direct2D' 카테고리의 다른 글
Direct2D - ID2D1SolidColorBrush (0) | 2021.04.05 |
---|---|
Direct2D - DrawRectangle() (0) | 2021.04.05 |
Direct2D - Clear() (0) | 2021.04.04 |
Direct2D - D2D1CreateFactory() (0) | 2021.04.04 |
Direct2D - CreateHwndRenderTarget() (0) | 2021.04.04 |
Comments