Python开发植物大战僵尸游戏(附github项目地址)
今天给大家分享一个仿《植物大战僵尸》的小游戏开发案例。
开发思路
- 引入需要的模块,配置图片路径,设置界面宽高背景颜色,创建游戏主入口。
#1引入需要的模块
import pygame
import random
#1配置图片地址
IMAGE_PATH = ‘imgs/’
#1设置页面宽高
scrrr_width=800
scrrr_height =560
#1创建控制游戏结束的状态
GAMEOVER = False
#1主程序
class MainGame():
#1加载游戏窗口
def init_window(self):
#1调用显示模块的初始化
pygame.display.init()
#1创建窗口
MainGame.window = pygame.display.set_mode([scrrr_width,scrrr_height]) #
#1开始游戏
def start_game(self):
#1初始化窗口
self.init_window()
#1只要游戏没结束,就一直循环
while not GAMEOVER:
#1渲染白色背景
MainGame.window.fill((255, 255, 255))
#1实时更新
pygame.display.update()
#1启动主程序
if name == ‘main’:
game = MainGame()
game.start_game()
- 文本绘制,创建要动态改变的属性,渲染的位置
#2 创建关数,得分,剩余分数,钱数
shaoguan = 1
score = 0
remnant_score = 100
money = 200
#2 文本绘制
def draw_text(self, content, size, color):
pygame.font.init()
font = pygame.font.SysFont(‘kaiti’, size)
text = font.render(content, True, color)
return text
#2 加载帮助提示
def load_help_text(self):
text1 = self.draw_text(‘1.按左键创建向日葵 2.按右键创建豌豆射手’, 26, (255, 0, 0))
MainGame.window.blit(text1, (5, 5))
#2 渲染的文字和坐标位置
MainGame.window.blit(self.draw_text(‘当前钱数$: {}’.format(MainGame.money), 26, (255, 0, 0)), (500, 40))
MainGame.window.blit(self.draw_text(
‘当前关数{},得分{},距离下关还差{}分’.format(MainGame.shaoguan, MainGame.score, MainGame.remnant_score), 26,
(255, 0, 0)), (5, 40))
self.load_help_text()
最后,如果你的时间不是很紧张,并且又想python快速的提高,最重要的是不怕吃苦,建议你可以扩我伪xin 762459510 ,那个真的很不错,很多人进步都很快,需要你不怕吃苦哦!大家可以去添加上看一下~
- 创建地图类,初始化地图和坐标
#3 创建地图类
class Map():
#3 存储两张不同颜色的图片名称
map_names_list = [IMAGE_PATH + ‘map1.png’, IMAGE_PATH + ‘map2.png’]
#3 初始化地图
def init(self, x, y, img_index):
self.image = pygame.image.load(Map.map_names_list[img_index])
self.position = (x, y)
是否能够种植
self.can_grow = True
#3 加载地图
def load_map(self):
MainGame.window.blit(self.image,self.position)
#3 存储所有地图坐标点
map_points_list = []
#3 存储所有的地图块
map_list = []
#3 初始化坐标点
def init_plant_points(self):
for y in range(1, 7):
points = []
for x in range(10):
point = (x, y)
points.append(point)
MainGame.map_points_list.append(points)
print(“MainGame.map_points_list”, MainGame.map_points_list)
#3 初始化地图
def init_map(self):
for points in MainGame.map_points_list:
temp_map_list = list()
for point in points:
map = None
if (point[0] + point[1]) % 2 == 0:
map = Map(point[0] * 80, point[1] * 80, 0)
else:
map = Map(point[0] * 80, point[1] * 80, 1)
将地图块加入到窗口中
temp_map_list.append(map)
print(“temp_map_list”, temp_map_list)
MainGame.map_list.append(temp_map_list)
print(“MainGame.map_list”, MainGame.map_list)
#3 将地图加载到窗口中
def load_map(self):
for temp_map_list in MainGame.map_list:
for map in temp_map_list:
map.load_map()
#3 初始化坐标和地图
self.init_plant_points()
self.init_map()
#3 需要反复加载地图
self.load_map()
- 创建植物类,图片加载报错处理,加载植物方法
#4 图片加载报错处理
LOG = ‘文件:{}中的方法:{}出错’.format(file,name)
#4 植物类
class Plant(pygame.sprite.Sprite):
def init(self):
super(Plant, self).init()
self.live=True
加载图片
def load_image(self):
if hasattr(self, ‘image’) and hasattr(self, ‘rect’):
MainGame.window.blit(self.image, self.rect)
else:
print(LOG)
#4 存储所有植物的列表
plants_list = []
- 创建向日葵类
#5 向日葵类
class Sunflower(Plant):
def init(self,x,y):
super(Sunflower, self).init()
self.image = pygame.image.load(‘imgs/sunflower.png’)
self.rect = self.image.get_rect()
self.rect.x = x
self.rect.y = y
self.price = 50
self.hp = 100
#5 时间计数器
self.time_count = 0
#5 功能:生成阳光(生产钱)
def produce_money(self):
self.time_count += 1
if self.time_count == 25:
MainGame.money += 5
self.time_count = 0
#5 向日葵加入到窗口中
def display_sunflower(self):
MainGame.window.blit(self.image,self.rect)
- 创建豌豆射手类
#6 豌豆射手类
class PeaShooter(Plant):
def init(self,x,y):
super(PeaShooter, self).init()
self.image 为一个 surface
self.image = pygame.image.load(‘imgs/peashooter.png’)
self.rect = self.image.get_rect()
self.rect.x = x
self.rect.y = y
self.price = 50
self.hp = 200
#6 发射计数器
self.shot_count = 0
#6 增加射击方法
def shot(self):
#6 记录是否应该射击
should_fire = False
for zombie in MainGame.zombie_list:
if zombie.rect.y == self.rect.y and zombie.rect.xself.rect.x:
should_fire = True
#6 如果活着
if self.live and should_fire:
self.shot_count += 1
计数器到25发射一次
if self.shot_count == 25:
#6 基于当前豌豆射手的位置,创建子弹
peabullet = PeaBullet(self)
#6 将子弹存储到子弹列表中
MainGame.peabullet_list.append(peabullet)
self.shot_count = 0
#6 将豌豆射手加入到窗口中的方法
def display_peashooter(self):
MainGame.window.blit(self.image,self.rect)
#6 增加豌豆射手发射处理
def load_plants(self):
for plant in MainGame.plants_list:
#6 优化加载植物的处理逻辑
if plant.live:
if isinstance(plant, Sunflower):
plant.display_sunflower()
plant.produce_money()
elif isinstance(plant, PeaShooter):
plant.display_peashooter()
plant.shot()
else:
MainGame.plants_list.remove(plant)
#6 调用加载植物的方法
self.load_plants()
- 创建子弹类
#7 豌豆子弹类
class PeaBullet(pygame.sprite.Sprite):
def init(self,peashooter):
self.live = True
self.image = pygame.image.load(‘imgs/peabullet.png’)
self.damage = 50
self.speed = 10
self.rect = self.image.get_rect()
self.rect.x = peashooter.rect.x + 60
self.rect.y = peashooter.rect.y + 15
def move_bullet(self):
#7 在屏幕范围内,实现往右移动
if self.rect.x
self.rect.x += self.speed
else:
self.live = False
#7 新增,子弹与僵尸的碰撞
def hit_zombie(self):
for zombie in MainGame.zombie_list:
if pygame.sprite.collide_rect(self,zombie):
#打中僵尸之后,修改子弹的状态,
self.live = False
#僵尸掉血
zombie.hp -= self.damage
if zombie.hp
zombie.live = False
self.nextLevel()
#7闯关方法
def nextLevel(self):
MainGame.score += 20
MainGame.remnant_score -=20
for i in range(1,100):
if MainGame.score100*i and MainGame.remnant_score0:
MainGame.remnant_score=100*i
MainGame.shaoguan+=1
MainGame.produce_zombie+=50
def display_peabullet(self):
MainGame.window.blit(self.image,self.rect)
#7 存储所有豌豆子弹的列表
peabullet_list = []
#7 加载所有子弹的方法
def load_peabullets(self):
for b in MainGame.peabullet_list:
if b.live:
b.display_peabullet()
b.move_bullet()
#7 调用子弹是否打中僵尸的方法
b.hit_zombie()
else:
MainGame.peabullet_list.remove(b)
#7 调用加载所有子弹的方法
self.load_peabullets()
- 事件处理
#8事件处理
def deal_events(self):
#8 获取所有事件
eventList = pygame.event.get()
#8 遍历事件列表,判断
for e in eventList:
if e.type == pygame.QUIT:
self.gameOver()
elif e.type == pygame.MOUSEBUTTONDOWN:
print(‘按下鼠标按键’)
print(e.pos)
print(e.button)#左键1 按下滚轮2 上转滚轮为4 下转滚轮为5 右键 3
x = e.pos[0] // 80
y = e.pos[1] // 80
print(x, y)
map = MainGame.map_list[y - 1][x]
print(map.position)
#8 增加创建时候的地图装填判断以及金钱判断
if e.button == 1:
if map.can_grow and MainGame.money >= 50:
sunflower = Sunflower(map.position[0], map.position[1])
MainGame.plants_list.append(sunflower)
print(‘当前植物列表长度:{}’.format(len(MainGame.plants_list)))
map.can_grow = False
MainGame.money -= 50
elif e.button == 3:
if map.can_grow and MainGame.money >= 50:
peashooter = PeaShooter(map.position[0], map.position[1])
MainGame.plants_list.append(peashooter)
print(‘当前植物列表长度:{}’.format(len(MainGame.plants_list)))
map.can_grow = False
MainGame.money -= 50
#8 调用事件处理的方法
self.deal_events()
- 创建僵尸类
#9 僵尸类
class Zombie(pygame.sprite.Sprite):
def init(self,x,y):
super(Zombie, self).init()
self.image = pygame.image.load(‘imgs/zombie.png’)
self.rect = self.image.get_rect()
self.rect.x = x
self.rect.y = y
self.hp = 1000
self.damage = 2
self.speed = 1
self.live = True
self.stop = False
#9 僵尸的移动
def move_zombie(self):
if self.live and not self.stop:
self.rect.x -= self.speed
if self.rect.x
#8 调用游戏结束方法
MainGame().gameOver()
#9 判断僵尸是否碰撞到植物,如果碰撞,调用攻击植物的方法
def hit_plant(self):
for plant in MainGame.plants_list:
if pygame.sprite.collide_rect(self,plant):
#8 僵尸移动状态的修改
self.stop = True
self.eat_plant(plant)
#9 僵尸攻击植物
def eat_plant(self,plant):
#9 植物生命值减少
plant.hp -= self.damage
#9 植物死亡后的状态修改,以及地图状态的修改
if plant.hp
a = plant.rect.y // 80 - 1
b = plant.rect.x // 80
map = MainGame.map_list[a][b]
map.can_grow = True
plant.live = False
#8 修改僵尸的移动状态
self.stop = False
#9 将僵尸加载到地图中
def display_zombie(self):
MainGame.window.blit(self.image,self.rect)
#9 新增存储所有僵尸的列表
zombie_list = []
count_zombie = 0
produce_zombie = 100
#9 新增初始化僵尸的方法
def init_zombies(self):
for i in range(1, 7):
dis = random.randint(1, 5) * 200
zombie = Zombie(800 + dis, i * 80)
MainGame.zombie_list.append(zombie)
#9将所有僵尸加载到地图中
def load_zombies(self):
for zombie in MainGame.zombie_list:
if zombie.live:
zombie.display_zombie()
zombie.move_zombie()
v2.0 调用是否碰撞到植物的方法
zombie.hit_plant()
else:
MainGame.zombie_list.remove(zombie)
#9 调用初始化僵尸的方法
self.init_zombies()
#9 调用展示僵尸的方法
self.load_zombies()
#9 计数器增长,每数到100,调用初始化僵尸的方法
MainGame.count_zombie += 1
if MainGame.count_zombie == MainGame.produce_zombie:
self.init_zombies()
MainGame.count_zombie = 0
#9 pygame自己的休眠
pygame.time.wait(10)
- 游戏结束方法
#10 程序结束方法
def gameOver(self):
MainGame.window.blit(self.draw_text(‘游戏结束’, 50, (255, 0, 0)), (300, 200))
pygame.time.wait(400)
global GAMEOVER
GAMEOVER = True
以上就是整个游戏的开发思路和核心代码,大家可以自己尝试更改游戏参数,或增加更多功能。
如果文章对你有帮助,欢迎转发/点赞/收藏~
往期文章推荐
如需了解付费精品课程及教学答疑服务
请在梦子mengy7762内回复:666
Python开发植物大战僵尸游戏(附github项目地址)相关推荐
- [Python] 开发植物大战僵尸游戏
用python开发植物大战僵尸 早期的植物大战僵尸是由vc开发的,作者的想法是非常地有特色,所以今天我们来探讨下植物大战僵尸游戏的进入场景怎么开发. 我们首需要用到如下几个文件 程序文件 功能 gam ...
- 牛逼了!Python 开发植物大战僵尸游戏
作者:楷楷 链接: https://segmentfault.com/a/1190000019418065 开发思路 完整项目地址: https://github.com/371854496/pyga ...
- Python 开发植物大战僵尸游戏
开发思路 1.引入需要的模块,配置图片路径,设置界面宽高背景颜色,创建游戏主入口. #1引入需要的模块 import pygame import random #1配置图片地址 IMAGE_PATH ...
- Python开发植物大战僵尸游戏,详细教程
1.引入需要的模块,配置图片路径,设置界面宽高背景颜色,创建游戏主入口. #1引入需要的模块 import pygame import random #1配置图片地址 IMAGE_PATH = 'im ...
- 基于python的植物大战僵尸游戏开发
1 简介 今天向大家介绍一个帮助往届学生完成的毕业设计项目,基于python的植物大战僵尸游戏开发. 计算机毕业生设计,课程设计需要帮助的可以找我 2 设计概要 21世纪是信息化时代,随着信息技术和网 ...
- python版植物大战僵尸源码_基于python的植物大战僵尸游戏设计与实现.docx
湖南理工学院毕业设计(论文) PAGE PAGE 1 学 号 毕业设计(论文) 题目:基于python的植物大战僵尸游戏设计与实现 作 者 届 别 届 院 别 信息与通信工程学院 专 业 信息工程 指 ...
- python植物大战僵尸代码例_用Python实现植物大战僵尸游戏,很酷
以前很火的植物大战僵尸游戏, 本想在网上找个python版本游戏学习下,无奈没有发现比较完整的,那就自己来写一个把.图片资源是从github上下载的,因为图片资源有限,只能实现几种植物和僵尸. 功能实 ...
- python编写植物大战僵尸_python开发植物大战僵尸游戏
开发思路 完整项目地址:https://github.com/371854496/... 觉得还OK的话,点下Star,作者不易,thank you! 1.引入需要的模块,配置图片路径,设置界面宽高背 ...
- python实现植物大战僵尸_Python开发植物大战僵尸游戏
开发思路 1.引入需要的模块,配置图片路径,设置界面宽高背景颜色,创建游戏主入口. 1引入需要的模块 import pygame import random 1配置图片地址 IMAGE_PATH = ...
最新文章
- 基本数据类型和引用数据类型作为参数时候的问题
- mysql线程异常中断事务_清理MySQL死锁事务线程
- 你选的那些创业方向 可能正在毁掉你!
- 使用SOCKET实现TCP/IP协议的通讯
- JDK 14的新特性:文本块Text Blocks
- 明细表如何添加重量_关于Revit中明细表标准的导出及导入
- 使用valgrind检查cache命中率
- Unity 无法识别视频
- 如何在PowerPoint中更改整个演示文稿的格式
- 【FineBI】权限控制之动态维度/动态列
- kotterKnife+dagger2+otto+okhttp+picasso+retrofit+rxjava示例项目,使用kotlin编写。
- android aoto未解锁,【求教】为什么我的解锁屏幕代码缺无法解锁屏幕
- Java导出带格式的Excel数据到Word表格
- nginx中的超时设置,请求超时、响应等待超时等
- 实现财务自由 之 A 股上市公司的年报(年度财报)查阅查看、下载地址、以及下载的方法
- 阿里云MQTT_Password工具下载地址
- R_Studio(学生成绩)对数据缺失值md.pattern()、异常值分析(箱线图)
- 微信小程序开发实战11_4 微信支付退款流程
- 机器学习模型性能提升技巧:指数加权平均(EMA)
- PHP - ChatGpt 学习 仅供参考
热门文章
- 第一篇学术演讲准备两个月,去了谷歌却做不了深度学习,听Facebook田渊栋谈人生挑战与选择...
- 我,25岁,高中时创立的自动驾驶技术公司即将上市,估值34亿美元
- 年薪70W架构师:全套英语学习资源泄露,手慢则无!(禁止外传)
- 双十一,假如有人把支付宝存储服务器炸了,你的钱是不是都没了?
- 张一鸣、王欣、罗永浩三家对垒微信,张小龙如何应对?
- 数据结构之二分查找(折半查找)
- OSPF协议将其管理的网络划分为不同类型的若干区域(Area),其中标准区域特点是(64);存根区域(stub)的特点是(65)。【答案】C B
- 一文带你了解为什么是知识图谱的时代!
- darknet-mini:带注释的darknet简化版,助你深入理解YOLO
- ResNet在计算机视觉中的应用