Introduction to pygame
Game programming is very rewarding nowadays and it can also be used in advertising and as a teaching tool too. Game development includes mathematics, logic, physics, AI and much more and it can be amazingly fun. In python, game programming is done in pygame
and it is one of the best modules for doing so.
Installing pygame:
Pygame requires Python; if you don’t already have it, you can download it from python.org. Use python 3.6.1 or greater, because it is much friendlier to newbies, and additionally runs faster.
The best way to install pygame
is with the pip tool (which python uses to install packages). Note, this comes with python in recent versions. We use the --user
flag to tell it to install into the home directory, rather than globally.
python3 -m pip install -U pygame --user
To see if it works, run one of the included examples:
python3 -m pygame.examples.aliens
If it works, we are ready to go!
Once you have installed pygame
, you’re ready to create your very first pygame instance.
# import the pygame module import pygame # import pygame.locals for easier # access to key coordinates from pygame. locals import * # Define our square object and call super to # give it all the properties and methods of pygame.sprite.Sprite # Define the class for our square objects class Square(pygame.sprite.Sprite): def __init__( self ): super (Square, self ).__init__() # Define the dimension of the surface # Here we are making squares of side 25px self .surf = pygame.Surface(( 25 , 25 )) # Define the color of the surface using RGB color coding. self .surf.fill(( 0 , 200 , 255 )) self .rect = self .surf.get_rect() # initialize pygame pygame.init() # Define the dimensions of screen object screen = pygame.display.set_mode(( 800 , 600 )) # instantiate all square objects square1 = Square() square2 = Square() square3 = Square() square4 = Square() # Variable to keep our game loop running gameOn = True # Our game loop while gameOn: # for loop through the event queue for event in pygame.event.get(): # Check for KEYDOWN event if event. type = = KEYDOWN: # If the Backspace key has been pressed set # running to false to exit the main loop if event.key = = K_BACKSPACE: gameOn = False # Check for QUIT event elif event. type = = QUIT: gameOn = False # Define where the squares will appear on the screen # Use blit to draw them on the screen surface screen.blit(square1.surf, ( 40 , 40 )) screen.blit(square2.surf, ( 40 , 530 )) screen.blit(square3.surf, ( 730 , 40 )) screen.blit(square4.surf, ( 730 , 530 )) # Update the display using flip pygame.display.flip() |
The above python code is a simple pygame
script to draw four cyan color squares. Don’t worry! We will learn a lot more about how to make an object move, how to add animation effects, buttons, music and much more in the next few articles but for now let’s understand this basic code which contains all the necessary pygame elements.
import pygame from pygame.locals import *
In the first few lines, we import pygame and pygame.locals
which is necessary to do before using any module in python.
Sprite, Surf and Rect:
Sprite: Sprite is just a 2d object that we draw on the screen. We can use them by extending the sprite class.
Surf: Surfaces are like blank sheet of paper on which we draw. Our screen object is also a Surface. They can hold images as well.
Rects: Rectangular area that we define on a surface.
class Square(pygame.sprite.Sprite): def __init__( self ): super (Square, self ).__init__() self .surf = pygame.Surface(( 25 , 25 )) self .surf.fill(( 0 , 200 , 255 )) self .rect = self .surf.get_rect() |
Note: We are using RGB format of color coding in which we can form different colors by giving Red, Blue and Green color values in the range of 0-255. A tuple of (0, 0, 0) is the color black as there is no color present and a tuple of (255, 255, 255) is the color white.
In our code we are extending the sprite class so that we can use surfs and rects to draw our squares.We have made a surface of dimension 25x25px and filled it will a color: (0, 200, 255)
pygame.init() :
pygame.init() screen = pygame.display.set_mode(( 800 , 600 )) square1 = Square() square2 = Square() square3 = Square() square4 = Square() |
The above lines of code initialize pygame using the command pygame.init()
which is necessary to use the pygame module commands. After that we define our screen object and its dimensions in pixels. Then in the next lines we initialize our four squares.
Game Loop
while running: for event in pygame.event.get(): if event. type = = KEYDOWN: if event.key = = K_BACKSPACE: running = False elif event. type = = QUIT: running = False |
The most important part of game development code is the game loop. This loop continuously runs in the background until the user ends the game or the game is over. Right now our game loop is not much to look forward to. It only tracks two basic events. We can add more events according to game state, user inputs and much more but the point to remember here is that the game loop must end after some condition else the user will be stuck in the game loop forever.
Blit and Flip –
Blit: Blit keyword is used to draw a surface on another surface. In simple words when we draw a surface we just blit it onto some other surface.
Flip: It is used to update the entire screen after everything is drawn. Remember that the flip only works after drawing all the necessary surfaces otherwise it will update nothing.
screen.blit(square1.surf, ( 40 , 40 )) screen.blit(square2.surf, ( 40 , 530 )) screen.blit(square3.surf, ( 730 , 40 )) screen.blit(square4.surf, ( 730 , 530 )) pygame.display.flip() |
In the above lines of code first we blit four squares on the screen and then we flip to make them appear.
Recommended Posts:
- Python | Display images with PyGame
- Python | Drawing different shapes on PyGame window
- Python | Display text to PyGame window
- Introduction to TensorFlow
- Introduction to OpenCV
- CNN | Introduction to Pooling Layer
- Python | Introduction to PyQt5
- Python | Introduction to Matplotlib
- Python Language Introduction
- Multiprocessing in Python | Set 1 (Introduction)
- NumPy in Python | Set 1 (Introduction)
- Django Introduction and Installation
- Introduction to Tensor with Tensorflow
- Introduction to Convolutions using Python
- K means Clustering - Introduction
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.