Python面向对象植物大战僵尸

news2024/11/24 4:12:57

先来一波效果图

 

 来看看如何设计游戏架构

import sys

import pygame


class BaseSprite(pygame.sprite.Sprite):
    def __init__(self, name):
        super().__init__()
        self.image = pygame.image.load(name)
        self.rect = self.image.get_rect()


class AnimateSprite(BaseSprite):
    def __init__(self, default_name, names):
        super().__init__(default_name)
        self.images = [pygame.image.load(name) for name in names]
        self.current = 0

    def update(self):
        self.current += 1
        if self.current == len(self.images) * 2:
            self.current = 0
        self.image = self.images[self.current // 2]


class Enemy(AnimateSprite):
    def __init__(self, default_name, names, center, gm):
        super().__init__(default_name, names)
        self.rect.center = center
        self.time_count = 2
        self.gm = gm

        self.bullet_group = pygame.sprite.Group()

    def update(self):
        super().update()
        self.rect.left -= 1


class PeaShooter(AnimateSprite):
    def __init__(self, default_name, names, center, gm):
        super().__init__(default_name, names)
        self.rect.center = center
        self.time_count = 5
        self.gm = gm

        self.bullet_group = pygame.sprite.Group()

    def update(self):
        super().update()
        self.time_count -= 0.1
        if self.time_count <= 0:
            self.time_count = 5
            BulletSprite("bullet.png", (self.rect.right, self.rect.top + 15)).add(self.bullet_group)

        self.bullet_group.draw(self.gm.screen)
        self.bullet_group.update()

        print("当前子弹哟", len(self.bullet_group.sprites()))


class BulletSprite(BaseSprite):
    def __init__(self, name, center):
        super().__init__(name)
        self.rect.center = center

    def update(self):
        self.rect.left += 5
        if self.rect.left > 1400:
            self.kill()


class GameManage:
    def __init__(self):
        self.screen = pygame.display.set_mode((1400, 600))
        pygame.display.set_caption("植物大战僵尸")

        self.clock = pygame.time.Clock()

        self.bg_surface = pygame.image.load("background1.jpg")

        # 射手精灵组
        self.pea_shooter_group = pygame.sprite.Group()

        self.pea1 = PeaShooter("plants/peashooter/idle/idle_00.png",
                               [f"plants/peashooter/idle/idle_0{i}.png" for i in range(8)], (700, 200), self)
        self.pea1.add(self.pea_shooter_group)

        self.pea2 = PeaShooter("plants/peashooter/idle/idle_00.png",
                               [f"plants/peashooter/idle/idle_0{i}.png" for i in range(8)], (700, 300), self)
        self.pea2.add(self.pea_shooter_group)

        self.enemy_group = pygame.sprite.Group()

        images = [f"zombies/run/run_0{i}.png" for i in range(10)]
        for i in range(10, 31):
            images.append(f"zombies/run/run_{i}.png")

        self.enemy1 = Enemy("zombies/run/run_00.png", images, (1400, 200), self)
        self.enemy1.add(self.enemy_group)

        self.enemy2 = Enemy("zombies/run/run_00.png", images, (1100, 200), self)
        self.enemy2.add(self.enemy_group)

        self.enemy3 = Enemy("zombies/run/run_00.png", images, (1300, 300), self)
        self.enemy3.add(self.enemy_group)

        self.enemy4 = Enemy("zombies/run/run_00.png", images, (1200, 300), self)
        self.enemy4.add(self.enemy_group)

    def run(self):
        while True:
            self.clock.tick(20)

            for event in pygame.event.get():
                if event.type == pygame.QUIT:
                    pygame.quit()
                    sys.exit()

            self.screen.blit(self.bg_surface, (0, 0))

            self.pea_shooter_group.draw(self.screen)
            self.pea_shooter_group.update()

            self.enemy_group.draw(self.screen)
            self.enemy_group.update()


            for pea_sprite in self.pea_shooter_group.sprites():
                if pygame.sprite.groupcollide(pea_sprite.bullet_group, self.enemy_group, True, True):
                    print("打死了一个僵尸")

            pygame.display.flip()


gm = GameManage()
gm.run()

抛砖引玉,等待后续完善。。。。。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/892525.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ARM体系结构学习笔记:PC寄存器

PC寄存器 32位thumb也是采用三级流水线结构,但是每个指令位2个字节因此4thumb模式读PC寄存器 mov r0, pc ; thumb mode r0 pc 4LDR R1, (aLd - 0xAC3B62C) ADD R1, PC ; "%ld\n"thumb模式使用LDR使用PC进行间接寻址 如…

jvs-logic(逻辑引擎)的产生背景和使用场景作用

逻辑引擎的由来 要了解逻辑引擎的产生背景&#xff0c;我们需要了解程序执行的基本原理&#xff0c;那么编译是少不了的&#xff0c;编译是将高级语言翻译成为机器可以执行的机器语言 。我们在做日常开发过程中&#xff0c;把通用的业务逻辑通过高级语言写出来后&#xff0c;需…

2022年12月 C/C++(二级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题&#xff1a;数组逆序重放 将一个数组中的值按逆序重新存放。例如&#xff0c;原来的顺序为8,6,5,4,1。要求改为1,4,5,6,8。 输入 输入为两行&#xff1a;第一行数组中元素的个数n(1 输出 输出为一行&#xff1a;输出逆序后数组的整数&#xff0c;每两个整数之间用空格分隔…

87-基于stm32单片机粮仓仓库环境温湿度烟雾监测报警系统Proteus仿真+源码

资料编号&#xff1a;087 一&#xff1a;功能介绍&#xff1a; 1、采用stm32单片机OLED显示屏烟雾浓度检测DHT11温湿度电机按键蜂鸣器&#xff0c;制作一个温湿度采集、烟雾浓度采集&#xff0c;OLED显示相关数据&#xff0c; 2、通过按键设置温度上限、烟雾浓度上限&#xff0…

逻辑漏洞合集

0x01 未授权 未授权问题为普通用户登录或没有登录后&#xff0c;拼接js接口&#xff0c;构造报文&#xff0c;越权实现管理员的权限操作。原因&#xff1a;后端没有校验Cookie/Session的身份信息&#xff0c;以至于普通用户的权限可以实现管理员权限的功能。 First webpack打…

dll修复精灵怎么下载,vcruntime140.dll丢失该如何修复

vcruntime140.dll是Microsoft Visual C Redistributable中的一个动态链接库&#xff08;DLL&#xff09;文件。它是一种运行时库&#xff08;Runtime Library&#xff09;&#xff0c;用于支持使用Microsoft Visual C编写的程序的正常运行。作为一个DLL文件&#xff0c;vcrunti…

ModStartCMS v7.0.0 多语言开发优化,多个常用组件升级

ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用&#xff0c;支持后台一键快速安装&#xff0c;让开发者能快的实现业务功能开发。 系统完全开源&#xff0c;基于 Apache 2.0 开源协议&#xff0c;免费且不限制商业使用。 功能特性 丰富的模块市…

超越传统测试方法:掌握最新的测试技术和工具

随着科技的不断进步和软件行业的快速发展&#xff0c;传统的测试方法已经无法满足现代软件开发的需求。为了提高测试的效率和准确性&#xff0c;测试人员需要及时掌握最新的测试技术和工具。本文将探讨一些创新的测试技术和工具&#xff0c;帮助测试人员超越传统的测试方法。 首…

Visual Studio 配置远程调试

1.在Visual Studio安装目录中找到远程调试工具(msvsmon.exe)。 2.将x64文件夹压缩成压缩包&#xff0c;然后拷贝到客户机 3.将pdb文件拷贝到客户机上版本对应的文件夹中。 4. 启动Visual Studio开始进行远程调试 选择“调试”> “附加到进程”

p-级数的上界(Upper bound of p-series)

积分判别法-The Integral Test https://math.stackexchange.com/questions/2858067/upper-bound-of-p-series https://courses.lumenlearning.com/calculus2/chapter/the-p-series-and-estimating-series-value/ 两个重要级数&#xff08;p级数和几何级数&#xff09; ht…

探索OLED透明屏方案的设计与应用

OLED透明屏作为一种新兴的显示技术&#xff0c;正逐渐在商业展示、新媒体互动和智能家居等领域展现出广阔的应用前景。 在这篇文章中&#xff0c;尼伽将深入探讨OLED透明屏方案的设计和应用&#xff0c;展示其在提升用户体验和创造商业价值方面的优势。 一、OLED透明屏方案的设…

web前端tips:js继承——组合继承

上篇文章给大家分享了 js继承中的借用构造函数继承 web前端tips&#xff1a;js继承——借用构造函数继承 在借用构造函数继承中&#xff0c;我提到了它的缺点 无法继承父类原型链上的方法和属性&#xff0c;只能继承父类构造函数中的属性和方法 父类的方法无法复用&#xff0…

UE Json Operate 解析嵌套数组

演示如何使用 DTJsonOperate 插件&#xff0c;在蓝图中解析嵌套数组。 比如这个Json {"name": [[[1, 2]],[3, 4],[5, 6]] } 操作演示 最后打印 本功能需要插件支持&#xff0c;插件下载地址。

2023牛客多校第二场 G Link with Centrally Symmetric String(类马拉车)

2023牛客多校第二场 G Link with Centrally Symmetric Strings(类马拉车 最长回文后缀) 题目链接 大意&#xff1a;定义对称回文的回文中心可以是 间隔(偶回文中心) 或者 o / x / s / z (奇回文中心) 五种 &#xff0c; 定义匹配为 b/q d/p n/u o/o x/x s/s z/z 之间相互匹…

nvm安装使用与常见问题

前言 nvm是一个用来进行nodejs多个版本管理和切换的工具。这个工具的使用相当简单和方便&#xff0c;但是没想到我使用的时候却遇到了好些问题&#xff0c;这里记录一下顺便分享。 安装nvm 先去下载地址Releases coreybutler/nvm-windows GitHub下载&#xff0c;建议选择下…

批量记录收支明细,轻松通过收支占比图表轻松分析支出项目占比!

您是否希望更加直观地了解个人或企业的支出项目占比情况&#xff1f;是否想通过图表分析&#xff0c;快速定位支出的主要项目&#xff0c;并做出相应的调整&#xff1f;现在&#xff0c;我们的智能收支分析大师为您提供了一种智能化的解决方案&#xff01;只需几步操作&#xf…

sliver C2 切换会话

使用中发现会话的切换直接输入sessions,显示会话 use 切换到新会话 在测试进程迁移的时候发现命令不好用 多次尝试,没有成功的

骨传导耳机戴久了头疼正常吗?骨传导耳机对健康有影响吗

骨传导耳机戴久了头疼正常吗&#xff1f;骨传导耳机对健康有影响吗 长时间佩戴骨传导耳机可能会引起一些人头疼的不适感&#xff0c;这可能是因为长时间的接触和震动影响了你的感知和舒适度。如果你遇到这样的问题&#xff0c;可以尝试以下几种解决方法&#xff1a; ⑴适当休…

第6章:支持向量机

间隔与支持向量 w为法向量&#xff0c;决定的是超平面的方向。b是偏移项&#xff0c;决定了超平面与原点之间的距离。 为什么最大化间隔&#xff0c;得到的就是最优平面呢&#xff1f; 当超平面没有正确划分正负样本时&#xff0c;几何间隔为负数。几何间隔&#xff0c;各个…

C++学习系列之DLL动态库使用

C学习系列之DLL动态库使用 啰嗦动态库的创建动态库的调用函数生成1.需要头文件函数定义&#xff08;头文件&#xff09;2.需要函数定义&#xff08;函数文件&#xff09;3.动态库中的头文件4.动态库中的主文件5.运行查看是否存在C#的调用的入口点6.C#调用 总结 啰嗦 项目需要&…