SlideShare uma empresa Scribd logo
1 de 39
Baixar para ler offline
Introduction to 
Presented by 
Felix Homann 
@Felix11H 
felix11h.github.io/ 
Slides 
Slideshare: 
tiny.cc/pyg-into 
Source: 
tiny.cc/pyg-into-github 
References 
- Pygame website: pygame.org 
- Richard Jones' Pygame lecture: 
- recording on Youtube 
- code samples on Bitbucket 
- List of keys: 
pygame.org/docs/ref/key.html 
This work is licensed under a Creative Commons Attribution 4.0 International License.
http://www.pygame.org 
Pygame is a Python wrapper around the SDL library (Simple 
DirectMedia Layer) with a few unique libraries with an emphasis on 
game programming, written by Pete Shinners.
From the FAQ 
Does not require OpenGL 
Uses either opengl, directx, windib, X11, linux frame buer, 
and many other dierent backends... including an ASCII art 
backend! 
Truly portable 
Supports Linux, Windows, Windows CE, BeOS, MacOS, Mac 
OS X, FreeBSD, NetBSD, OpenBSD, BSD/OS, Solaris, IRIX, 
and QNX . . . 
Silliness built in!
A simple Pygame example 
1 import pygame 
2 
3 pygame.init() 
4 screen = pygame.display.set_mode((640, 480)) 
5 
6 color = [(0,0,0),(255,255,255)] 
7 running = True 
8 
9 while running: 
10 for event in pygame.event.get(): 
11 if event.type == pygame.QUIT: 
12 running = False 
13 if event.type == pygame.KEYDOWN: 
14 color[0], color[1] = color[1],color[0] 
15 
16 screen.fill(color[0]) 
17 pygame.display.flip() 
01-simple_pygame.py
What each element does: Importing  Initializing 
import pygame 
to import the Pygame module. 
from pygame.locals import * 
Optional. Puts limited set of constant and function in the global 
namespace. 
pygame.init() 
to initialize Pygame's modules (e.g. pygame.font). Not always 
needed, but recommended in any case.
What each element does: Setting Window  Screen 
screen = pygame.display.set_mode((640, 480)) 
initializes a window with dimensions 640  480 and returns the 
screen object. 
Everything to be displayed needs to be drawn on the screen.
Initializing a Pygame window 
Together: 
1 import pygame 
2 
3 pygame.init() 
4 screen = pygame.display.set_mode((640, 480)) 
02-window.py
Initializing a Pygame window - Extended 
1 import pygame 
2 
3 pygame.init() 
4 screen = pygame.display.set_mode((640, 480)) 
5 
6 running = True 
7 while running: 
8 for event in pygame.event.get(): 
9 if event.type == pygame.QUIT: 
10 running = False
What each element does: The Main Loop 
1 running = True 
2 while running: 
3 for event in pygame.event.get(): 
4 if event.type == pygame.QUIT: 
5 running = False 
6 if event.type == pygame.KEYDOWN: 
7 color[0], color[1] = color[1],color[0] 
8 
9 screen.fill(color[0]) 
10 pygame.display.flip() 
is the main loop of the game. 
I listen to events ! respond 
I proceed the game 
I draw on the screen 
I stop when done
A framework for your Pygames 
1 import pygame 
2 
3 pygame.init() 
4 screen = pygame.display.set_mode((640, 480)) 
5 
6 running = True 
7 while running: 
8 for event in pygame.event.get(): 
9 if event.type == pygame.QUIT: 
10 running = False 
11 if event.type == pygame.KEYDOWN: 
12 react_to_user_input() 
13 
14 do_things_the_game_does() 
15 draw_everything_on_the_screen() 
Next: 
I Drawing 
I User Input 
I Game Events
Drawing
Drawing on the screen I 
Filling the screen with a color: 
1 blue = (0,0,255) 
2 screen.fill(blue) 
3 pygame.display.flip() 
After all drawing is done, call display.flip() to update the 
display. 
Use pygame.draw to draw geometric shapes. A circle: 
1 red = (255,0,0) 
2 # position (320,240), radius = 50 
3 pygame.draw.circle(screen, red, (320,240), 50)
Drawing on the screen II 
Geometric shapes available for pygame.draw: 
circle(Surface, color, pos, radius, width=0) 
polygon(Surface, color, pointlist, width=0) 
line(Surface, color, start, end, width= 1) 
rect(Surface, color, Rect, width=0) 
ellipse(Surface, color, Rect, width=0) 
Example: 
1 red = (255,0,0) 
2 pygame.draw.line(screen, red, (10,50),(30,50),10)
Drawing on the screen - Colors 
De
ning a color 
gray = (200,200,200) 
#(red, green, blue) 
Use for example colorpicker.com:
Drawing on the screen - Positions 
De
ning a position: 
P = (11,9) 
#(x-axis, y-axis) 
To the reference coordinate system
Drawing on the screen - Rects 
pygame.Rect(left, top, width, height) 
to create a Rect. 
1 box = pygame.Rect(10, 10, 100, 40) 
2 pygame.draw.rect(screen, blue, box) 
3 #draws at (10,10) rectangle of width 100, height 40 
Rect anchors: 
top, left, bottom, right 
topleft, bottomleft, topright, bottomright 
midtop, midleft, midbottom, midright 
center, centerx, centery 
size, width, height 
w,h
A full drawing example 
1 import pygame 
2 
3 pygame.init() 
4 screen = pygame.display.set_mode((640, 480)) 
5 
6 white = (255,255,255) 
7 blue = (0,0,255) 
8 
9 running = True 
10 while running: 
11 for event in pygame.event.get(): 
12 if event.type == pygame.QUIT: 
13 running = False 
14 
15 screen.fill(white) 
16 pygame.draw.circle(screen, blue, (320,240), 100) 
17 # position (320,240), radius = 100 
18 
19 pygame.display.flip() 
04-drawing.py.
User Input
Events 
get all events in Pygame's event queue 
pygame.event.get() 
usually used as 
1 for event in pygame.event.get(): 
2 if event.type == YourEvent: 
3 react_to_your_event()
Event types 
Some of the most important event types are: 
pygame.QUIT 
pygame.KEYDOWN 
pygame.KEYUP 
pygame.USEREVENT 
With 
from pygame.locals import * 
from earlier, pre
x pygame isn't needed.
Events 
React to KEYDOWN event: 
1 while running: 
2 for event in pygame.event.get(): 
3 if event.type == KEYDOWN: 
4 react_to_key() 
Which key? ! if event type is KEYDOWN or KEYUP event has 
attribute key. 
1 for event in pygame.event.get(): 
2 if event.type == KEYDOWN: 
3 if event.key == K_ESCAPE: 
4 running = False
Pygame Keys 
Some of the most important keys are: 
K_RETURN 
K_SPACE 
K_ESCAPE 
K_UP, K_DOWN, K_LEFT, K_RIGHT 
K_a, K_b, ... 
K_0, K_1, ... 
Full list of keys: http://www.pygame.org/docs/ref/key.html
Getting continuous input 
KEYDOWN is a unique event. 
key = pygame.key.get_pressed() 
to get keys currently pressed. 
if key[pygame.K_UP]: 
move_up() 
to check and react on a speci
c key.
A user input example 
1 color = [0,0,0] 
2 
3 while running: 
4 for event in pygame.event.get(): 
5 if event.type == pygame.QUIT: 
6 running = False 
7 if event.type == KEYDOWN and event.key == K_SPACE: 
8 color = [0,0,0] 
9 
10 keys = pygame.key.get_pressed() 
11 if keys[K_UP]: 
12 color = [(rgb+1)%256 for rgb in color] 
13 
14 screen.fill(color) 
15 pygame.display.flip() 
05-user_input.py
Pygame's Clock
Limiting the frames per second 
clock = pygame.time.Clock() 
to initialize the clock. 
In your main loop call 
clock.tick(60) #limit to 60 fps
Clock example 
1 clock = pygame.time.Clock() 
2 
3 while running: 
4 for event in pygame.event.get(): 
5 if event.type == pygame.QUIT: 
6 running = False 
7 if event.type == KEYDOWN and event.key == K_SPACE: 
8 color = [0,0,0] 
9 
10 keys = pygame.key.get_pressed() 
11 if keys[K_UP]: 
12 color = [(rgb+1)%256 for rgb in color] 
13 
14 screen.fill(color) 
15 pygame.display.flip() 
16 
17 clock.tick(60) 
06-clock.py
Game Events
Sprites 
Pygame's sprite class gives convenient options for handling 
interactive graphical objects. 
If you want to draw and move (or manipulate) and object, make it 
a sprite. 
Sprites 
can be grouped together 
are easily drawn to a surface (even as a group!) 
have an update method that can be modi
ed 
have collision detection
Basic Sprite 
1 class SpriteExample(pygame.sprite.Sprite): 
2 
3 def __init__(self): 
4 pygame.sprite.Sprite.__init__(self) 
5 
6 self.image = #image 
7 self.rect = #rect 
8 
9 def update(self): 
10 pass
Sprite from a local image 
1 class SpriteExample(pygame.sprite.Sprite): 
2 
3 def __init__(self): 
4 pygame.sprite.Sprite.__init__(self) 
5 
6 self.image = pygame.image.load('local_img.png') 
7 self.rect = self.image.get_rect() 
8 self.rect.topleft = (80,120) 
9 
10 def update(self): 
11 pass
Self-drawn sprites: Rectangle 
1 class Rectangle(pygame.sprite.Sprite): 
2 
3 def __init__(self): 
4 pygame.sprite.Sprite.__init__(self) 
5 self.image = pygame.Surface([200, 50]) 
6 self.image.fill(blue) 
7 self.rect = self.image.get_rect() 
8 self.rect.top, self.rect.left = 100, 100 
9 
10 def update(self): 
11 pass
Sprites: A reminder about classes 
1 class Rectangle(pygame.sprite.Sprite): 
2 
3 def __init__(self, color): 
4 pygame.sprite.Sprite.__init__(self) 
5 self.image = pygame.Surface([200, 50]) 
6 self.image.fill(color) 
7 self.rect = self.image.get_rect() 
8 self.rect.top, self.rect.left = 100, 100 
9 
10 def update(self): 
11 pass 
1 white, blue = (255,255,255), (0,0,255) 
2 
3 white_rect = Rectangle(white) 
4 blue_rect = Rectangle(blue)
Sprite groups 
new_sprite_group = pygame.sprite.Group(sprite1) 
to create a new sprite group containing sprite sprite1. 
new_sprite_group.add(sprite2) 
to add another sprite later. 
Group updating and drawing: 
1 #inside main loop: 
2 
3 new_sprite_group.update() #game events 
4 new_sprite_group.draw() #drawing

Mais conteúdo relacionado

Mais procurados

Date and Time Module in Python | Edureka
Date and Time Module in Python | EdurekaDate and Time Module in Python | Edureka
Date and Time Module in Python | EdurekaEdureka!
 
Introduction to Game Design
Introduction to Game DesignIntroduction to Game Design
Introduction to Game DesignMartin Sillaots
 
game project presentation
game project presentationgame project presentation
game project presentationKavi Kumar
 
Game Development with Unity
Game Development with UnityGame Development with Unity
Game Development with Unitydavidluzgouveia
 
Project presentation FPS
Project presentation FPSProject presentation FPS
Project presentation FPSShubham Rajput
 
Introduction to the basics of Python programming (part 1)
Introduction to the basics of Python programming (part 1)Introduction to the basics of Python programming (part 1)
Introduction to the basics of Python programming (part 1)Pedro Rodrigues
 
Operators and Control Statements in Python
Operators and Control Statements in PythonOperators and Control Statements in Python
Operators and Control Statements in PythonRajeswariA8
 
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...Edureka!
 
Python: Modules and Packages
Python: Modules and PackagesPython: Modules and Packages
Python: Modules and PackagesDamian T. Gordon
 
Understanding casual games
Understanding casual gamesUnderstanding casual games
Understanding casual gamesDori Adar
 
Python | What is Python | History of Python | Python Tutorial
Python | What is Python | History of Python | Python TutorialPython | What is Python | History of Python | Python Tutorial
Python | What is Python | History of Python | Python TutorialQA TrainingHub
 
Unity - Essentials of Programming in Unity
Unity - Essentials of Programming in UnityUnity - Essentials of Programming in Unity
Unity - Essentials of Programming in UnityNexusEdgesupport
 
Introduction to Unity3D Game Engine
Introduction to Unity3D Game EngineIntroduction to Unity3D Game Engine
Introduction to Unity3D Game EngineMohsen Mirhoseini
 

Mais procurados (20)

Date and Time Module in Python | Edureka
Date and Time Module in Python | EdurekaDate and Time Module in Python | Edureka
Date and Time Module in Python | Edureka
 
Unity3D Programming
Unity3D ProgrammingUnity3D Programming
Unity3D Programming
 
Unity 3d Basics
Unity 3d BasicsUnity 3d Basics
Unity 3d Basics
 
Introduction to Game Design
Introduction to Game DesignIntroduction to Game Design
Introduction to Game Design
 
game project presentation
game project presentationgame project presentation
game project presentation
 
Game Development with Unity
Game Development with UnityGame Development with Unity
Game Development with Unity
 
Project presentation FPS
Project presentation FPSProject presentation FPS
Project presentation FPS
 
Introduction to the basics of Python programming (part 1)
Introduction to the basics of Python programming (part 1)Introduction to the basics of Python programming (part 1)
Introduction to the basics of Python programming (part 1)
 
Operators and Control Statements in Python
Operators and Control Statements in PythonOperators and Control Statements in Python
Operators and Control Statements in Python
 
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...
Tkinter Python Tutorial | Python GUI Programming Using Tkinter Tutorial | Pyt...
 
Python
PythonPython
Python
 
First-person Shooters
First-person ShootersFirst-person Shooters
First-person Shooters
 
Python: Modules and Packages
Python: Modules and PackagesPython: Modules and Packages
Python: Modules and Packages
 
Python Basics
Python BasicsPython Basics
Python Basics
 
Understanding casual games
Understanding casual gamesUnderstanding casual games
Understanding casual games
 
GUI programming
GUI programmingGUI programming
GUI programming
 
Python | What is Python | History of Python | Python Tutorial
Python | What is Python | History of Python | Python TutorialPython | What is Python | History of Python | Python Tutorial
Python | What is Python | History of Python | Python Tutorial
 
Unity - Essentials of Programming in Unity
Unity - Essentials of Programming in UnityUnity - Essentials of Programming in Unity
Unity - Essentials of Programming in Unity
 
Python programming : Files
Python programming : FilesPython programming : Files
Python programming : Files
 
Introduction to Unity3D Game Engine
Introduction to Unity3D Game EngineIntroduction to Unity3D Game Engine
Introduction to Unity3D Game Engine
 

Destaque

Minecraft in 500 lines of Python with Pyglet
Minecraft in 500 lines of Python with PygletMinecraft in 500 lines of Python with Pyglet
Minecraft in 500 lines of Python with PygletRichard Donkin
 
Powerpoint Guidelines
Powerpoint GuidelinesPowerpoint Guidelines
Powerpoint GuidelinesKathryn Harth
 
Slide Presentation Guidelines
Slide Presentation GuidelinesSlide Presentation Guidelines
Slide Presentation GuidelinesPlusOrMinusZero
 
Денис Ковалев «Python в игровой индустрии»
Денис Ковалев «Python в игровой индустрии»Денис Ковалев «Python в игровой индустрии»
Денис Ковалев «Python в игровой индустрии»DataArt
 
Introduction to Python
Introduction to PythonIntroduction to Python
Introduction to PythonNowell Strite
 

Destaque (7)

Introduction to Sumatra
Introduction to SumatraIntroduction to Sumatra
Introduction to Sumatra
 
Minecraft in 500 lines of Python with Pyglet
Minecraft in 500 lines of Python with PygletMinecraft in 500 lines of Python with Pyglet
Minecraft in 500 lines of Python with Pyglet
 
Powerpoint Guidelines
Powerpoint GuidelinesPowerpoint Guidelines
Powerpoint Guidelines
 
Slide Presentation Guidelines
Slide Presentation GuidelinesSlide Presentation Guidelines
Slide Presentation Guidelines
 
Python Presentation
Python PresentationPython Presentation
Python Presentation
 
Денис Ковалев «Python в игровой индустрии»
Денис Ковалев «Python в игровой индустрии»Денис Ковалев «Python в игровой индустрии»
Денис Ковалев «Python в игровой индустрии»
 
Introduction to Python
Introduction to PythonIntroduction to Python
Introduction to Python
 

Semelhante a Pygame presentation

The Ring programming language version 1.5.4 book - Part 48 of 185
The Ring programming language version 1.5.4 book - Part 48 of 185The Ring programming language version 1.5.4 book - Part 48 of 185
The Ring programming language version 1.5.4 book - Part 48 of 185Mahmoud Samir Fayed
 
The Ring programming language version 1.7 book - Part 53 of 196
The Ring programming language version 1.7 book - Part 53 of 196The Ring programming language version 1.7 book - Part 53 of 196
The Ring programming language version 1.7 book - Part 53 of 196Mahmoud Samir Fayed
 
XIX PUG-PE - Pygame game development
XIX PUG-PE - Pygame game developmentXIX PUG-PE - Pygame game development
XIX PUG-PE - Pygame game developmentmatheuscmpm
 
14multithreaded Graphics
14multithreaded Graphics14multithreaded Graphics
14multithreaded GraphicsAdil Jafri
 
The Ring programming language version 1.7 book - Part 50 of 196
The Ring programming language version 1.7 book - Part 50 of 196The Ring programming language version 1.7 book - Part 50 of 196
The Ring programming language version 1.7 book - Part 50 of 196Mahmoud Samir Fayed
 
The Ring programming language version 1.9 book - Part 56 of 210
The Ring programming language version 1.9 book - Part 56 of 210The Ring programming language version 1.9 book - Part 56 of 210
The Ring programming language version 1.9 book - Part 56 of 210Mahmoud Samir Fayed
 
The Ring programming language version 1.8 book - Part 53 of 202
The Ring programming language version 1.8 book - Part 53 of 202The Ring programming language version 1.8 book - Part 53 of 202
The Ring programming language version 1.8 book - Part 53 of 202Mahmoud Samir Fayed
 
Teaching Python to 9 Year Old Girl - map mover
Teaching Python to 9 Year Old Girl -  map moverTeaching Python to 9 Year Old Girl -  map mover
Teaching Python to 9 Year Old Girl - map moverCraig Oda
 
The Ring programming language version 1.2 book - Part 36 of 84
The Ring programming language version 1.2 book - Part 36 of 84The Ring programming language version 1.2 book - Part 36 of 84
The Ring programming language version 1.2 book - Part 36 of 84Mahmoud Samir Fayed
 
C++ game development with oxygine
C++ game development with oxygineC++ game development with oxygine
C++ game development with oxyginecorehard_by
 
The Ring programming language version 1.4 book - Part 14 of 30
The Ring programming language version 1.4 book - Part 14 of 30The Ring programming language version 1.4 book - Part 14 of 30
The Ring programming language version 1.4 book - Part 14 of 30Mahmoud Samir Fayed
 
The Ring programming language version 1.5.4 book - Part 47 of 185
The Ring programming language version 1.5.4 book - Part 47 of 185The Ring programming language version 1.5.4 book - Part 47 of 185
The Ring programming language version 1.5.4 book - Part 47 of 185Mahmoud Samir Fayed
 
building_games_with_ruby_rubyconf
building_games_with_ruby_rubyconfbuilding_games_with_ruby_rubyconf
building_games_with_ruby_rubyconftutorialsruby
 
building_games_with_ruby_rubyconf
building_games_with_ruby_rubyconfbuilding_games_with_ruby_rubyconf
building_games_with_ruby_rubyconftutorialsruby
 
[EN] Ada Lovelace Day 2014 - Tampon run
[EN] Ada Lovelace Day 2014  - Tampon run[EN] Ada Lovelace Day 2014  - Tampon run
[EN] Ada Lovelace Day 2014 - Tampon runMaja Kraljič
 
JavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeJavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeLaurence Svekis ✔
 
CE344L-200365-Lab5.pdf
CE344L-200365-Lab5.pdfCE344L-200365-Lab5.pdf
CE344L-200365-Lab5.pdfUmarMustafa13
 
The Ring programming language version 1.10 book - Part 70 of 212
The Ring programming language version 1.10 book - Part 70 of 212The Ring programming language version 1.10 book - Part 70 of 212
The Ring programming language version 1.10 book - Part 70 of 212Mahmoud Samir Fayed
 
The Ring programming language version 1.3 book - Part 43 of 88
The Ring programming language version 1.3 book - Part 43 of 88The Ring programming language version 1.3 book - Part 43 of 88
The Ring programming language version 1.3 book - Part 43 of 88Mahmoud Samir Fayed
 

Semelhante a Pygame presentation (20)

The Ring programming language version 1.5.4 book - Part 48 of 185
The Ring programming language version 1.5.4 book - Part 48 of 185The Ring programming language version 1.5.4 book - Part 48 of 185
The Ring programming language version 1.5.4 book - Part 48 of 185
 
The Ring programming language version 1.7 book - Part 53 of 196
The Ring programming language version 1.7 book - Part 53 of 196The Ring programming language version 1.7 book - Part 53 of 196
The Ring programming language version 1.7 book - Part 53 of 196
 
XIX PUG-PE - Pygame game development
XIX PUG-PE - Pygame game developmentXIX PUG-PE - Pygame game development
XIX PUG-PE - Pygame game development
 
14multithreaded Graphics
14multithreaded Graphics14multithreaded Graphics
14multithreaded Graphics
 
The Ring programming language version 1.7 book - Part 50 of 196
The Ring programming language version 1.7 book - Part 50 of 196The Ring programming language version 1.7 book - Part 50 of 196
The Ring programming language version 1.7 book - Part 50 of 196
 
The Ring programming language version 1.9 book - Part 56 of 210
The Ring programming language version 1.9 book - Part 56 of 210The Ring programming language version 1.9 book - Part 56 of 210
The Ring programming language version 1.9 book - Part 56 of 210
 
Vanmathy python
Vanmathy python Vanmathy python
Vanmathy python
 
The Ring programming language version 1.8 book - Part 53 of 202
The Ring programming language version 1.8 book - Part 53 of 202The Ring programming language version 1.8 book - Part 53 of 202
The Ring programming language version 1.8 book - Part 53 of 202
 
Teaching Python to 9 Year Old Girl - map mover
Teaching Python to 9 Year Old Girl -  map moverTeaching Python to 9 Year Old Girl -  map mover
Teaching Python to 9 Year Old Girl - map mover
 
The Ring programming language version 1.2 book - Part 36 of 84
The Ring programming language version 1.2 book - Part 36 of 84The Ring programming language version 1.2 book - Part 36 of 84
The Ring programming language version 1.2 book - Part 36 of 84
 
C++ game development with oxygine
C++ game development with oxygineC++ game development with oxygine
C++ game development with oxygine
 
The Ring programming language version 1.4 book - Part 14 of 30
The Ring programming language version 1.4 book - Part 14 of 30The Ring programming language version 1.4 book - Part 14 of 30
The Ring programming language version 1.4 book - Part 14 of 30
 
The Ring programming language version 1.5.4 book - Part 47 of 185
The Ring programming language version 1.5.4 book - Part 47 of 185The Ring programming language version 1.5.4 book - Part 47 of 185
The Ring programming language version 1.5.4 book - Part 47 of 185
 
building_games_with_ruby_rubyconf
building_games_with_ruby_rubyconfbuilding_games_with_ruby_rubyconf
building_games_with_ruby_rubyconf
 
building_games_with_ruby_rubyconf
building_games_with_ruby_rubyconfbuilding_games_with_ruby_rubyconf
building_games_with_ruby_rubyconf
 
[EN] Ada Lovelace Day 2014 - Tampon run
[EN] Ada Lovelace Day 2014  - Tampon run[EN] Ada Lovelace Day 2014  - Tampon run
[EN] Ada Lovelace Day 2014 - Tampon run
 
JavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeJavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your code
 
CE344L-200365-Lab5.pdf
CE344L-200365-Lab5.pdfCE344L-200365-Lab5.pdf
CE344L-200365-Lab5.pdf
 
The Ring programming language version 1.10 book - Part 70 of 212
The Ring programming language version 1.10 book - Part 70 of 212The Ring programming language version 1.10 book - Part 70 of 212
The Ring programming language version 1.10 book - Part 70 of 212
 
The Ring programming language version 1.3 book - Part 43 of 88
The Ring programming language version 1.3 book - Part 43 of 88The Ring programming language version 1.3 book - Part 43 of 88
The Ring programming language version 1.3 book - Part 43 of 88
 

Último

Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfOrbitshub
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyKhushali Kathiriya
 
Six Myths about Ontologies: The Basics of Formal Ontology
Six Myths about Ontologies: The Basics of Formal OntologySix Myths about Ontologies: The Basics of Formal Ontology
Six Myths about Ontologies: The Basics of Formal Ontologyjohnbeverley2021
 
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...apidays
 
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Orbitshub
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoffsammart93
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobeapidays
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Victor Rentea
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfsudhanshuwaghmare1
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Jeffrey Haguewood
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024The Digital Insurer
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businesspanagenda
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FMESafe Software
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...apidays
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxRustici Software
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native ApplicationsWSO2
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Angeliki Cooney
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Victor Rentea
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProduct Anonymous
 

Último (20)

Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Six Myths about Ontologies: The Basics of Formal Ontology
Six Myths about Ontologies: The Basics of Formal OntologySix Myths about Ontologies: The Basics of Formal Ontology
Six Myths about Ontologies: The Basics of Formal Ontology
 
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
 
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 

Pygame presentation

  • 1. Introduction to Presented by Felix Homann @Felix11H felix11h.github.io/ Slides Slideshare: tiny.cc/pyg-into Source: tiny.cc/pyg-into-github References - Pygame website: pygame.org - Richard Jones' Pygame lecture: - recording on Youtube - code samples on Bitbucket - List of keys: pygame.org/docs/ref/key.html This work is licensed under a Creative Commons Attribution 4.0 International License.
  • 2. http://www.pygame.org Pygame is a Python wrapper around the SDL library (Simple DirectMedia Layer) with a few unique libraries with an emphasis on game programming, written by Pete Shinners.
  • 3. From the FAQ Does not require OpenGL Uses either opengl, directx, windib, X11, linux frame buer, and many other dierent backends... including an ASCII art backend! Truly portable Supports Linux, Windows, Windows CE, BeOS, MacOS, Mac OS X, FreeBSD, NetBSD, OpenBSD, BSD/OS, Solaris, IRIX, and QNX . . . Silliness built in!
  • 4. A simple Pygame example 1 import pygame 2 3 pygame.init() 4 screen = pygame.display.set_mode((640, 480)) 5 6 color = [(0,0,0),(255,255,255)] 7 running = True 8 9 while running: 10 for event in pygame.event.get(): 11 if event.type == pygame.QUIT: 12 running = False 13 if event.type == pygame.KEYDOWN: 14 color[0], color[1] = color[1],color[0] 15 16 screen.fill(color[0]) 17 pygame.display.flip() 01-simple_pygame.py
  • 5. What each element does: Importing Initializing import pygame to import the Pygame module. from pygame.locals import * Optional. Puts limited set of constant and function in the global namespace. pygame.init() to initialize Pygame's modules (e.g. pygame.font). Not always needed, but recommended in any case.
  • 6. What each element does: Setting Window Screen screen = pygame.display.set_mode((640, 480)) initializes a window with dimensions 640 480 and returns the screen object. Everything to be displayed needs to be drawn on the screen.
  • 7. Initializing a Pygame window Together: 1 import pygame 2 3 pygame.init() 4 screen = pygame.display.set_mode((640, 480)) 02-window.py
  • 8. Initializing a Pygame window - Extended 1 import pygame 2 3 pygame.init() 4 screen = pygame.display.set_mode((640, 480)) 5 6 running = True 7 while running: 8 for event in pygame.event.get(): 9 if event.type == pygame.QUIT: 10 running = False
  • 9. What each element does: The Main Loop 1 running = True 2 while running: 3 for event in pygame.event.get(): 4 if event.type == pygame.QUIT: 5 running = False 6 if event.type == pygame.KEYDOWN: 7 color[0], color[1] = color[1],color[0] 8 9 screen.fill(color[0]) 10 pygame.display.flip() is the main loop of the game. I listen to events ! respond I proceed the game I draw on the screen I stop when done
  • 10. A framework for your Pygames 1 import pygame 2 3 pygame.init() 4 screen = pygame.display.set_mode((640, 480)) 5 6 running = True 7 while running: 8 for event in pygame.event.get(): 9 if event.type == pygame.QUIT: 10 running = False 11 if event.type == pygame.KEYDOWN: 12 react_to_user_input() 13 14 do_things_the_game_does() 15 draw_everything_on_the_screen() Next: I Drawing I User Input I Game Events
  • 12. Drawing on the screen I Filling the screen with a color: 1 blue = (0,0,255) 2 screen.fill(blue) 3 pygame.display.flip() After all drawing is done, call display.flip() to update the display. Use pygame.draw to draw geometric shapes. A circle: 1 red = (255,0,0) 2 # position (320,240), radius = 50 3 pygame.draw.circle(screen, red, (320,240), 50)
  • 13. Drawing on the screen II Geometric shapes available for pygame.draw: circle(Surface, color, pos, radius, width=0) polygon(Surface, color, pointlist, width=0) line(Surface, color, start, end, width= 1) rect(Surface, color, Rect, width=0) ellipse(Surface, color, Rect, width=0) Example: 1 red = (255,0,0) 2 pygame.draw.line(screen, red, (10,50),(30,50),10)
  • 14. Drawing on the screen - Colors De
  • 15. ning a color gray = (200,200,200) #(red, green, blue) Use for example colorpicker.com:
  • 16. Drawing on the screen - Positions De
  • 17. ning a position: P = (11,9) #(x-axis, y-axis) To the reference coordinate system
  • 18. Drawing on the screen - Rects pygame.Rect(left, top, width, height) to create a Rect. 1 box = pygame.Rect(10, 10, 100, 40) 2 pygame.draw.rect(screen, blue, box) 3 #draws at (10,10) rectangle of width 100, height 40 Rect anchors: top, left, bottom, right topleft, bottomleft, topright, bottomright midtop, midleft, midbottom, midright center, centerx, centery size, width, height w,h
  • 19. A full drawing example 1 import pygame 2 3 pygame.init() 4 screen = pygame.display.set_mode((640, 480)) 5 6 white = (255,255,255) 7 blue = (0,0,255) 8 9 running = True 10 while running: 11 for event in pygame.event.get(): 12 if event.type == pygame.QUIT: 13 running = False 14 15 screen.fill(white) 16 pygame.draw.circle(screen, blue, (320,240), 100) 17 # position (320,240), radius = 100 18 19 pygame.display.flip() 04-drawing.py.
  • 21. Events get all events in Pygame's event queue pygame.event.get() usually used as 1 for event in pygame.event.get(): 2 if event.type == YourEvent: 3 react_to_your_event()
  • 22. Event types Some of the most important event types are: pygame.QUIT pygame.KEYDOWN pygame.KEYUP pygame.USEREVENT With from pygame.locals import * from earlier, pre
  • 23. x pygame isn't needed.
  • 24. Events React to KEYDOWN event: 1 while running: 2 for event in pygame.event.get(): 3 if event.type == KEYDOWN: 4 react_to_key() Which key? ! if event type is KEYDOWN or KEYUP event has attribute key. 1 for event in pygame.event.get(): 2 if event.type == KEYDOWN: 3 if event.key == K_ESCAPE: 4 running = False
  • 25. Pygame Keys Some of the most important keys are: K_RETURN K_SPACE K_ESCAPE K_UP, K_DOWN, K_LEFT, K_RIGHT K_a, K_b, ... K_0, K_1, ... Full list of keys: http://www.pygame.org/docs/ref/key.html
  • 26. Getting continuous input KEYDOWN is a unique event. key = pygame.key.get_pressed() to get keys currently pressed. if key[pygame.K_UP]: move_up() to check and react on a speci
  • 28. A user input example 1 color = [0,0,0] 2 3 while running: 4 for event in pygame.event.get(): 5 if event.type == pygame.QUIT: 6 running = False 7 if event.type == KEYDOWN and event.key == K_SPACE: 8 color = [0,0,0] 9 10 keys = pygame.key.get_pressed() 11 if keys[K_UP]: 12 color = [(rgb+1)%256 for rgb in color] 13 14 screen.fill(color) 15 pygame.display.flip() 05-user_input.py
  • 30. Limiting the frames per second clock = pygame.time.Clock() to initialize the clock. In your main loop call clock.tick(60) #limit to 60 fps
  • 31. Clock example 1 clock = pygame.time.Clock() 2 3 while running: 4 for event in pygame.event.get(): 5 if event.type == pygame.QUIT: 6 running = False 7 if event.type == KEYDOWN and event.key == K_SPACE: 8 color = [0,0,0] 9 10 keys = pygame.key.get_pressed() 11 if keys[K_UP]: 12 color = [(rgb+1)%256 for rgb in color] 13 14 screen.fill(color) 15 pygame.display.flip() 16 17 clock.tick(60) 06-clock.py
  • 33. Sprites Pygame's sprite class gives convenient options for handling interactive graphical objects. If you want to draw and move (or manipulate) and object, make it a sprite. Sprites can be grouped together are easily drawn to a surface (even as a group!) have an update method that can be modi
  • 34. ed have collision detection
  • 35. Basic Sprite 1 class SpriteExample(pygame.sprite.Sprite): 2 3 def __init__(self): 4 pygame.sprite.Sprite.__init__(self) 5 6 self.image = #image 7 self.rect = #rect 8 9 def update(self): 10 pass
  • 36. Sprite from a local image 1 class SpriteExample(pygame.sprite.Sprite): 2 3 def __init__(self): 4 pygame.sprite.Sprite.__init__(self) 5 6 self.image = pygame.image.load('local_img.png') 7 self.rect = self.image.get_rect() 8 self.rect.topleft = (80,120) 9 10 def update(self): 11 pass
  • 37. Self-drawn sprites: Rectangle 1 class Rectangle(pygame.sprite.Sprite): 2 3 def __init__(self): 4 pygame.sprite.Sprite.__init__(self) 5 self.image = pygame.Surface([200, 50]) 6 self.image.fill(blue) 7 self.rect = self.image.get_rect() 8 self.rect.top, self.rect.left = 100, 100 9 10 def update(self): 11 pass
  • 38. Sprites: A reminder about classes 1 class Rectangle(pygame.sprite.Sprite): 2 3 def __init__(self, color): 4 pygame.sprite.Sprite.__init__(self) 5 self.image = pygame.Surface([200, 50]) 6 self.image.fill(color) 7 self.rect = self.image.get_rect() 8 self.rect.top, self.rect.left = 100, 100 9 10 def update(self): 11 pass 1 white, blue = (255,255,255), (0,0,255) 2 3 white_rect = Rectangle(white) 4 blue_rect = Rectangle(blue)
  • 39. Sprite groups new_sprite_group = pygame.sprite.Group(sprite1) to create a new sprite group containing sprite sprite1. new_sprite_group.add(sprite2) to add another sprite later. Group updating and drawing: 1 #inside main loop: 2 3 new_sprite_group.update() #game events 4 new_sprite_group.draw() #drawing
  • 40. Framework for working with sprite groups 1 class NewSprite(pygame.sp... 2 #defining a new sprite 3 4 newsprite = NewSprite() 5 sprites = pygame.sprite.Group() 6 sprites.add(newsprite) 7 8 while running: 9 for event in ... 10 11 sprites.update() #game events 12 sprites.draw() 13 pygame.display.flip()
  • 41. Sprite groups: working example 1 class Circle(pygame.sprite.Sprite): 2 def __init__(self): 3 pygame.sprite.Sprite.__init__(self) 4 self.image = pygame.Surface([100, 100]) 5 pygame.draw.circle(self.image, blue, (50, 50), 50) 6 self.rect = self.image.get_rect() 7 self.rect.center = [320,240] 8 9 def draw(sprites): 10 screen.fill(white) 11 sprites.draw(screen) 12 pygame.display.flip() 13 14 circle = Circle() 15 sprites = pygame.sprite.Group(circle) 16 17 while running: 18 sprites.update() 19 draw(sprites) 07-sprite-circle.py
  • 42. Working example: Transparency By default pygame.Surface is black. For transparency: 1 class Circle(pygame.sprite.Sprite): 2 def __init__(self): 3 pygame.sprite.Sprite.__init__(self) 4 self.image = pygame.Surface([100, 100], pygame.SRCALPHA, 32) 5 pygame.draw.circle(self.image, blue, (50, 50), 50) 6 self.image = self.image.convert_alpha() 08-circle.py
  • 43. Sprite Collision Detection pygame.sprite.collide_rect(left, right) to detect collision between two sprites pygame.sprite.spritecollideany(sprite, group) to test if the given sprite intersects with any sprites in a Group
  • 44. Have fun with ! Presented by Felix Homann @Felix11H felix11h.github.io/ Slides Slideshare: tiny.cc/pyg-into Source: tiny.cc/pyg-into-github References - Pygame website: pygame.org - Richard Jones' Pygame lecture: - recording on Youtube - code samples on Bitbucket - List of keys: pygame.org/docs/ref/key.html This work is licensed under a Creative Commons Attribution 4.0 International License.