PyGame 모듈은 다양한 기능을 지원하는데, 그 중에서 여러가지 도형을 그릴 수 있는 메소드들을 소개하도록 하겠습니다.


00. PyGame 지원되는 도형

PyGame에서 지원되는 도형은 다음과 같습니다.

메소드

도형

설명

 pygame.draw.rect

 사각형

 화면에 사각형을 그려줍니다.

 pygame.draw.polygon

 삼각형

 화면에 삼각혁을 그려줍니다.

 pygame.draw.circle

 원

 화면에 원을 그려줍니다.

 pygame.draw.ellipse

 타원

 화면에 타원을 그려줍니다.

 pygame.draw.arc

 원

 화면에 원하는 만큼의 원을 그려줍니다.

 원을 얼마나 그려줄지 정할 수 있습니다.

 pygame.draw.line

 선

 화면에 선을 그려줍니다.

 pygame.draw.lines

 여러 개의 선

 화면에 여러 개의 선을 이어서 그립니다.

 pygame.draw.aaline

 부드러운 선

 화면에 부드러운 선을 그려줍니다.

 pygame.draw.aalines

 부드러운 선들

 화면에 부드러운 선을 여러 개 이어서 그립니다.


여기서는 pygame.draw.lines를 이용하여 여러 개의 선을 그리는 방법을 살펴볼 것입니다.

만약 다른 draw 메소드를 참고하고 싶으시다면 아래의 링크에서 선택하시면 될 것 같습니다.




사각형 - pygame.draw.rect

삼각형 - pygame.draw.polygon

원 - pygame.draw.circle

타원 - pygame.draw.ellipse

원(특정 부분까지 그리기) - pygame.draw.arc

선 - pygame.draw.line

부드러운 선 - pygame.draw.aaline

여러 개의 부드러운 선 - pygame.draw.aalines



01. pygame.draw.lines 함수

pygame에서 지원하는 여러 개의 선 그리기 함수인 lines 함수는 다음과 같은 인자값들을 받습니다.



 pygame.draw.lines(Surface, Color, Closed, PointList, Width=1)

  Draw a sequence of lines on a Surface. The pointlist argument is a series of points that are connected by a line. If the closed argument is true an additional line segment is drawn between the first and last points.

  This does not draw any endcaps or miter joints. Lines with sharp corners and wide line widths can have improper looking corners.




변수 

설명

Surface

 pygame을 실행할 때 전체적으로 화면을 선언한 변수 값

Color

 선의 색깔로 (R, G, B)의 형태로 데이터의 값을 삽입함

Closed

 이어지는 여러 개의 선을 다 그리고 하나의 구역으로 설정할지 결정

PointList

 여러 개의 선을 그릴 위치들을 입력함

Width

 선의 두께를 말하며, 기본적으로 1으로 설정됨


위의 변수들은 예제 소스코드를 통해 설명하도록 하겠습니다.


02. pygame.draw.lines를 이용한 여러 개의 선 그리기(예제)

먼저 소스코드를 살펴보면 다음과 같습니다.


Source

# Import a library of functions called 'pygame'
import pygame

# Initialize the game engine
pygame.init()
 
# Define the colors we will use in RGB format
BLACK = (  0,   0,   0)
WHITE = (255, 255, 255)
BLUE  = (  0,   0, 255)
GREEN = (  0, 255,   0)
RED   = (255,   0,   0)
 
# Set the height and width of the screen
size   = [400, 300]
screen = pygame.display.set_mode(size)
 
pygame.display.set_caption("Drawing Rectangle")
 
#Loop until the user clicks the close button.
done = False
clock = pygame.time.Clock()
 
while not done:
 
    # This limits the while loop to a max of 10 times per second.
    # Leave this out and we will use all CPU we can.
    clock.tick(10)
     
    for event in pygame.event.get(): # User did something
        if event.type == pygame.QUIT: # If user clicked close
            done=True # Flag that we are done so we exit this loop
 
    # All drawing code happens after the for loop and but
    # inside the main while done==False loop.
     
    # Clear the screen and set the screen background
    screen.fill(WHITE)

    # Draw on the screen a RED lines from (0,80) to (50, 90) to (200, 80) to (220, 30) 
    # 5 pixels wide.
    pygame.draw.lines(screen, RED, False, [[0, 80], [50, 90], [200, 80], [220, 30]], 5)

    # Draw on the screen a BLUE lines from (100,180) to (150,190) to (300,180) to (320,130) 
    # 5 pixels wide.
    pygame.draw.lines(screen, BLUE, True, [[100, 180], [150, 190], [300, 180], [320, 130]], 5)
     
    # Go ahead and update the screen with what we've drawn.
    # This MUST happen after all the other drawing commands.
    pygame.display.flip()
 
# Be IDLE friendly
pygame.quit()

전체적인 소스는 위와 같습니다.

이제 아래에서는 소스를 특정하여 나눠서 설명을 해보도록 하겠습니다.



Variable - Surface

# Set the height and width of the screen
size   = [400, 300]
screen = pygame.display.set_mode(size)

먼저, 16번째 줄의 screen 변수를 보면, 해당 변수에는 화면 전체를 설정하기 위한 값이 들어가 있습니다.

화면을 새로고침 해주거나, 화면을 채워주거나 할 때 해당 변수를 이용합니다.

pygame.draw.lines 함수의 Surface는 이러한 화면 설정 변수를 넣어주시면 됩니다.


Variable - Color

# Define the colors we will use in RGB format
BLACK = (  0,   0,   0)
WHITE = (255, 255, 255)
BLUE  = (  0,   0, 255)
GREEN = (  0, 255,   0)
RED   = (255,   0,   0)

다음으로, 8 ~ 12번 라인을 보시면, Tuple 형태의 값이 설정되어 있는 것을 보실 수 있습니다.

세 개의 값이 0 ~ 255의 범위를 가지게 되는데, 이렇게 설정된 값이 색깔(RGB) 값으로 Color 변수가 들어갈 곳에 넣어주시면 됩니다.


Variable - Closed

    # Draw on the screen a RED lines from (0,80) to (50, 90) to (200, 80) to (220, 30) 
    # 5 pixels wide.
    pygame.draw.lines(screen, RED, False, [[0, 80], [50, 90], [200, 80], [220, 30]], 5)

    # Draw on the screen a BLUE lines from (100,180) to (150,190) to (300, 180) to (320, 130) 
    # 5 pixels wide.
    pygame.draw.lines(screen, BLUE, True, [[100, 180], [150, 190], [300, 180], [320, 130]], 5)

먼저 42번째 라인과 46번째 라인을 살펴보면 False와 True로 되어 있는 인자값을 보실 수 있습니다.

42번째 라인의 값의 False일 경우는 빨간색 선으로 보시면 되고,

46번째 라인의 값의 True일 경우는 파란색 선으로 보시면 됩니다.



빨간색 선을 보면 하나의 구역으로 나눠지지 않고, 선분만 이어져있는 것을 볼 수 있습니다.

파란색 선을 보면 하나의 구역으로 나눠져서 선분들이 이어져 있는 곳을 사각형으로 만들어낸 모습으로 보입니다.

파란색 선처럼 구역을 Closed 하고 싶을 때는 True, 빨간색 선처럼 구역이 없이 선만 그리고 싶을 때는 False를 하면 됩니다.


Variable - Width

    # Draw on the screen a RED lines from (0,80) to (50, 90) to (200, 80) to (220, 30) 
    # 5 pixels wide.
    pygame.draw.lines(screen, RED, False, [[0, 80], [50, 90], [200, 80], [220, 30]], 5)

    # Draw on the screen a BLUE lines from (100,180) to (150,190) to (300, 180) to (320, 130) 
    # 5 pixels wide.
    pygame.draw.lines(screen, BLUE, True, [[100, 180], [150, 190], [300, 180], [320, 130]], 5)

42번째 라인과 46번째 라인을 보시면 두 함수의 선 두께가 모두 5로 같은 것을 볼 수 있습니다.

기본적으로 lines 함수의 경우 Width가 1로 되어 있으나, 이를 수정해줄 수 있습니다.

단, 0 이하의 수는 사용할 수 없습니다.

만약 사용하더라도 선이 그려지지 않습니다.(선의 두께가 0이라는 것은 선이 없다라는 걸 의미하지요.)



+ Recent posts