pygame教程笔记

article/2025/10/3 19:10:46

pygame教程

    • 安装pygame
    • Game Development 1-1: Getting Started with Pygame
    • Game Development 1-2: Working with Sprites
    • Game Development 1-3: More About Sprites
    • Pygame Shmup Part 1: Player Sprite and Controls
    • Pygame Shmup Part 2: Enemy Sprites
    • Pygame Shmup Part 3: Collisions (and Bullets!)
    • Pygame Shmup Part 4: Adding Graphics
    • Pygame Shmup Part 5: Improved Collisions
    • Pygame Shmup Part 6: Sprite Animation(精灵动画)
    • Pygame Shmup Part 7: Score (and Drawing Text)
    • Pygame Shmup Part 8: Sound and Music

教程地址

安装pygame

坑:如果使用虚拟解释器中的pygame模块,可能会产生没有提示的副作用

在这里插入图片描述

Game Development 1-1: Getting Started with Pygame

游戏主体是一个大循环主要分为三个部分:
处理输入(鼠标键盘事件等等),更新游戏(更新位置坐标,速度属性等)和渲染屏幕(更新屏幕上的图像).
在这里插入图片描述
绘制图像就像一个板,我们在后面画上我们要画的东西,然后立刻反转板子,东西就呈现出来了.如此循环往复
在这里插入图片描述

import pygame
import random
from pygame.locals import *# 定义初始屏幕大小和游戏帧率
WIDTH = 360
HEIGHT = 480
FPS = 30# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("My Game") # 设置标题clock = pygame.time.Clock()# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新update# 3.渲染绘图screen.fill(BLACK)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

Game Development 1-2: Working with Sprites

精灵就是一个对象,如果绘制每个精灵还要更新的话就会很耗时,因此引入了精灵组

坐标原点在左上角
在这里插入图片描述

import pygame
import random
from pygame.locals import *# 定义初始屏幕大小和游戏帧率
WIDTH = 880
HEIGHT = 600
FPS =  30# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)# 定义玩家类
class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.Surface((50,50))self.image.fill(GREEN)self.rect = self.image.get_rect()self.rect.center = (WIDTH/2, HEIGHT/2)def update(self):self.rect.x += 5if self.rect.left > WIDTH:self.rect.right = 0# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("My Game") # 设置标题
clock = pygame.time.Clock()# 创建一个装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
player = Player()
all_sprites.add(player)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新updateall_sprites.update()# 3.渲染绘图screen.fill(BLACK)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

Game Development 1-3: More About Sprites

开源游戏素材:https://opengameart.org/
搜索Kenny ke
在这里插入图片描述

import pygame
import random
import os
from pygame.locals import *# 定义初始屏幕大小和游戏帧率
WIDTH = 880
HEIGHT = 600
FPS =  30# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)# 设置assets文件夹(游戏素材)
# E:\xiangyun\代码\AlienBattle\img\sinkar birber.png
game_folder = os.path.dirname(__file__)
img_folder = os.path.join(game_folder, "img")class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)# 添加路径并把图像转换为透明self.image = pygame.image.load(os.path.join(img_folder,"sinkar birber.png")).convert_alpha()# self.image.set_colorkey(BLACK) 把黑色部分转换为透明self.rect = self.image.get_rect()self.rect.center = (WIDTH/2, HEIGHT/2)self.y_speed = 5def update(self):self.rect.x += 1# 使角色看起来上下跳跃self.rect.y += self.y_speedif self.rect.bottom > HEIGHT - 200:self.y_speed = -5if self.rect.top < 200:self.y_speed = 5if self.rect.left > WIDTH:self.rect.right = 0# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("My Game") # 设置标题
clock = pygame.time.Clock()# 创建一个装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
player = Player()
all_sprites.add(player)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新updateall_sprites.update()# 3.渲染绘图screen.fill(BLUE)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

在这里插入图片描述

Pygame Shmup Part 1: Player Sprite and Controls

shoot em up

"""Shump Game"""
import pygame
import random
from pygame.locals import *# 定义初始屏幕大小和游戏帧率
WIDTH = 480
HEIGHT = 600
# 射击游戏需要高帧率
FPS = 60# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("Shmup!") # 设置标题
clock = pygame.time.Clock()class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.Surface((50, 40))self.image.fill(GREEN)self.rect = self.image.get_rect()self.rect.centerx = WIDTH/2self.rect.bottom = HEIGHT - 10self.speedx = 0def update(self):# 加入按键控制self.speedx = 0keystate = pygame.key.get_pressed()if keystate[pygame.K_LEFT] or keystate[pygame.K_a]:self.speedx = -5if keystate[pygame.K_RIGHT] or keystate[pygame.K_d] :self.speedx = 5self.rect.x += self.speedx# 边界约束if self.rect.right > WIDTH:self.rect.right = WIDTHif self.rect.left < 0:self.rect.left = 0# 创建一个装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
player = Player()
all_sprites.add(player)
# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新updateall_sprites.update()# 3.渲染绘图screen.fill(BLACK)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

在这里插入图片描述

Pygame Shmup Part 2: Enemy Sprites

"""Shump Game"""
import pygame
import random
from pygame.locals import *# 定义初始屏幕大小和游戏帧率
WIDTH = 480
HEIGHT = 600
# 射击游戏需要高帧率
FPS = 60# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("Shmup!") # 设置标题
clock = pygame.time.Clock()class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.Surface((50, 40))self.image.fill(GREEN)self.rect = self.image.get_rect()self.rect.centerx = WIDTH/2self.rect.bottom = HEIGHT - 10self.speedx = 0def update(self):# 加入按键控制self.speedx = 0keystate = pygame.key.get_pressed()if keystate[pygame.K_LEFT] or keystate[pygame.K_a]:self.speedx = -5if keystate[pygame.K_RIGHT] or keystate[pygame.K_d] :self.speedx = 5self.rect.x += self.speedx# 边界约束if self.rect.right > WIDTH:self.rect.right = WIDTHif self.rect.left < 0:self.rect.left = 0
# 创建敌方类
class Mob(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.Surface((30, 40))self.image.fill(RED)self.rect = self.image.get_rect()# 设置敌方的出生位置,要在屏幕外面,这样才显得不突兀self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)self.speedx = random.randrange(-3, 3)def update(self, *args):self.rect.x += self.speedxself.rect.y += self.speedyif self.rect.top > HEIGHT + 10 or self.rect.left < -25 or self.rect.right>WIDTH+25:self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)# 创建装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
# 创建敌方精灵组
mobs = pygame.sprite.Group()player = Player()
all_sprites.add(player)
for i in range(8):m = Mob()all_sprites.add(m)mobs.add(m)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新updateall_sprites.update()# 3.渲染绘图screen.fill(BLACK)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

在这里插入图片描述

Pygame Shmup Part 3: Collisions (and Bullets!)

精灵碰撞检测:检查一个精灵和其他精灵组的碰撞,返回值是一个列表,列表中是和这个精灵发生碰撞的精灵组中的精灵…
dokill是个布尔值,如果设置为真,则所有发生碰撞的精灵组精灵将会移除.
collided是遮罩用于碰撞检测,默认矩形

在这里插入图片描述
精灵组碰撞:检测两组精灵组的碰撞,返回一个字典,字典的Key是第一组里面发生碰撞的精灵,而value是第二组中碰撞的精灵.
dokill指的是否消除碰撞精灵
在这里插入图片描述

   # 检查碰撞# 检查是否子弹击中敌方dics = pygame.sprite.groupcollide(bullets, mobs, True, True)for dic in dics:m = Mob()all_sprites.add(m)mobs.add(m)# if dic:#     print(dic)hits = pygame.sprite.spritecollide(player, mobs, False)if hits:running = False

Pygame Shmup Part 4: Adding Graphics

在这里插入图片描述

"""Shump Game添加了图片,代替小方块(缩放, 加载, 转换)"""import pygame
import random
from os import path
from pygame.locals import *img_dir = path.join(path.dirname(__file__), "img")# 定义初始屏幕大小和游戏帧率
WIDTH = 480
HEIGHT = 600
# 射击游戏需要高帧率
FPS = 60# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)
YELLOW = (255, 255, 0)# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("Shmup!") # 设置标题
clock = pygame.time.Clock()class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.transform.scale(player_img, (50, 38))self.rect = self.image.get_rect()self.rect.centerx = WIDTH/2self.rect.bottom = HEIGHT - 10self.speedx = 0# 定义玩家射击方法def shoot(self):bullet = Bullet(self.rect.centerx, self.rect.top)all_sprites.add(bullet)bullets.add(bullet)def update(self):# 加入按键控制self.speedx = 0keystate = pygame.key.get_pressed()if keystate[pygame.K_LEFT] or keystate[pygame.K_a]:self.speedx = -5if keystate[pygame.K_RIGHT] or keystate[pygame.K_d] :self.speedx = 5self.rect.x += self.speedx# 边界约束if self.rect.right > WIDTH:self.rect.right = WIDTHif self.rect.left < 0:self.rect.left = 0# 创建敌方类
class Mob(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = meteor_imgself.rect = self.image.get_rect()# 设置敌方的出生位置,要在屏幕外面,这样才显得不突兀self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)self.speedx = random.randrange(-3, 3)def update(self, *args):self.rect.x += self.speedxself.rect.y += self.speedyif self.rect.top > HEIGHT + 10 or self.rect.left < -25 or self.rect.right>WIDTH+25:self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)class Bullet(pygame.sprite.Sprite):def __init__(self, x, y):pygame.sprite.Sprite.__init__(self)self.image = bullet_imgself.rect = self.image.get_rect()self.rect.bottom = yself.rect.centerx = xself.speedy = -10def update(self, *args):self.rect.y += self.speedy# 如果飞出屏幕顶部则销毁if self.rect.bottom < 0:self.kill()# 加载全部游戏图像
background = pygame.image.load(path.join(img_dir, "starfield.png")).convert()
background_rect = background.get_rect()
player_img = pygame.image.load(path.join(img_dir, "playerShip1_orange.png")).convert_alpha()
meteor_img = pygame.image.load(path.join(img_dir, "meteorBrown_med1.png")).convert_alpha()
bullet_img = pygame.image.load(path.join(img_dir, "laserRed16.png")).convert_alpha()
# 创建装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
# 创建敌方精灵组
mobs = pygame.sprite.Group()
# 创建子弹精灵组
bullets = pygame.sprite.Group()player = Player()
all_sprites.add(player)
for i in range(8):m = Mob()all_sprites.add(m)mobs.add(m)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_SPACE:player.shoot()# 2.更新updateall_sprites.update()# 检查碰撞# 检查是否子弹击中敌方dics = pygame.sprite.groupcollide(bullets, mobs, True, True)for dic in dics:m = Mob()all_sprites.add(m)mobs.add(m)# if dic:#     print(dic)hits = pygame.sprite.spritecollide(player, mobs, False)if hits:running = False# 3.渲染绘图screen.fill(BLACK)screen.blit(background, background_rect)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

Pygame Shmup Part 5: Improved Collisions

圆形碰撞遮罩更符合,可以设置radius实例属性,并
在这里插入图片描述

"""Shump Game添加圆形碰撞"""import pygame
import random
from os import path
from pygame.locals import *img_dir = path.join(path.dirname(__file__), "img")# 定义初始屏幕大小和游戏帧率
WIDTH = 480
HEIGHT = 600
# 射击游戏需要高帧率
FPS = 60# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)
YELLOW = (255, 255, 0)# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("Shmup!") # 设置标题
clock = pygame.time.Clock()class Player(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = pygame.transform.scale(player_img, (50, 38))self.rect = self.image.get_rect()# 增加半径属性,可以绘制出⚪来显示范围self.radius = 20# pygame.draw.circle(self.image, RED, self.rect.center, self.radius)self.rect.centerx = WIDTH/2self.rect.bottom = HEIGHT - 10self.speedx = 0# 定义玩家射击方法def shoot(self):bullet = Bullet(self.rect.centerx, self.rect.top)all_sprites.add(bullet)bullets.add(bullet)def update(self):# 加入按键控制self.speedx = 0keystate = pygame.key.get_pressed()if keystate[pygame.K_LEFT] or keystate[pygame.K_a]:self.speedx = -5if keystate[pygame.K_RIGHT] or keystate[pygame.K_d] :self.speedx = 5self.rect.x += self.speedx# 边界约束if self.rect.right > WIDTH:self.rect.right = WIDTHif self.rect.left < 0:self.rect.left = 0# 创建敌方类
class Mob(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.image = meteor_imgself.rect = self.image.get_rect()self.radius = int(self.rect.width * 0.85 / 2)# pygame.draw.circle(self.image, RED, self.rect.center, self.radius)# 设置敌方的出生位置,要在屏幕外面,这样才显得不突兀self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)self.speedx = random.randrange(-3, 3)def update(self, *args):self.rect.x += self.speedxself.rect.y += self.speedyif self.rect.top > HEIGHT + 10 or self.rect.left < -25 or self.rect.right>WIDTH+25:self.rect.x = random.randrange(WIDTH - self.rect.width)self.rect.y = random.randrange(-100, -40)self.speedy = random.randrange(1, 8)class Bullet(pygame.sprite.Sprite):def __init__(self, x, y):pygame.sprite.Sprite.__init__(self)self.image = bullet_imgself.rect = self.image.get_rect()self.rect.bottom = yself.rect.centerx = xself.speedy = -10def update(self, *args):self.rect.y += self.speedy# 如果飞出屏幕顶部则销毁if self.rect.bottom < 0:self.kill()# 加载全部游戏图像
background = pygame.image.load(path.join(img_dir, "starfield.png")).convert()
background_rect = background.get_rect()
player_img = pygame.image.load(path.join(img_dir, "playerShip1_orange.png")).convert_alpha()
meteor_img = pygame.image.load(path.join(img_dir, "meteorBrown_med1.png")).convert_alpha()
bullet_img = pygame.image.load(path.join(img_dir, "laserRed16.png")).convert_alpha()
# 创建装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
# 创建敌方精灵组
mobs = pygame.sprite.Group()
# 创建子弹精灵组
bullets = pygame.sprite.Group()player = Player()
all_sprites.add(player)
for i in range(8):m = Mob()all_sprites.add(m)mobs.add(m)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_SPACE:player.shoot()# 2.更新updateall_sprites.update()# 检查碰撞# 检查是否子弹击中敌方dics = pygame.sprite.groupcollide(bullets, mobs, True, True)for dic in dics:m = Mob()all_sprites.add(m)mobs.add(m)# if dic:#     print(dic)hits = pygame.sprite.spritecollide(player, mobs, False, pygame.sprite.collide_circle)if hits:running = False# 3.渲染绘图screen.fill(BLACK)screen.blit(background, background_rect)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

Pygame Shmup Part 6: Sprite Animation(精灵动画)

旋转,如果用以下代码,会因为位信息丢失的累加,让图像失真

    # 设置精灵旋转度数,速率       self.rot = 0self.rot_speed = random.randrange(-8, 8)self.last_update = pygame.time.get_ticks()def rotate(self):now = pygame.time.get_ticks()if now - self.last_update > 50:self.last_update = nowself.rot = (self.rot + self.rot_speed) % 360self.image = pygame.transform.rotate(self.image, self.rot) # 这一行会出问题def update(self, *args):self.rotate() 

self.image = pygame.transform.rotate(self.image, self.rot) # 这一行会出问题
解决办法:
在这里插入图片描述
self.image = pygame.transform.rotate(self.image, self.rot) # 这一行会出问题
由于拷贝的是原始图像,将不会因为失真问题而导致程序崩溃

在这里插入图片描述

import pygame
import random
from os import path
from pygame.locals import *img_dir = path.join(path.dirname(__file__), "img")WIDTH = 360
HEIGHT = 480
FPS = 30# 定义颜色
WHITE = (255, 255, 255)
BLACK = (0, 0, 0)
RED = (255, 0, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)class Plane(pygame.sprite.Sprite):def __init__(self):pygame.sprite.Sprite.__init__(self)self.orig = plane_imgself.image = self.origself.rect = self.image.get_rect()self.rect.centerx = WIDTH / 2self.rect.bottom = HEIGHT / 2self.rot = 0self.rot_speed = 1self.last_update = pygame.time.get_ticks()def update(self, *args):now = pygame.time.get_ticks()if now - self.last_update > 50:self.last_update = nowself.rot = (self.rot + self.rot_speed) % 360new_img = pygame.transform.rotate(self.orig, self.rot)old_center = self.rect.centerself.image = new_imgself.rect = self.image.get_rect()self.rect.center = old_center# 初始化并创建游戏窗口
pygame.init()
pygame.mixer.init() # 如果需要混音声音
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("Test Game") # 设置标题
clock = pygame.time.Clock()
# 必须初始化之后才能加载
plane_img = pygame.image.load(path.join(img_dir, "playerShip1_orange.png")).convert()# 创建一个装有所有精灵的精灵组
all_sprites = pygame.sprite.Group()
plane = Plane()
all_sprites.add(plane)# 游戏循环
running = True
while running:clock.tick(FPS)# 1.处理输入for event in pygame.event.get():# 检查是否关闭窗口事件if event.type == pygame.QUIT:running = False# 2.更新updateall_sprites.update()# 3.渲染绘图screen.fill(BLUE)all_sprites.draw(screen)# 画完了之后翻转显示pygame.display.flip()pygame.quit()

在这里插入图片描述
添加列表随机值,让陨石的图像随机出现
在这里插入图片描述

Pygame Shmup Part 7: Score (and Drawing Text)

在这里插入图片描述

在这里插入图片描述

Pygame Shmup Part 8: Sound and Music

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述


http://chatgpt.dhexx.cn/article/OwYDpHUJ.shtml

相关文章

pygame基础教程

pygame简介 pygame可以实现python游戏的一个基础包。 pygame实现窗口 初始化pygame&#xff0c;init()类似于java类的初始化方法&#xff0c;用于pygame初始化。 pygame.init() 设置屏幕&#xff0c;(500,400)设置屏幕初始大小为500 * 400的大小&#xff0c; 0和32 是比较高…

Python pygame(GUI编程)模块最完整教程(1)

提示&#xff1a;下滑文章左侧可以查看目录&#xff01;本教程分为多篇&#xff0c;总目录如下。 总目录&#xff1a; README.md Python-ZZY/Python-Pygame最完整教程 - Gitee.com 1 初识pygame 1.1 简介 pygame是python中一个流行的GUI编程模块&#xff0c;是专门为了开发游…

Pygame教程(非常详细)

文章目录 教程特点阅读条件 Pygame是什么扩展知识 Pygame下载和安装1) pip包管理器安装2) 二进制安装包安装 第一个Pygame程序初始化程序创建Surface对象事件监听游戏循环 Pygame Display显示模块详解Pygame Surface创建图像Pygame Transform图像变形Pygame Time时间控制详解1)…

GeoWave0.9.8开发人员指南

GeoWave0.9.8开发人员指南 官方英文地址&#xff1a;http://s3.amazonaws.com/geowave/0.9.8/docs/devguide.html 介绍 什么是GeoWave GeoWave是一个开源库&#xff0c;用于在排序的键值数据存储和流行的大数据框架之上存储&#xff0c;索引和搜索多维数据。GeoWave包含特定的…

行人检测之DPM

基于可识别训练的部件模型的目标检测 Object Detection with Discriminatively Trained Part Based Models 摘要 基于多尺度可变形的部件模型我们来描述一个目标检测系统。我们的系统能够表示高度可变的对象类并在PASCAL目标检测挑战达到最先进的结果。虽然可变形部件模型变…

Xuxiang Qi--Deep Learning based Semantic Labelling of 3D Point Cloud in Visual SLAM

元学习论文总结||小样本学习论文总结 2017-2019年计算机视觉顶会文章收录 AAAI2017-2019 CVPR2017-2019 ECCV2018 ICCV2017-2019 ICLR2017-2019 NIPS2017-2019 提出了一种建立三维密集语义地图的方法&#xff0c;采用GPU&#xff0c;ROS消息通信无法支持。 摘要 三维(3D)点云…

古老的DPM

基于可识别训练的部件模型的目标检测 Object Detection with Discriminatively Trained Part Based Models 摘要 基于多尺度可变形的部件模型我们来描述一个目标检测系统。我们的系统能够表示高度可变的对象类并在PASCAL目标检测挑战达到最先进的结果。虽然可变形部件模型变得…

OpenCV-Python (官方)中文教程(部分一)

官网链接(英文版):https://docs.opencv.org/4.1.1/d6/d00/tutorial_py_root.html 第一章. OpenCV简介 了解如何在计算机上设置OpenCV-Python&#xff01; 1.OpenCV-Python教程简介 1.1 OpenCV OpenCV是由Gary Bradsky于1999年在Intel公司创建的&#xff0c;第一次发布是在…

【视觉SLAM十四讲】视觉里程计—特征点法

本文为视觉 SLAM 学习笔记&#xff0c;讲解视觉里程计中的特征点法。 本讲内容概要 图像特征的意义&#xff0c;在单幅及多幅图像中提取特征点。对极几何的原理&#xff0c;利用对极几何的约束恢复图像间相机的三维运动PnP 问题&#xff0c;利用已知三维结构与图像的对应关系…

【记录】一个深度学习算法工程师的成长之路( 思考和方法以及计划 )

原文链接:https://blog.csdn.net/TeFuirnever/article/details/100999282 声明&#xff1a; 1&#xff09;该文章整理自网上的大牛和机器学习专家无私奉献的资料&#xff0c;具体引用的资料请看参考文献。 2&#xff09;本文仅供学术交流&#xff0c;非商用。所以每一部分具体的…

面向动态环境基于面元的RGB-D SLAM系统

点击上方“3D视觉工坊”&#xff0c;选择“星标” 干货第一时间送达 作者&#xff1a;robot L https://zhuanlan.zhihu.com/p/142175916 本文仅做学术分享&#xff0c;如有侵权&#xff0c;请联系删除。 主要内容 面向动态环境基于面元的RGB-D SLAM系统&#xff0c;主要内容如下…

StaticFusion

主要内容 面向动态环境基于面元的RGB-D SLAM系统&#xff0c;主要内容如下&#xff1a; 同时估计RGB-D相机位姿并分割当前帧图片中的静态像素。将当前帧像素的静态概率当做一个取值范围为 的连续变量&#xff0c;和位姿一起联合优化。构建静态场景的面元地图。为此&#xff…

Caffe各层参数详解

在之前的文章中&#xff0c;整理了 ubuntu18安装和caffe-cpu安装问题汇总&#xff08;含详细流程&#xff09;&#xff0c;这篇文章则对caffe的各个层进行一个剖析。文章篇幅较长&#xff0c;可根据目录按层选择阅读。 简述 Net是由Layer层层组成的 Net是由Solver文件支配的…

CoppeliaSim用户手册中文翻译版(二)

CoppeliaSim 用户手册 文章目录 5. 计算模块5.1 计算模块属性对话框5.2 碰撞检测5.3 距离计算5.4 逆运动学5.4.1 IK组和IK元素的基础知识5.4.2 解决IK和FK的任何类型的机制 5.5 逆运动对话框5.5.1 IK元素对话框 5.6 动力学5.6.1 设计动态仿真5.6.2 一般动力学特性5.6.2.1 动态引…

【记录】一个深度学习算法工程师的成长之路(思考和方法以及计划)

声明&#xff1a; 1&#xff09;该文章整理自网上的大牛和机器学习专家无私奉献的资料&#xff0c;具体引用的资料请看参考文献。 2&#xff09;本文仅供学术交流&#xff0c;非商用。所以每一部分具体的参考资料并没有详细对应。如果某部分不小心侵犯了大家的利益&#xff0c…

五年无人驾驶工作总结及展望

点击上方“小白学视觉”&#xff0c;选择加"星标"或“置顶” 重磅干货&#xff0c;第一时间送达本文转自|计算机视觉工坊现在是晚上22点46分&#xff0c;大小美女都睡觉了&#xff0c;我突然想写一篇这五年无人驾驶工作的总结。没有打草稿&#xff0c;想到啥说啥。如…

CoppeliaSim用户手册中文翻译版(一)

CoppeliaSim 用户手册 文章目录 主要功能历史版本许可证致谢和鸣谢概述1. 用户界面1.1 页面和视图1.2 自定义用户界面1.3 位置/方向操作1.3.1 位置对话框1.3.2 方向对话框1.3.3 使用鼠标移动物体 1.4 欧拉角1.5 用户设置1.6 快捷键1.7 命令行 2. 场景和模型2.1 场景2.2 模型2.2…

深度学习一(PyTorch物体检测实战)

深度学习一(PyTorch物体检测实战) 文章目录 深度学习一(PyTorch物体检测实战)1、浅谈物体检测与PyTorch1.1、深度学习与计算机视觉1.1.1 发展历史1.2.2 计算机视觉 1.2、物体检测技术1.2.1、发展历程1.2.2、技术应用领域1.2.3、评价指标 3、PyTorch简介1.3.1、诞生于特点1.3.2、…

目前学什么专业的人在搞SLAM?各有什么优势?

点击上方“小白学视觉”&#xff0c;选择加"星标"或“置顶” 重磅干货&#xff0c;第一时间送达 原提问&#xff1a; 目前学什么专业的人在搞SLAM&#xff1f;如需要哪些专业知识&#xff0c;或者找什么专业的人合作&#xff1f; 李雅不诺夫 一些比较牛掰的论文后面都…

opencv-python学习笔记(十):实现人脸特征转换

引言 本次实验来自实验楼&#xff0c;而实验楼代码的出处为如下GitHub链接&#xff0c;加上一些自己的理解与说明&#xff0c;总结成本文笔记。 https://github.com/matthewearl/faceswap 所需环境 Dlib是一个高级的机器学习库&#xff0c;它是为解决复杂的现实世界问题而创…