디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

적분시리즈: 4. 행렬변환을 통해 회전, 확대/축소하기

∫ 2t dt=t²+c갤로그로 이동합니다. 2009.11.24 23:47:11
조회 716 추천 0 댓글 3


이번에는 스프라이트를 확대/축소하거나 회전해서 출력할 수 있게 해보자.

이런 까다로운 일들을 하기 위해선 \'행렬\'이라는 걸 알아야한다. 하지만 여기서 행렬에 대해서 자세히 설명할 시간은 없고, 3D프로그래밍을 할때는 행렬을 통해서 여러가지 변환을 한다는 사실만 알아두도록 하자.

D3D에서는 행렬을 위한 자료형으로 D3DXMATRIX타입을 제공한다.
그리고 편리한 행렬 계산을 위해 D3DXMatrix~~~ 시리즈 함수를 제공한다.
D3DXMATRIX 타입에 각종 연산자(대입, 곱하기, 더하기, 빼기 등등)가 정의되어 있으므로 연산도 편리하게 할 수 있다.

점 (x, y, z, 1)에다가 4차정사각행렬을 곱함으로써 행렬변환은 이루어진다. 점에다가 특정한 행렬을 곱하면 여러가지 효과를 줄 수 있다.

ID3DXSprite는 SetTransform 라는 변환행렬을 지정하는 함수를 제공한다.
19499B174B0BD8A98067DA
자, 가상의 텍스쳐가 좌표계 위에 있다.
(화면 상의 좌표계는 수학과는 다르게 아래로 내려갈수록 y가 증가한다. )
변환행렬을 단위행렬로 설정해놓으면 항상 이 상태로 텍스쳐가 출력된다.
자, 이제 행렬의 마법이 시작된다.
1. 평행이동 D3DXMatrixTranslation(행렬, x이동, y이동, z이동)
1121FC234B0BE132248A03
x축, y축, z축 방향으로 평행이동시킨다. 근데 2D출력에서는 z축이동은 필요가 없으므로 무시해도 된다.

D3DXMATRIX mat;
D3DXMatrixTranslation(&mat, 3.f, 4.f, 0.f);
m_pspr->SetTransform(&mat);
//x축으로 3, y축으로 4만큼 평행이동해서 그린다.

2. 확대/축소 D3DXMatrixScaling(행렬, x축확대율, y축확대율, z축확대율)
2018BA0C4B0BE2420961C1
x축, y축, z축으로 일정 비율 확대/축소시킨다. 역시 z축은 무시하도록 하자. 확대/축소시에 기준점은 항상 원점이다.

D3DXMATRIX mat;
D3DXMatrixScaling(&mat, 3.f, 4.f, 1.f);
m_pspr->SetTransform(&mat);
//x축으로 3배 늘리고, y축으로 4배 늘려서 그린다.

3. 회전 D3DXRotationZ(행렬, 회전각도)
2005F50C4B0BE2E1236869
z축을 축으로 일정 각도 회전시킨다. z축은 원점을 지나, x,y축에 수직으로 화면속으로 들어가는 방향이다. 그러므로 기준점은 원점이 되고, 회전방향은 우리가 보는 입장에서 시계방향이 된다.

D3DXMATRIX mat;
D3DXMatrixRotationZ(&mat, D3DX_PI/6.f);
m_pspr->SetTransform(&mat);
//시계방향으로 30도(Pi/6)회전시켜서 그린다.

참 쉽죠?
근데,  원점을 기준으로 회전하니까, 좀 거시기하다. 텍스쳐의 중심을 기준으로 회전하게 하려면 어떻게 해야 할까?

먼저 평행이동을 통해서 텍스쳐의 중심을 원점과 일치시킨다.
2066EF234B0BE89B7B583F

그리고 회전시킨다.
2014C11F4B0BE8B5653DEF
그리고 다시 평행이동시켜 원래 위치로 보낸다
121D48214B0BE8CF0A97E3
D3DXMATRIX mat, mat1, mat2, mat3;
D3DXMatrixTranslation(&mat1, -w*0.5f, -h*0.5f, 0.f); //w,h는 텍스쳐의 가로 세로길이
D3DXMatrixRotationZ(&mat2, angle); //angle은 회전각도
D3DXMatrixTranslation(&mat3, w*0.5f, h*0.5f, 0.f);
mat=mat1*mat2*mat3;
/*변환을 차례대로 적용하고 싶으면,
변환행렬들을 차례대로 곱하면 된다.*/
m_pspr->SetTransform(&mat);

이제 스프라이트를 회전시켜서, 확대/축소시켜서 그릴수 있겠다.
GRET GSprites::DrawSprite(UINT index, int x, int y, float sx, float sy, D3DCOLOR color) const
{
    if(m_vspr.size()<=index)return GRET_ERROR_PARAM;
    D3DXMATRIX mat, mat2;
    D3DXMatrixScaling(&mat, sx, sy, 0);
    mat*=*D3DXMatrixTranslation(&mat2, (float)x, (float)y, 0);
    GGame::GetInstance()->GetSprite()->SetTransform(&mat);
    if(FAILED( GGame::GetInstance()->GetSprite()
        ->Draw(m_vptxt[m_vspr[index].itxt],
        &m_vspr[index].rect, NULL, NULL, color) ))
    {
        return GRET_ERROR_FAIL;
    }
    return GRET_OK;
}
가로로 sx배, 세로로 sy배 확대/축소하는 함수이다.
중간에
mat*=*D3DXMatrixTranslation(&mat2, (float)x, (float)y, 0);
라는 상당히 해괴한 코드가 보인다.

D3DXMatrix~~함수는 첫번째 인자를 다시 리턴해준다.
즉 원래는
D3DXMatrixTranslation(&mat2, (float)x, (float)y, 0);
mat*=mat2;
인데, 어차피 D3DXMatrixTranslation(&mat2, (float)x, (float)y, 0)가 &mat2이므로,
mat*=*D3DXMatrixTranslation(&mat2, (float)x, (float)y, 0);라고 쓴것이다.

ID3DXSprite::Draw을 사용할때, 주의할점.

HRESULT Draw(  LPDIRECT3DTEXTURE9 pTexture,  CONST RECT * pSrcRect, CONST D3DXVECTOR3 * pCenter,  CONST D3DXVECTOR3 * pPosition,  D3DCOLORColor );
네 번째 인자로 주는 pPosition으로 좌표를 줄때, 행렬변환이 적용된 것을 감안해야 한다.
만약 가로, 세로 2배씩 키워주는 행렬을 변환행렬로 잡았을때, pPosition을 (10, 10, 0)으로 주면, pPosition에도 변환이 적용되어 결국 (20, 20, 0)에 텍스쳐를 출력하게 될 것이다.
1628131A4B0BEF9B969972
행렬변환을 이용해서 스프라이트를 여러가지 모습으로 출력해보자.




추천 비추천

0

고정닉 0

0

원본 첨부파일 1

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 며느리, 사위되면 시댁, 처가에 잘할 것 같은 스타 운영자 25/10/13 - -
AD iPad Pro 사전예약!! 운영자 25/10/17 - -
공지 프로그래밍 갤러리 이용 안내 [97] 운영자 20.09.28 48070 65
2897304 개발자들 이제 뭐먹고살아야함? [1] 프갤러(39.117) 22:52 31 0
2897303 통계학과에서 데이터사이언스 배워? 돌진하자(121.175) 22:28 11 0
2897302 아니 공공데이터포털 아직도 안돼? 데이터 써야하는데 ㅅㅂ [1] 프갤러(124.59) 22:22 29 0
2897301 코딩갤 맞음? 왜 정치글이 념글임? [1] ㅇㅇ갤로그로 이동합니다. 22:21 16 0
2897299 나님 탈갤합니당.. [1] ♥덩냥이♥갤로그로 이동합니다. 22:01 15 0
2897298 인생 역대급으로 목적이없음 [7] 공기역학갤로그로 이동합니다. 21:46 44 0
2897294 아프리카 흑인들도 짱깨 더럽다고 무시하넹 ♥덩냥이♥갤로그로 이동합니다. 21:27 15 0
2897293 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥덩냥이♥갤로그로 이동합니다. 21:23 17 0
2897292 러스트 배우면 갹체지향도 그냥 깔끔하게 끝납니다. 프갤러(110.8) 21:15 19 0
2897291 흐흣.. 모모야.. 기다려.. [1] ♥덩냥이♥갤로그로 이동합니다. 21:03 24 0
2897290 남녀평등 배구공(119.202) 20:57 28 0
2897289 OOP가 참 존나 웃김 [6] 루도그담당(58.239) 20:47 88 0
2897288 데이터 싸이언스 할라면 R 타이디버스부터 해야함 ㅆㅇㅆ(124.216) 20:41 18 0
2897287 뭐 어떤 지향이 필수는 아님. 결국 다형성의 구현이니까 [4] ㅆㅇㅆ(124.216) 20:40 47 0
2897286 데이터 사이언스 할려면 도메인부터 먼저 필수임? [4] 돌진하자(121.175) 20:35 35 0
2897285 죽을까 프갤러(106.101) 20:29 24 0
2897284 발음 굿~ ♥덩냥이♥갤로그로 이동합니다. 20:28 19 0
2897283 아 재밌고 어려운거 심장떨리는거 하고싶다 [1] ㅆㅇㅆ(124.216) 20:24 39 0
2897281 논문 재현외주는 재미는 있는데 돈이 안되네 [4] ㅆㅇㅆ(124.216) 20:17 48 0
2897280 믿고 거르는 찢두순 ㅋㅅㅋ ♥덩냥이♥갤로그로 이동합니다. 20:07 14 0
2897279 oop는 필요성을 느껴야지, 연습한다고 의미 없음 ㅋㅋ [2] 에이도비갤로그로 이동합니다. 20:01 44 0
2897278 나님 슬슬 치카푸카악퉷 하구 주무실 준비 ♥덩냥이♥갤로그로 이동합니다. 19:35 20 0
2897277 쉬야하궁 부르르 했당 [2] ♥덩냥이♥갤로그로 이동합니다. 19:18 36 0
2897276 음기 충전 발명도둑잡기(39.7) 19:11 31 0
2897275 점심 간식 저녁 발명도둑잡기(39.7) 19:10 16 0
2897273 “내가 망해도 남이 더 망하면 좋다”는 인간의 본성 [1] 발명도둑잡기(39.7) 19:07 23 0
2897272 상냥하게 대해줘멍..❤+ [2] ♥덩냥이♥갤로그로 이동합니다. 18:53 40 0
2897271 함수형보다는 ㅇㅇ(118.235) 18:39 33 0
2897270 유방암환자를 돕는 최선책은 의료, 제약을 공영화하는 것 발명도둑잡기(39.7) 18:36 17 0
2897269 자기전에 야구 하이라이또 봐야징 [1] ♥덩냥이♥갤로그로 이동합니다. 18:34 25 0
2897268 나님 길냥덩 마스터임 ㅇㅅㅇ ♥덩냥이♥갤로그로 이동합니다. 18:25 33 0
2897267 소화되면 바루 자야징 ♥덩냥이♥갤로그로 이동합니다. 18:23 24 0
2897266 배뷰르당 ♥덩냥이♥갤로그로 이동합니다. 18:23 23 0
2897264 [애니뉴스] 조아라 패러디 프갤러(121.172) 18:05 23 0
2897263 개인적으로 함수형 패러다임 익히는데는 R이 좋더라 ㅆㅇㅆ(124.216) 17:40 32 0
2897262 링크드인서 만난 그 남자..."알고 보니 채용 빙자 해커" 발명도둑잡기(118.235) 17:24 22 0
2897261 oop는 다형성의 구현일뿐인데 그게 정형화된거라 [2] ㅆㅇㅆ(124.216) 17:23 49 0
2897260 원래 주식 자동매매 거의 나만하는 꿀통이었는데 ㅆㅇㅆ(124.216) 17:21 34 0
2897259 OOP는 연습한다기보다 그냥 단순하게 많이 짜봐야함. [2] ㅆㅇㅆ(124.216) 17:16 50 0
2897257 oop를 연습하려면? [5] 프갤러(14.36) 17:05 71 0
2897255 오늘만큼 프로그래밍에 감사한 적이 없었다 [1] ㅆㅇㅆ(124.216) 16:51 66 0
2897254 나랑 결혼한지 5년차인 와이프 사진인데 어떠냐 [2] ㅁㅁ갤로그로 이동합니다. 16:49 68 0
2897252 개발자하려면 노트북 쓰지 마라. [6] 프갤러(59.16) 16:41 86 0
2897250 [대한민국] [단독] SBS 무궁화 훈장 욕보여- 프갤러(121.172) 16:31 17 0
2897249 주말이 벌써끝이라고? [11] 개멍청한유라갤로그로 이동합니다. 16:24 51 0
2897248 공지] 냥덩짤 무단사용 ㄴㄴ [8] ♥덩냥이♥갤로그로 이동합니다. 16:23 70 0
2897247 왜 가난의 이미지를 측은함, 부끄러움으로만 만드는걸까... [2] ㅇㅇ(223.39) 16:16 41 0
2897246 존재하지도 않는 것을 동경하고 절망한다 [6] 공기역학갤로그로 이동합니다. 16:14 66 0
2897245 데이터 분석 과제 하고 있는데 미치겠다. [1] 프갤러(218.152) 16:10 49 1
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2