代码:

import pygame
import random
import sys
#1 配置图片地址
#IMAGE_PATH = 'grassland.png'
#1 设置页面宽高
scrrr_width=800
scrrr_height =560
#1 创建控制游戏结束的状态
GAMEOVER = False
#4 图片加载报错处理
LOG = '文件:{}中的方法:{}出错'.format(__file__,__name__)
#3 创建地图类
class Map():#3 存储两张不同颜色的图片名称map_names_list = ['map1.png', '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)
#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)
#5 向日葵类
class Sunflower(Plant):def __init__(self,x,y):super(Sunflower, self).__init__()self.image = pygame.image.load('sunflower.PNG')self.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.price = 50self.hp = 100#5 时间计数器self.time_count = 0#5 新增功能:生成阳光def produce_money(self):self.time_count += 1if self.time_count == 25:MainGame.money += 10self.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 为一个 surfaceself.image = pygame.image.load('shooter.png')self.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.price = 50self.hp = 200#6 发射计数器self.shot_count = 0#6 增加射击方法def shot(self):#6 记录是否应该射击should_fire = Falsefor zombie in MainGame.zombie_list:if zombie.rect.y == self.rect.y and zombie.rect.x < 800 and zombie.rect.x > self.rect.x:should_fire = True#6 如果活着if self.live and should_fire:self.shot_count += 1#6 计数器到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)#7 豌豆子弹类
class PeaBullet(pygame.sprite.Sprite):def __init__(self,peashooter):self.live = Trueself.image = pygame.image.load('peabullet.png')self.damage = 100self.speed  = 10self.rect = self.image.get_rect()self.rect.x = peashooter.rect.x + 60self.rect.y = peashooter.rect.y + 15def move_bullet(self):#7 在屏幕范围内,实现往右移动if self.rect.x < scrrr_width:self.rect.x += self.speedelse: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.damageif zombie.hp <= 0:zombie.live = Falseself.nextLevel()#7闯关方法def nextLevel(self):MainGame.score += 20MainGame.remnant_score -=20for i in range(1,100):if MainGame.score==100*i and MainGame.remnant_score==0:MainGame.remnant_score=100*iMainGame.shaoguan+=1MainGame.produce_zombie+=50def display_peabullet(self):MainGame.window.blit(self.image,self.rect)class Nut(Plant):def __init__(self,x,y):super(Nut, self).__init__()self.image = pygame.image.load('nut.png')self.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.price = 50self.hp = 3000def display_nut(self):MainGame.window.blit(self.image,self.rect)#9 僵尸类
class Zombie(pygame.sprite.Sprite):def __init__(self,x,y):super(Zombie, self).__init__()self.image = pygame.image.load('zombies.PNG')self.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.hp = 1000 #僵尸血量self.damage = 10 #僵尸攻击力self.speed = 1 #僵尸速度self.live = Trueself.stop = False#9 僵尸的移动def move_zombie(self):if self.live and not self.stop:self.rect.x -= self.speedif self.rect.x < -80:#8 调用游戏结束方法MainGame().gameOver()#9 判断僵尸是否碰撞到植物,如果碰撞,调用攻击植物的方法def hit_plant(self):for plant in MainGame.plants_list:if pygame.sprite.collide_rect(self,plant):#8  僵尸移动状态的修改self.stop = Trueself.eat_plant(plant)#9 僵尸攻击植物def eat_plant(self,plant):#9 植物生命值减少plant.hp -= self.damage#9 植物死亡后的状态修改,以及地图状态的修改if plant.hp <= 0:a = plant.rect.y // 80 - 1b = plant.rect.x // 80map = MainGame.map_list[a][b]map.can_grow = Trueplant.live = False#8 修改僵尸的移动状态self.stop = False#9 将僵尸加载到地图中def display_zombie(self):MainGame.window.blit(self.image,self.rect)
#1 主程序
class MainGame():#2 创建关数,得分,剩余分数,钱数shaoguan = 1score = 0remnant_score = 100money = 200#3 存储所有地图坐标点map_points_list = []#3 存储所有的地图块map_list = []#4 存储所有植物的列表plants_list = []#7 存储所有豌豆子弹的列表peabullet_list = []#9 新增存储所有僵尸的列表zombie_list = []count_zombie = 0produce_zombie = 100#1 加载游戏窗口def init_window(self):#1 调用显示模块的初始化pygame.display.init()#1 创建窗口MainGame.window = pygame.display.set_mode([scrrr_width,scrrr_height])#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.按右键创建豌豆射手 3.按滚轮创建坚果', 26, (255, 0, 0))MainGame.window.blit(text1, (5, 5))#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 = Noneif (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()#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()elif isinstance(plant, Nut):plant.display_nut()    else:MainGame.plants_list.remove(plant)#7 加载所有子弹的方法def load_peabullets(self):for b in MainGame.peabullet_list:if b.live:b.display_peabullet()b.move_bullet()# v1.9 调用子弹是否打中僵尸的方法b.hit_zombie()else:MainGame.peabullet_list.remove(b)#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  右键 3x = e.pos[0] // 80y = e.pos[1] // 80print(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 = FalseMainGame.money -= 50elif 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 = FalseMainGame.money -= 50elif e.button == 2:if map.can_grow and MainGame.money >= 50:nut = Nut(map.position[0], map.position[1])MainGame.plants_list.append(nut)print('当前植物列表长度:{}'.format(len(MainGame.plants_list)))map.can_grow = FalseMainGame.money -= 50#9 新增初始化僵尸的方法def init_zombies(self):for i in range(1, 7):dis = random.randint(1, 5) * 200zombie = 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)#1 开始游戏def start_game(self):#1 初始化窗口self.init_window()#3 初始化坐标和地图self.init_plant_points()self.init_map()#9 调用初始化僵尸的方法self.init_zombies()#1 只要游戏没结束,就一直循环while not GAMEOVER:#1 渲染白色背景MainGame.window.fill((255, 255, 255))#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()#3 需要反复加载地图self.load_map()#6 调用加载植物的方法self.load_plants()#7  调用加载所有子弹的方法self.load_peabullets()#8 调用事件处理的方法self.deal_events()#9 调用展示僵尸的方法self.load_zombies()#9 计数器增长,每数到100,调用初始化僵尸的方法MainGame.count_zombie += 1if MainGame.count_zombie == MainGame.produce_zombie:self.init_zombies()MainGame.count_zombie = 0#9 pygame自己的休眠pygame.time.wait(10)#1 实时更新pygame.display.update()#10 程序结束方法def gameOver(self):MainGame.window.blit(self.draw_text('游戏结束', 50, (255, 0, 0)), (300, 200))print('游戏结束')pygame.time.wait(400)global GAMEOVERGAMEOVER = Truepygame.quit()sys.exit()#1 启动主程序
if __name__ == '__main__':game = MainGame()game.start_game()

python植物大战僵尸代码1.2相关推荐

  1. python植物大战僵尸代码例_用Python实现植物大战僵尸游戏,很酷

    以前很火的植物大战僵尸游戏, 本想在网上找个python版本游戏学习下,无奈没有发现比较完整的,那就自己来写一个把.图片资源是从github上下载的,因为图片资源有限,只能实现几种植物和僵尸. 功能实 ...

  2. 卡片的sak为不支持的类型_Python 植物大战僵尸代码实现(2):植物卡片选择和种植...

    植物大战僵尸 功能介绍 最近一直在给这个植物大战僵尸游戏添加新的植物和僵尸, 因为网上的图片资源有限,能加的植物和僵尸比较少, 目前进展如下: 功能实现如下: 支持的植物类型:太阳花,豌豆射手,寒冰射 ...

  3. 第5课python植物大战僵尸-添加豌豆射手类

    提示:第5课python植物大战僵尸-添加豌豆射手类 文章目录 摘要 一.豌豆射手类 Peashooter 1.import导入pygame模块 2.定义一个豌豆射手的类型,不用继承任何的类 3.定义 ...

  4. 用 Python 实现植物大战僵尸代码!

    作者 | marble_xu 责编 | 毛中政 出品 | CSDN博客 功能介绍 最近一直在给这个植物大战僵尸游戏添加新的植物和僵尸, 因为网上的图片资源有限,能加的植物和僵尸比较少, 目前进展如下. ...

  5. 涨知识!用 Python 实现植物大战僵尸代码

    作者 | marble_xu 责编 | 毛中政 出品 | CSDN博客 功能介绍 最近一直在给这个植物大战僵尸游戏添加新的植物和僵尸, 因为网上的图片资源有限,能加的植物和僵尸比较少, 目前进展如下. ...

  6. python植物大战僵尸辅助器手机版_GitHub又放大招,Python版本的植物大战僵尸还能作弊玩!...

    <植物大战僵尸>游戏它是一款极富策略性的小游戏,集成了即时战略.塔防御战和卡片收集等要素,玩家控制植物抵御僵尸的进攻,保护这片植物园.记得小编刚工作的时候抱着IPAD经常玩到深夜. 最近在 ...

  7. python植物大战僵尸(1)

    欢迎加入我们卧虎藏龙的python讨论qq群:729683466 ●导 语 ● 之前一直发一些简单的小游戏 百十行代码的那种 估计大家已经了解的一清二楚了 现在可以讲一些比较复杂的游戏 今天就带领大家 ...

  8. 第4课python植物大战僵尸-绘制背景

    摘要 1.新建material文件夹,在该文件下新建images和music,这两个文件存放音乐和图片,还有声音的处理. 2.新建python文件(plant_vs_zoomie_game_norma ...

  9. 用python写一个植物大战僵尸代码

    由于这是一个相对复杂的游戏,所以我将为您提供一个简化版的代码示例. # 创建植物类 class Plant:def __init__(self, name, damage):self.name = n ...

  10. 【Python植物大战僵尸军团来袭】“大家快醒一醒、一大波僵尸来了”

    前言 大家好!我是梨子同学! 希望大家多多支持我!哈哈 为了感谢每一个关注我的小可爱:

最新文章

  1. 写给NLP研究者的编程指南
  2. sqlserver 根据数组排序_看动画学算法之:排序-count排序
  3. cloud foundry_将Spring Boot应用程序绑定到Cloud Foundry中的服务的方法
  4. 删除rz上传失败乱码的文件
  5. LeetCode 362. 敲击计数器(map)
  6. 论文浅尝 | 面向多语言语义解析的神经网络框架
  7. BlogEngine.Net架构与源代码分析系列索引贴
  8. 深入理解jQuery插件开发
  9. python做积分计算器_PyQt5练习:积分计算器
  10. android 让程序在后台运行,android – 如何让我的应用程序在后台运行?
  11. Arraylist的最大长度
  12. 2021 年 GitHub 上十大最火 Python 项目,看完之后我裂开了
  13. 有10亿个整数,要求选取重复次数最多的100个整数
  14. 【产业互联网周报】房企分拆物业公司上市潮来临,“智慧社区”加码;旷视智慧物流业务定位及战略布局;京东健康与药明康德入股卫宁科技...
  15. 计算机文化基础项目化教程答案,第七版计算机文化基础实践教程 第3-4章习题答案及解析...
  16. 深度学习推理框架调研总结
  17. Linux内核是什么?Linux内核是怎么工作的?
  18. 如何优雅地追回被骗款项(上篇)
  19. OSS: cURL error: Empty reply from server (52)
  20. java as2_使用AS2(http)协议实现 B2B 商用数据交换 (二) [译]

热门文章

  1. windows运行命令大全
  2. Win7主题文件themepack不能安装,低级错误!
  3. 大学计算机实验vfp,Visual FoxPro程序设计上机实验(第2版)
  4. EASE-Grid投影
  5. Oracle 12c RAC--安装grid
  6. 谷歌、火狐浏览器扩展开发
  7. linux终端字体安装,在Gnome-terminal下安装以及使用Monaco字体
  8. 编译原理第四章--自上而下的语法分析
  9. 计算机控制的行业规模,2019年中国DCS控制系统行业市场现状及竞争格局分析,内资“两家独大”「图」...
  10. 用java判定三角形_人教版初中数学八年级上册“角角边”判定三角形全等公开课优质课课件教案视频...