Pygame Front Page¶
Quick start¶
Welcome to pygame! Once you've got pygame installed (pip install pygame
or
pip3 install pygame
for most people), the next question is how to get a game
loop running. Pygame, unlike some other libraries, gives you full control of program
execution. That freedom means it is easy to mess up in your initial steps.
Here is a good example of a basic setup (opens the window, updates the screen, and handles events)--
# Example file showing a basic pygame "game loop"
import pygame
# pygame setup
pygame.init()
screen = pygame.display.set_mode((1280, 720))
clock = pygame.time.Clock()
running = True
while running:
# poll for events
# pygame.QUIT event means the user clicked X to close your window
for event in pygame.event.get():
if event.type == pygame.QUIT:
running = False
# fill the screen with a color to wipe away anything from last frame
screen.fill("purple")
# RENDER YOUR GAME HERE
# flip() the display to put your work on screen
pygame.display.flip()
clock.tick(60) # limits FPS to 60
pygame.quit()
Here is a slightly more fleshed out example, which shows you how to move something (a circle in this case) around on screen--
# Example file showing a circle moving on screen
import pygame
# pygame setup
pygame.init()
screen = pygame.display.set_mode((1280, 720))
clock = pygame.time.Clock()
running = True
dt = 0
player_pos = pygame.Vector2(screen.get_width() / 2, screen.get_height() / 2)
while running:
# poll for events
# pygame.QUIT event means the user clicked X to close your window
for event in pygame.event.get():
if event.type == pygame.QUIT:
running = False
# fill the screen with a color to wipe away anything from last frame
screen.fill("purple")
pygame.draw.circle(screen, "red", player_pos, 40)
keys = pygame.key.get_pressed()
if keys[pygame.K_w]:
player_pos.y -= 300 * dt
if keys[pygame.K_s]:
player_pos.y += 300 * dt
if keys[pygame.K_a]:
player_pos.x -= 300 * dt
if keys[pygame.K_d]:
player_pos.x += 300 * dt
# flip() the display to put your work on screen
pygame.display.flip()
# limits FPS to 60
# dt is delta time in seconds since last frame, used for framerate-
# independent physics.
dt = clock.tick(60) / 1000
pygame.quit()
For more in depth reference, check out the Tutorials section below, check out a video tutorial (I'm a fan of this one), or reference the API documentation by module.
Documents¶
- Readme
Basic information about pygame: what it is, who is involved, and where to find it.
- Install
Steps needed to compile pygame on several platforms. Also help on finding and installing prebuilt binaries for your system.
- File Path Function Arguments
How pygame handles file system paths.
- Pygame Logos
The logos of Pygame in different resolutions.
- LGPL License
This is the license pygame is distributed under. It provides for pygame to be distributed with open source and commercial software. Generally, if pygame is not changed, it can be used with any type of program.
Tutorials¶
- Introduction to Pygame
An introduction to the basics of pygame. This is written for users of Python and appeared in volume two of the Py magazine.
- Import and Initialize
The beginning steps on importing and initializing pygame. The pygame package is made of several modules. Some modules are not included on all platforms.
- How do I move an Image?
A basic tutorial that covers the concepts behind 2D computer animation. Information about drawing and clearing objects to make them appear animated.
- Chimp Tutorial, Line by Line
The pygame examples include a simple program with an interactive fist and a chimpanzee. This was inspired by the annoying flash banner of the early 2000s. This tutorial examines every line of code used in the example.
- Sprite Module Introduction
Pygame includes a higher level sprite module to help organize games. The sprite module includes several classes that help manage details found in almost all games types. The Sprite classes are a bit more advanced than the regular pygame modules, and need more understanding to be properly used.
- Surfarray Introduction
Pygame used the NumPy python module to allow efficient per pixel effects on images. Using the surface arrays is an advanced feature that allows custom effects and filters. This also examines some of the simple effects from the pygame example, arraydemo.py.
- Camera Module Introduction
Pygame, as of 1.9, has a camera module that allows you to capture images, watch live streams, and do some basic computer vision. This tutorial covers those use cases.
- Newbie Guide
A list of thirteen helpful tips for people to get comfortable using pygame.
- Making Games Tutorial
A large tutorial that covers the bigger topics needed to create an entire game.
- Display Modes
Getting a display surface for the screen.
- 한국어 튜토리얼 (Korean Tutorial)
빨간블록 검은블록
Reference¶
- Index
A list of all functions, classes, and methods in the pygame package.
- pygame.BufferProxy
An array protocol view of surface pixels
- pygame.Color
Color representation.
- pygame.cursors
Loading and compiling cursor images.
- pygame.display
Configure the display surface.
- pygame.draw
Drawing simple shapes like lines and ellipses to surfaces.
- pygame.event
Manage the incoming events from various input devices and the windowing platform.
- pygame.examples
Various programs demonstrating the use of individual pygame modules.
- pygame.font
Loading and rendering TrueType fonts.
- pygame.freetype
Enhanced pygame module for loading and rendering font faces.
- pygame.gfxdraw
Anti-aliasing draw functions.
- pygame.image
Loading, saving, and transferring of surfaces.
- pygame.joystick
Manage the joystick devices.
- pygame.key
Manage the keyboard device.
- pygame.locals
Pygame constants.
- pygame.mixer
Load and play sounds
- pygame.mouse
Manage the mouse device and display.
- pygame.mixer.music
Play streaming music tracks.
- pygame
Top level functions to manage pygame.
- pygame.PixelArray
Manipulate image pixel data.
- pygame.Rect
Flexible container for a rectangle.
- pygame.scrap
Native clipboard access.
- pygame.sndarray
Manipulate sound sample data.
- pygame.sprite
Higher level objects to represent game images.
- pygame.Surface
Objects for images and the screen.
- pygame.surfarray
Manipulate image pixel data.
- pygame.tests
Test pygame.
- pygame.time
Manage timing and framerate.
- pygame.transform
Resize and move images.
- pygame C API
The C api shared amongst pygame extension modules.
- Search Page
Search pygame documents by keyword.
Edit on GitHub