메뉴 건너뛰기

창작에 관련된 질문이나 간단한 팁, 예제를 올리는 곳

이미지가 중요한 글인데 이미지가 다 짤렸네요. 압박.


준비물은 일단 이미지입니다.

예제 이미지로 럭키♥를 준비했습니다.




럭키! 럭키! 럭키! 와아아아!

어쨌든 이 럭키를 가지고 예제를 진행하겠습니다! 와아아! 글쓸 맛 난다!


일단 Love2D에서 뭔가 그린다는 건 좌표입니다.

저번의 배열에서 [y][x]로 처리했던것과 달리 이번엔 진짜 (x, y)꼴입니다.

와아아!



이런 럭키가 있으면 럭키의 x는 30, y는 10이 됩니다.

x 30, y 10에 그리면 저렇게 그려지는 겁니다.

(어쩐지 위키에 있는 그림이랑 똑같이 그려졌지만 럭키가 있으니 이쪽을 쓰겠습니다.)


하지만 파일이 있다고 바로 그릴 수 있는 게 아닙니다.

파일을 먼저 불러와야 합니다.

이것을 love.graphics.newImage로 불러옵니다.


[이미지] = love.graphics.newImage([파일경로])


[이미지] 부분에는 불러온 이미지를 식별할 수 있는 이름을,

[파일경로]에는 파일의 경로를 넣습니다.

Love2D의 main.lua와 같은 경로에 있으면 파일 이름만 적어도 됩니다.

이것을 유식한 말로 상대경로라고 합니다.


저는 pokemon이라는 이미지를 생성해보겠습니다.


pokemon = love.graphics.newImage("lucky.png")


공 식 위키에 따르면, 여러 번 실행되는 콜백(뭔지는 다뤘죠?)에서 저런 짓을 하면 상당히 게임이 느려진다고 합니다. 그러니까 그냥 한번만 불러온 뒤 (love.load 같은 콜백에서요!) 나중에 여러 번 호출하는 것이 훨씬 더 효율적이겠죠.

love.update나 love.draw같은 콜백에는 넣지 맙시다.


예제 코드:

function love.load()

pokemon = love.graphics.newImage("lucky.png")

end


이미지를 불러왔으니 이제 그릴 수 있습니다.

이미지를 그리는 것은 보통 love.draw 콜백에서 하게 됩니다.


love.graphics.draw(drawable, x, y, r, sx, sy, ox, oy, kx, ky) <br />

이게 뭔 개소리야?!

하나하나 뜯어봅시다.


Lua 글에서 설명했듯, 괄호 안에는 인수가 들어갑니다.

저기에 넣는 값에 따라 어떻게 그려질지가 달라지겠지요.


drawable는 그릴 수 있는 것이니, 이미지가 되겠네요.

방금 생성한 이미지 (예제에서는 pokemon)를 넣어주면 되겠습니다.


x랑 y는 뭔지 감이 잡히지 않습니까? 그림이 어디에 그려질지를 넣어주면 됩니다.

위의 그림이라면 x가 30이고 y가 10이겠지요.


r은 뭘까요? 회전시키는 겁니다.

그냥 그리고 싶을 때는 0을 넣습니다.


love.graphics.draw(pokemon, 100, 100, 0, 1, 1, 0, 0, 0, 0)

모르는 건 그냥 다 눈치껏 넣었을 때 어떻게 그려지냐면..



그럼 회전이니까 30도 돌리고 싶으면 어떻게 하나요? 30 넣으면 되나요?

위키에 조건이 있네요, 라디안으로 넣어달라고 합니다. 그게 뭐죠? 우걱우걱?

그래서 그냥 위키의 예제를 배껴서 math.rad(30) 를 넣었습니다.


love.graphics.draw(pokemon, 100, 100, math.rad(30), 1, 1, 0, 0, 0, 0)



얍.


주의할 점(?)은.. 기울어지면 좌표도 같이 기울어지는 듯 합니다.

90을 넣었더니 90도로 기울어지면서 아주 좌측의 창 테두리에 달라붙어 버리는 현상이;;

좀 더 파보면 좋겠지만 귀찮아서 생략,


sx랑 sy의 s는 scale의 약자입니다.

크기 조절!

기본값은 1이며, 넣은 만큼 크기가 줄어나거나 늘어듭니다.

0.5를 넣으면 반으로 줄어들고, 2를 넣으면 두배로 커집니다.

sx와 sy가 같을 필요는 없으며, 음수가 들어가면 그 쪽으로 잡아당겨서 커집니다.

그러니까.. -2를 넣으면 반으로 줄어드는 게 아니라 2배로 커지는데 좌표가 이동하면서 커집니다.

직접 한번 여러가지 해 보세요,



love.graphics.draw(pokemon, 100, 100, 0, 0.5, 1, 0, 0, 0, 0)

(가로를 반으로 축소)



love.graphics.draw(pokemon, 100, 100, 0, 1, 2, 0, 0, 0, 0)

(세로를 2배로 확대)


여담이지만 게임 엔진의 편리함을 몸으로 체험하고 있습니다.

빌려온 '세가의 신입 사원 교육 과정에서 배우는 게임 프로그래밍의 정석' 에서는 이미지의 확대, 축소, 회전을 큰 비중으로 다루고 있는데 엔진을 쓰면 코드 한 줄 쓰면 끝입니다.

얼핏 보니 회전을 다룰 때 삼각함수를 썼던가... 하지만 엔진을 쓰면 복잡한 수학은 그리 필요 없습니다.

하지만 엔진을 써도 어떻게 돌아가는지 원리는 알아야 합니다.

아니면, 엔진이 문제를 일으키면 속수무책이 되어버리던지, 엔진이 아직 없는 새로운 플랫폼에서 뭔가 개발하려면 무능해진다던지 하는 문제가 생깁니다.


ox와 oy는 뭘까요?

o는 아마 Origin, 시초? 뭐 그런 뜻입니다.

어디서부터 그릴지를 알려주는 것이라고 할 수 있습니다.



(위 그림은 예를 위해 그린 그림으로 실제 픽셀수와는 다릅니다.)


ox가 20, oy가 20이라면 그림의 20, 20 되는 점에서부터 그리기를 시작한다는 것입니다.

결과적으로 저렇게 잘린 럭키 이미지를 그리게 되는 것입니다.


이것만으로 '이미지를 다 그리게 되었다!' 라고 생각하면 좋겠지만...

타일 처리(뭔지는 나중에 설명해 드리겠습니다.)와 같은 것을 하기에는 아직 모자랍니다.

그래서 좀 더 찾아봤더니 Quad라는 것이 있는 고로 다음부터는 그 이야기를 해보겠습니다.


이미지 그리는 방법 2편, 기다려 주세요.

다음에는 Quad에 대해 파 보고, Quad가 뭔지, 어떻게 쓰는지 알아보겠습니다.

그리고는 Lua 소코반을 그래픽으로 옮기겠습니다... 모든 계획이 순조롭게 진행된다면요.


요약:

- Love2D에서 이미지를 그리기 전에 먼저 불러와야 한다.

- 불러오는 방법은 [이미지] = love.graphics.newImage([파일경로])

- 이미지를 그리기 위해서는 love.graphics.draw(drawable, x, y, r, sx, sy, ox, oy, kx, ky) .

- 일반적인 경우에 drawable, x, y만 지정해주고 sx, sy는 1, 나머지 인수는 다 0으로 지정해준다.

- 적절한 경우에 적절한 인수들을 적절히 사용하면 적절한 효과를 낼 수 있으며 이것을 적절히 사용하면 적절히 도움이 된다.
조회 수 :
812
등록일 :
2013.09.17
08:35:57 (*.209.135.92)
엮인글 :
게시글 주소 :
https://hondoom.com/zbxe/index.php?mid=study&document_srl=703469
List of Articles
번호 제목 글쓴이 조회 수 추천 수 날짜sort 최근 수정일
65 cocos2d-x 외부파일을 이용한 한글 처리 [1] 똥똥배 1938   2013-07-08 2013-09-13 07:29
cocos2d-x에서는 한글을 그냥 출력하려고 하면 깨져서 나온다. 이유는 VS 편집기에서는 ANSI코드 한글을 사용하는데, cocos2d-x에서 문자는 UTF-8 형식을 쓰기 때문이다. 이것을 해결하는 간단한 방법은 wchar_t wmsg[] = L"한글"; char msg[128]; WideChar...  
64 QT 프로젝트 배포에 필요한 거 똥똥배 602   2013-07-11 2013-07-11 04:25
일단 빌드한 EXE와 리소스 파일은 당연히 필요할 테고, 그 다음으로, QtCore4.dll QtGui4.dll 파일이 필요하다. 디버그 모드라면 QtCored4.dll, QtGuid4.dll 가 필요하겠지만, 디버그 모드를 배포할 생각은 아닐 것이므로 필요없을 듯. 하지만 이것만으로 끝난...  
63 cocos2d-x에서 schedule_selector 정의 변화 [1] 똥똥배 521   2013-08-19 2013-09-13 07:28
예전에 적은 글에는 터치와 업데이트를 활성화 시키는 법을 적어놨다. http://hondoom.com/zbxe/index.php?mid=study&document_srl=385031 이글은 cocos2d-1.0.1-x-0.9.1를 기준으로 적은 글인데, 최신버전으로 오면서 update의 정의에 대해서 변화가 생겼...  
62 cocos2d-x 게임을 iOS에 이식할 때 생기는 문제들 똥똥배 543   2013-08-26 2013-09-13 07:28
1. 윈도우 한정 명령어는 사용할 수 없다. 너무도 당연한 문제. 2. 한글 인코딩 문제 최신 VS을 사용하면 겪지 않을 문제일지 모르겠지만, 보통은 h나 cpp를 ANISI형식 문서로 만들 것이다. XCode에서는 Unicode나 UTF-8 형식을 쓰므로 소스에 박아둔 한글은 ...  
61 cocos2d-x Clipping Layer 수정 똥똥배 670   2013-09-10 2013-09-13 07:28
흔히 구글에서 찾아보면 다음과 같은 Clipping Layer 소스를 찾을 수 있다. CCEGLView::sharedOpenGLView()->setScissorInPoints( // scissorRect is the rectangle you want to show. clippingRegion.origin.x + getPosition().x, clippingRegion.origin.y + ...  
60 cocos2d-x CCMenuItem 자신을 지웠을 때 생기는 에러 똥똥배 442   2013-09-13 2013-09-13 07:28
CCMenuItem으로 메뉴를 생성하고 타겟과 셀렉터를 정해서 그 명령 안에서 자신을 지우게 되었을 경우 activate() 안에서 에러가 발생한다. 아직 activate()를 실행해야 되는데 remove 당했기 때문에 생긴 문제인데, 구글에서 검색해 본 결과, https://github.c...  
59 [Lua] 테이블 노루발 1422   2013-09-17 2013-09-17 08:13
이것은 Lua 문법입니다. Love2D와는 관계가 없습니다.  안녕하세요, 노루발입니다. 오늘은 테이블에 대해서 설명을 해보겠습니다.   테이블이란 쉽게 말해 변수를 묶은 겁니다. Lua상에서 뭔가 쌈빡하게 테이블을 쓰는 법도 있는 듯 하지만 저는 그냥 타 언어...  
58 love.update(dt) 에서 버벅이는 현상. 노루발 256   2013-09-17 2013-09-17 08:15
윈도우를 잡고 흔들거나 윈도우 사이로 잠시 전환하거나.. 등으로 원치 않는 렉이 발생할 시 dt의 값이 평소보다 크게 들어갑니다. (예를 들면, 평소에 0.25가 들어간다면 이번에는 3.1이 들어갑니다.) 이건 평소보다 더 많이 크기 때문에, dt를 가지고 타이...  
57 [Lua] Split 노루발 361   2013-09-17 2013-09-17 08:16
상황을 가정해보자. 웹 서버에 부탁해서 유희왕 덱의 리스트를 가져왔다. 원문은 대략 이렇다고 가정하자.   셰이프스내치x3 모린팬x3 트렌트x3 ...    보기엔 이렇지만 이걸 가져오면 아래와 같이 뜰 것이다. (웹 서버니까 HTML로 줌) 셰이프스내치x3<br>모...  
56 멘탈붕괴의 절정을 부르는 파일입출력 노루발 273   2013-09-17 2013-09-17 08:18
Love2D의 love.filesystem.load는 훼이크입니다. 파일을 로드하는 것 같지만 사실 lua 파일을 불러옴. love.filesystem.read도 그리 믿음직하지 못함. (고정 크기의 파일만 읽어옴) 우리가 믿을 수 있는 최후의 보루는 love.filesystem.lines 이었던 것입니다....  
55 Love2D? 개요, 설치, 실행. 노루발 465   2013-09-17 2013-09-17 08:20
love2d.org/Love2D 홈페이지. Lua로 2D 게임을 만드는 프레임워크입니다. 무료고, 오픈 소스이며, 윈도우, 맥, 리눅스에서 동작하며, 안드로이드에서 동작하게 하는 논의도 활발하다 합니다. 그럼 일단 받아봅시다. 아무리 좋아도 내 컴퓨터에 못 깔면 소용없...  
54 Love2D를 사용하기 위한 Lua 강좌: 입출력과 기본 노루발 706   2013-09-17 2013-09-17 08:21
Love2D 엔진은 Lua 기반이라 좋던 싫던 우리는 이미 Lua를 쓰고 있는 것입니다. 그래서 원활한 개발을 원한다면 Lua 언어를 알아두는 것이 좋습니다. 어 차피 Lua라는 게 알아먹기 쉽고 가벼우므로 게임 업게에 종사하는 디자이너 혹은 작가, 게임 디자이너가 ...  
53 Love2D를 사용하기 위한 Lua 강좌: 코딩 스타일, 변수 노루발 585   2013-09-17 2013-09-17 08:22
안녕하세요, 노루발입니다. 어제는 Lua에 대해 대강 알아보고 입력과 출력을 다뤄봤습니다. 출력은 print([출력할 것]), 입력은 io.read()였습니다. 일단 본격적인 프로그램 작성에 앞서 Lua의 코딩 스타일에 대해 알아보겠습니다. 코드를 작성하는 것을 코딩...  
52 Love2D를 사용하기 위한 Lua 강좌: 변수형 노루발 446   2013-09-17 2013-09-17 08:23
안녕하세요, 노루발입니다. 저번에 변수에 대해 다뤄보았습니다. 변수는 값을 담는 그릇이라고 했습니다. 그리고 루아는 변수 안에 있는 값이 숫자던 문자던 그냥 변수로 취급한다고 했고 "몇개를 살까요?" 라는 질문에 "ㄹ개" 라고 답할 수도 있다고 했습니...  
51 love.graphics.print 한국어 출력 노루발 431   2013-09-17 2013-09-17 08:24
Love2D 사용 시 한국어가 ㅁㅁㅁ이나 ??? 등으로 깨져 나와 해결책을 수소문하여 겨우 찾았다. 원래 중국어 등을 출력하기 위한 것이었으니 적절한 폰트를 쓴다면 한자나 히라가나등도 출력할 수 있을 것이다. function love.load() korfont = love.graphics....  
50 Love2D: 콜백 함수들 노루발 538   2013-09-17 2013-09-17 08:25
Love의 콜백 함수들은 love.run(가장 메인이 되는 겁니다.)에 의해 호출되며, 많은 작업들을 수행합니다. 이것들이 없다고 게임이 실행되지 않는다거나 하지는 않지만 좋은 게임을 만들기 위해선 이것들을 적재적소에 활용해야 합니다. 이미 아시는 분들도 있...  
49 [Love2D] 일단 뭔가 해보자 노루발 457   2013-09-17 2013-09-17 08:27
감기를 딛고 다시 재기... Lua로 초 간단한 원시적인 게임을 만들려고 합니다. 뭐냐하면 소코반이라고, 이렇게 말하시면 모르지만 푸쉬푸쉬라면 아시는 분들이 엄청 많으실겁니다. 이걸 그래픽조차 씌우지 않은 아스키로. ########## #    ..      # #    o  o...  
48 소코반: 맵을 초기화하자. 노루발 588   2013-09-17 2013-09-17 08:27
8*8 맵의 데이터가 담길 2차원 배열(테이블)을 초기화하는 코드이다. Map = {} for a = 1, 8 do     Map[a] = {}     for b = 1, 8 do         Map[a][b] = 0     end end Map 테이블의 [1][1]부터 [8][8]까지 모두 0이라는 값이 담기고 Map[0][0]이나 Map[1][...  
47 Lua 소코반: 맵을 뿌리자. 노루발 833   2013-09-17 2013-09-17 08:29
-- 맵 데이터를 저장하는 8*8의 2차원 배열 Map 생성 map = {} for a = 1, 8 do     map[a] = {}     for b = 1, 8 do         map[a][b] = 0     end end -- 맵 데이터 초기화 map[1][1] = 1 map[1][2] = 1 map[1][3] = 1 map[1][4] = 1 map[1][5] = 1 map[1]...  
46 Lua 소코반: 플레이어를 그리고 움직이게 해보자 노루발 758   2013-09-17 2013-09-17 08:30
오늘자 전체 코드입니다. 어제처럼 바뀐 부분만 설명해 봅니다. -- 플레이어 위치를 저장하는 변수 -- 초기 시작지점은 5, 5로 설정. playerx = 5 playery = 5 -- 움직인 횟수 저장 moves = 0 -- 맵 데이터를 저장하는 8*8의 2차원 배열 Map 생성 map = {} for...