How to use Pygame's Event event module in Python
Pygame's Event module
Event (Event) is one of the important modules of Pygame. It is the core of building the entire game program, such as commonly used mouse clicks, keyboard taps, game window movements, and adjustments. Window size, triggering specific plots, exiting the game, etc., can all be regarded as "events".
Event Type
Pygame defines a structure specifically used to process events, namely the event queue. This structure follows the basic principle of "first come, first processed" of the queue. Through the event queue, we User operations (triggered events) can be processed in an orderly and one-by-one manner. The following table lists commonly used game events in Pygame:
Name | Description |
---|---|
QUIT |
The user presses the close button of the window |
ATIVEEVENT |
Pygame Activate or hide |
KEYDOWN |
Keyboard press |
KEYUP |
Keyboard release |
MOUSEMOTION |
Mouse movement |
MOUSEBUTTONDOWN |
Mouse pressed |
MOUSEBUTTONUP |
Mouse released |
JOYAXISMOTION |
Game handle (Joystick or pad) movement |
##JOYBALLMOTION
| Gameball(Joy ball) Move|
Game Controller(Joystick) Move |
|
Game handle pressed |
|
Game handle released |
|
Pygame window scaling |
|
Pygame window partially exposed (expose) |
##USEREVENT |
Trigger a user event
|
Event handling methodName
Get an event from the event queue and delete the event from the queue
|
pygame.event.wait() | |||||||||||||||||||||||||||||||||||
Blocking will not continue until the event occurs. If no event occurs, it will remain blocked
|
pygame.event.set_blocked() | |||||||||||||||||||||||||||||||||||
Control which events are prohibited from entering the queue. If the parameter value is None, it means that all events are prohibited from entering
|
pygame.event.set_allowed() | |||||||||||||||||||||||||||||||||||
Control which events are allowed to enter the queue
|
pygame.event.pump() | |||||||||||||||||||||||||||||||||||
After calling this method, Pygame will automatically process the event queue
|
pygame.event.poll() | |||||||||||||||||||||||||||||||||||
will be processed according to the actual situation Returns a real event, or None
|
##pygame.event.peek() | |||||||||||||||||||||||||||||||||||
|
pygame.event.clear() | |||||||||||||||||||||||||||||||||||
|
pygame.event.get_blocked() | |||||||||||||||||||||||||||||||||||
|
pygame.event.post() | |||||||||||||||||||||||||||||||||||
|
pygame.event.Event() | |||||||||||||||||||||||||||||||||||
|
Name | Instructions |
---|---|
K_BACKSPACE | Backspace |
K_TAB | Tab |
K_CLEAR | Clear key (Clear) |
K_RETURN | Enter key (Enter) |
K_PAUSE | Pause button |
K_ESCAPE | Escape button |
K_SPACE | Space bar (Space) |
K_0...K_9 | 0…9 |
#K_a...Kz
| a…z|
K_DELETE
| Delete key (delete)|
0 (small keyboard)...9 (small keyboard) | |
F1…F15 | |
Up arrow | |
Towards Down arrow | |
right arrow | |
Left arrow | |
Press the Alt key at the same time |
import pygame import sys # 初始化pygame pygame.init() # 定义变量 size = width, height = 600, 400 bg = (255, 255, 255) # 加载logo图 img = pygame.image.load("./python.png") # 获取图像的位置 position = img.get_rect() # 创建一个主窗口 screen = pygame.display.set_mode(size) # 标题 pygame.display.set_caption("Python自学网") # 创建游戏主循环 while True: # 设置初始值 site = [0, 0] for event in pygame.event.get(): if event.type == pygame.QUIT: sys.exit() # 图像移动 KEYDOWN 键盘按下事件 # 通过 key 属性对应按键 if event.type == pygame.KEYDOWN: if event.key == pygame.K_UP: site[1] -= 8 if event.key == pygame.K_DOWN: site[1] += 8 if event.key == pygame.K_LEFT: site[0] -= 8 if event.key == pygame.K_RIGHT: site[0] += 8 # 移动图像 position = position.move(site) # 填充背景 screen.fill(bg) # 放置图片 screen.blit(img, position) # 更新显示界面 pygame.display.flip()
Handling mouse events
Pygame provides three mouse events, namely mouse movement (MOUSEMOTION), mouse press (MOUSEBUTTONDOWN), and mouse release (MOUSEBUTTONUP). Different event types correspond to different member attributes. As shown below:
pygame.event.MOUSEMOTION mouse movement event
event.pos relative to the upper left corner of the window, the current coordinate value of the mouse (x, y)
event.rel mouse Relative movement distance (X, Y), relative to the last eventevent.buttons The initial state of the mouse button (0,0,0), corresponding to (left button, pulley, right button) respectively, which button is clicked during the movement, The corresponding position will change to 1
pygame.event.MOUSEBUTTONUP mouse button release eventevent.pos relative to the upper left corner of the window, the current coordinate value of the mouse (x, y)
event .button Mouse release key number (integer) The left button is 1, the scroll wheel is pressed 2, the right button is 3
pygame.event.MOUSEBUTTONDOWN Mouse button press eventevent.pos relative to The upper left corner of the window, the current coordinate value of the mouse (x, y)
event.button mouse button number (integer), the left button is 1, press the scroll wheel 2, the right button is 3, scroll the wheel 4 forward, Roll the pulley backward 5
import pygame from random import randint # 初始化程序 pygame.init() screen = pygame.display.set_mode((450, 400)) pygame.display.set_caption("Python自学网") # 更新显示 pygame.display.flip() while True: # 等待事件发生 event = pygame.event.wait() if event.type == pygame.QUIT: exit("成功退出") if event.type == pygame.MOUSEBUTTONDOWN: # pos 获取鼠标当前位置 print('鼠标按下', event.pos) mx, my = event.pos # 调用 pygame.draw 模块画圆 pygame.draw.circle(screen, (255, 255, 0), (mx, my), 50) # 处理完,更新显示 pygame.display.update() if event.type == pygame.MOUSEBUTTONUP: print('鼠标弹起') pass if event.type == pygame.MOUSEMOTION: print('鼠标移动') mx, my = event.pos # 随机生成 RGB 颜色值 r = randint(0, 255) g = randint(0, 255) b = randint(0, 255) pygame.draw.circle(screen, (r, g, b,), (mx, my), 50) # 处理完,更新显示 pygame.display.update()Copy after login
The above is the detailed content of How to use Pygame's Event event module in Python. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

Enable PyTorch GPU acceleration on CentOS system requires the installation of CUDA, cuDNN and GPU versions of PyTorch. The following steps will guide you through the process: CUDA and cuDNN installation determine CUDA version compatibility: Use the nvidia-smi command to view the CUDA version supported by your NVIDIA graphics card. For example, your MX450 graphics card may support CUDA11.1 or higher. Download and install CUDAToolkit: Visit the official website of NVIDIACUDAToolkit and download and install the corresponding version according to the highest CUDA version supported by your graphics card. Install cuDNN library:

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

Docker uses Linux kernel features to provide an efficient and isolated application running environment. Its working principle is as follows: 1. The mirror is used as a read-only template, which contains everything you need to run the application; 2. The Union File System (UnionFS) stacks multiple file systems, only storing the differences, saving space and speeding up; 3. The daemon manages the mirrors and containers, and the client uses them for interaction; 4. Namespaces and cgroups implement container isolation and resource limitations; 5. Multiple network modes support container interconnection. Only by understanding these core concepts can you better utilize Docker.

MinIO Object Storage: High-performance deployment under CentOS system MinIO is a high-performance, distributed object storage system developed based on the Go language, compatible with AmazonS3. It supports a variety of client languages, including Java, Python, JavaScript, and Go. This article will briefly introduce the installation and compatibility of MinIO on CentOS systems. CentOS version compatibility MinIO has been verified on multiple CentOS versions, including but not limited to: CentOS7.9: Provides a complete installation guide covering cluster configuration, environment preparation, configuration file settings, disk partitioning, and MinI

PyTorch distributed training on CentOS system requires the following steps: PyTorch installation: The premise is that Python and pip are installed in CentOS system. Depending on your CUDA version, get the appropriate installation command from the PyTorch official website. For CPU-only training, you can use the following command: pipinstalltorchtorchvisiontorchaudio If you need GPU support, make sure that the corresponding version of CUDA and cuDNN are installed and use the corresponding PyTorch version for installation. Distributed environment configuration: Distributed training usually requires multiple machines or single-machine multiple GPUs. Place

When installing PyTorch on CentOS system, you need to carefully select the appropriate version and consider the following key factors: 1. System environment compatibility: Operating system: It is recommended to use CentOS7 or higher. CUDA and cuDNN:PyTorch version and CUDA version are closely related. For example, PyTorch1.9.0 requires CUDA11.1, while PyTorch2.0.1 requires CUDA11.3. The cuDNN version must also match the CUDA version. Before selecting the PyTorch version, be sure to confirm that compatible CUDA and cuDNN versions have been installed. Python version: PyTorch official branch

CentOS Installing Nginx requires following the following steps: Installing dependencies such as development tools, pcre-devel, and openssl-devel. Download the Nginx source code package, unzip it and compile and install it, and specify the installation path as /usr/local/nginx. Create Nginx users and user groups and set permissions. Modify the configuration file nginx.conf, and configure the listening port and domain name/IP address. Start the Nginx service. Common errors need to be paid attention to, such as dependency issues, port conflicts, and configuration file errors. Performance optimization needs to be adjusted according to the specific situation, such as turning on cache and adjusting the number of worker processes.
