한국어

Programming

twin 주소복사
조회 수 1159 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

캔버스는 터치가 가능하고 그림을 그릴 수 있으며, Ball 이나 이미지 스프라이트(ImageSprite)가 움직일 수 있는 사각형 영역입니다.

스프라이트는 영어로 "장난을 좋아하는 요정 또는 도깨비"라는 뜻인데요, 이미지 스프라이트는 캔버스 위에 그려지는 이미지로, 터치와 드래그가 가능하고 Ball 이나 ImageSprite와 같은 다른 스프라이트나 캔버스의 벽과 상호작용하는 컴포넌트입니다.  

이번 포스트에서는 이미지 스프라이트와 캔버스를 사용하는 예제 프로그램으로 Bouncing Ball, 즉 공 튀기기 예제를 만들어보겠습니다. 완성된 프로그램의 동작은 <그림1>의 동영상과 같습니다.

<그림 1> 실행동영상

디자인은 <그림 2>와 같이 Canvas, ImageSprite(이름은 myBall), Label과 Clock를 사용합니다. Clock의 Interval은 100ms로 수정합니다. 즉 0.1초에 한번씩 myBall의 위치를 바꾸어 그려줄겁니다.
 

<그림 2> 디자인

Canvas1은 배경색을 초록색으로 했습니다. ImageSprite는 이름을 myBall로 바꾸고 이미지를 축구공 이미지로 세팅했습니다. 크기는 50x50으로 주었습니다.

다음은 블록코딩입니다.

글로벌 변수를 4개 사용합니다. ballX, ballY는 축구공의 위치입니다. ImageSprite는 좌상점, 즉 이미지의 왼쪽 위쪽이 위치의 기준점입니다. dirX, dirY는 x 방향과 y 방향을 나타내는 변수로 1 또는 -1의 값을 갖게 합니다. dirX가 1이면 오른쪽, -1이면 왼쪽으로 이동합니다. dirY가 1이면 아래쪽으로 이동하고, -1이면 위쪽으로 이동하게 됩니다. 
처음에 축구공의 위치 ballX와 ballY를 (0,0)으로 만듭니다. dirX, dirY는 1로 초기화합니다. 그러니까 공은 캔버스의 맨 왼쪽 위에서 시작해서 오른쪽 아래방향으로 이동할 겁니다.

<그림 3> 4개의 글로벌 변수와 초기화

다음은 Clock1이 Timer 이벤트를 만들 때마다, 즉 0.1초마다 축구공의 위치를 바꾸어주는 코드입니다.

ballX의 위치는 dirX * 20 만큼 이동합니다. 즉 오른쪽 또는 왼쪽으로 20만큼 이동하는 겁니다. 처음에는 dirX가 +1이니까 오른쪽으로 이동하겠지요. x 방향이 바뀌는 경우는 공이 오른쪽 또는 왼쪽 벽에 맞을 때 입니다. 따라서 ballX >= Canvas1.Width - myBall.Width 또는 ballX <= 0 일 때 dirX = -1*dirX 로 방향을 바꿉니다.

같은 방법으로 y 방향도 타이머 이벤트 마다 dirY * 20 만큼 이동합니다. dirY가 1이면 +20이니까 아래방향, dirY가 -1이면 -20이니까 윗방향이 됩니다. y 방향이 바뀌는 경우는 공이 캔버스의 맨 아래 또는 캔버스의 맨 위를 맞을 때입니다. 따라서 ballY >= Canvas1.Height - myBall.Height 또는 ballY <= 0 일때   dirY = -1*dirY 로 부호를 바꿉니다.
 

<그림 4> 타이머 프로그램

좌표값을 계산한 후에는 myBall.MoveTo(ballX, ballY)로 공을 이동한 후 <그림 5>와 같이 Label1에 캔버스의 폭과 높이, myBall의 x, y 좌표를 출력합니다. Label1은 특별한 의미는 없고 값을 확인하기 위한 목적입니다. 
 

<그림 5> 앱 실행 화면

List of Articles
번호 제목 글쓴이 날짜 조회 수
31 [앱인벤터2] 말하는 Hello World 앱  twin 2018.08.27 1560
30 [앱인벤터] 위치센서 LocationSensor를 이용한 거리측정기  twin 2018.08.27 3122
29 [앱인벤터] 리스트를 이용하여 녹음이 되는 실로폰  twin 2018.08.27 5598
28 [앱인벤터] Sound를 이용한 실로폰 앱  twin 2018.08.27 1057
27 [앱인벤터] 내가 만든 앱을 구글 플레이스토어에 등록하는 방법  twin 2018.08.27 750
26 [앱인벤터] App Inventor 2 Tips  twin 2018.08.27 1402
25 [앱인벤터] 에뮬레이터, 녹스(nox) 앱플레이어 사용법  twin 2018.08.27 873
24 [앱인벤터] ActivityStarter 액티비티 스타터를 사용한 여행앱  twin 2018.08.27 1720
23 [앱인벤터] 성적계산기  twin 2018.08.27 1075
22 [앱인벤터] Camera & Share, 사진찍고 메모해서 공유하기  twin 2018.08.27 948
21 [앱인벤터]Player(플레이어)를 이용한 I have a dream 앱  twin 2018.08.27 1117
20 [앱인벤터] 카메라와 캔버스, PaintPot 앱  twin 2018.08.27 1360
19 [앱 인벤터] 캔버스와 이미지 스프라이트, 두더지잡기 게임(Molemash)  twin 2018.08.27 2780
18 [앱인벤터] 방향센서와 나침반  twin 2018.08.27 1195
» [앱인벤터2] 캔버스와 이미지스프라이트, Bouncing Ball 예제  twin 2018.08.27 1159
16 [앱인벤터2] 두 개의 스크린 사이의 값 전달, 구구단 예제  twin 2018.08.27 4328
15 [앱인벤터2] Slider를 사용하는 타이머  twin 2018.08.27 2235
14 [앱 인벤터2] 알람시계  twin 2018.08.27 3353
13 [앱 인벤터2] 위치센서와 문자 보내기, SOS 앱  twin 2018.08.27 2611
12 [앱인벤터2] 아날로그 시계 만들기  twin 2018.08.27 3004
Board Pagination Prev 1 2 3 Next
/ 3