80 python - 打飞机案例(代码优化-抽象出基类)

简介: 80 python - 打飞机案例(代码优化-抽象出基类)
#coding=utf-8
import time
import random
import pygame
from pygame.locals import *
class Base(object):
    def __init__(self,screen,name):
        self.name = name
        #设置要显示内容的窗口
        self.screen = screen
class Plane(Base):
    def __init__(self,screen,name):
        super().__init__(screen,name)
        self.image = pygame.image.load(self.imageName).convert()
        #用来存储英雄飞机发射的所有子弹
        self.bulletList = []
    def display(self):
        #更新飞机的位置
        self.screen.blit(self.image,(self.x,self.y))
        #判断一下子弹的位置是否越界,如果是,那么就要删除这颗子弹
        #
        #这种方法会漏掉很多需要删除的数据
        # for i in self.bulletList:
        #     if i.y<0:
        #         self.bulletList.remove(i)
        #存放需要删除的对象信息
        needDelItemList = []
        for i in self.bulletList:
            if i.judge():
                needDelItemList.append(i)
        for i in needDelItemList:
            self.bulletList.remove(i)
        # del needDelItemList
        #更新及这架飞机发射出的所有子弹的位置
        for bullet in self.bulletList:
            bullet.display()
            bullet.move()
        #修改所有子弹的位置
        # for bullet in self.bulletList:
        #     bullet.y -= 2
    def sheBullet(self):
        newBullet = PublicBullet(self.x,self.y,self.screen,self.name)
        self.bulletList.append(newBullet)
class HeroPlane(Plane):
    def __init__(self,screen,name):
        #设置飞机默认的位置
        self.x = 230
        self.y = 600
        self.imageName = "./feiji/hero.gif"
        super().__init__(screen,name)
    def moveLeft(self):
        self.x -= 10
    def moveRight(self):
        self.x += 10
class EnemyPlane(Plane):
    #重写父类的__init_-方法
    def __init__(self,screen,name):
        #设置飞机默认的位置
        self.x = 0
        self.y = 0
        self.imageName = "./feiji/enemy-1.gif"
        #调用父类的__init__方法
        super().__init__(screen,name)
        self.direction = "right"
    def move(self):
        #如果碰到了右边的边界,那么就往左走,如果碰到了左边的边界,那么就往右走
        if self.direction == "right":
            self.x += 2
        elif self.direction == "left":
            self.x -= 2
        if self.x>480-50:
            self.direction = "left"
        elif self.x<0:
            self.direction = "right"
    def sheBullet(self):
        num = random.randint(1,100)
        if num == 88:
            super().sheBullet()
class PublicBullet(Base):
    def __init__(self,x,y,screen,planeName):
        super().__init__(screen,planeName)
        if self.name == "hero":
            self.x = x+40
            self.y = y-20
            imageName = "./feiji/bullet-3.gif"
        elif self.name == "enemy":
            self.x = x+30
            self.y = y+30
            imageName = "./feiji/bullet-1.gif"
        self.image = pygame.image.load(imageName).convert()
    def move(self):
        if self.name == "hero":
            self.y -= 2
        elif self.name == "enemy":
            self.y += 2
    def display(self):
        self.screen.blit(self.image,(self.x,self.y))
    def judge(self):
        if self.y>890 or self.y<0:
            return True
        else:
            return False
if __name__ == "__main__":
    #1. 创建一个窗口,用来显示内容
    screen = pygame.display.set_mode((480,890),0,32)
    #2. 创建一个和窗口大小的图片,用来充当背景
    background = pygame.image.load("./feiji/background.png").convert()
    #3. 创建一个飞机对象
    heroPlane = HeroPlane(screen,"hero")
    #4. 创建一个敌人飞机
    enemyPlane = EnemyPlane(screen,"enemy")
    #3. 把背景图片放到窗口中显示
    while True:
        screen.blit(background,(0,0))
        heroPlane.display()
        enemyPlane.move()
        enemyPlane.sheBullet()
        enemyPlane.display()
        #判断是否是点击了退出按钮
        for event in pygame.event.get():
            # print(event.type)
            if event.type == QUIT:
                print("exit")
                exit()
            elif event.type == KEYDOWN:
                if event.key == K_a or event.key == K_LEFT:
                    print('left')
                    heroPlane.moveLeft()
                    #控制飞机让其向左移动
                elif event.key == K_d or event.key == K_RIGHT:
                    print('right')
                    heroPlane.moveRight()
                elif event.key == K_SPACE:
                    print("space")
                    heroPlane.sheBullet()
        time.sleep(0.01)
        pygame.display.update()
目录
相关文章
|
1天前
|
前端开发 JavaScript Python
使用Python读取本地行情csv文件,做出web网页画出K线图实现案例
【5月更文挑战第4天】使用Python绘制K线图的步骤:1) 安装pandas, matplotlib和Flask;2) 用pandas读取CSV文件并处理数据;3) 创建Flask应用,渲染包含K线图数据的HTML;4) 编写HTML,使用ECharts库绘制K线图。
13 0
|
6天前
|
机器学习/深度学习 数据采集 TensorFlow
【Python机器学习专栏】使用Python进行图像分类的实战案例
【4月更文挑战第30天】本文介绍了使用Python和深度学习库TensorFlow、Keras进行图像分类的实战案例。通过CIFAR-10数据集,展示如何构建和训练一个卷积神经网络(CNN)模型,实现对10个类别图像的识别。首先安装必要库,然后加载数据集并显示图像。接着,建立基本CNN模型,编译并训练模型,最后评估其在测试集上的准确性。此案例为初学者提供了图像分类的入门教程,为进一步学习和优化打下基础。
|
6天前
|
数据可视化 Python
Python用 PyMC3 贝叶斯推理案例研究:抛硬币和保险索赔发生结果可视化
Python用 PyMC3 贝叶斯推理案例研究:抛硬币和保险索赔发生结果可视化
|
7天前
|
Python
使用Seaborn库创建图形的使用案例
【4月更文挑战第29天】该代码段首先导入seaborn和matplotlib库,然后加载名为&quot;titanic&quot;的数据集。接着,它创建一个画布并设定子图大小。通过seaborn的FacetGrid以&quot;Attrition_Flag&quot;为列进行分组,映射数据到网格上,用histplot展示&quot;Customer_Age&quot;的直方图分布。同样,也使用boxplot方法生成&quot;Freq&quot;的箱线图。最后展示所有图形。
8 2
|
9天前
|
Python
python实现股票策略回测案例
此Python代码演示了一个简单的股票策略回测,使用yfinance库获取AAPL股票2020年至2022年的数据。它计算每日收益率,并基于前一日收益率决定买卖:正则买入,负则卖出。通过模拟交易更新现金和股票余额,最终计算总收益。请注意,此示例未涵盖交易费用、滑点、风险管理等实际交易因素。
18 0
|
9天前
|
Python
python实现股票均线策略案例
此Python代码示例展示了如何运用均线策略进行股票交易模拟。它下载AAPL的股票历史数据,计算每日收益率,设置短期和长期移动平均线。当短期均线超过长期均线时,模拟买入;反之则卖出。代码遍历每一天,更新现金和股票余额,并最终计算总收益。请注意,实际交易需考虑更多因素如交易费用和风险管理。
21 2
|
9天前
|
Serverless Python
python实现布林线策略案例
此Python代码示例展示了如何运用布林线策略进行股票交易模拟。首先,它下载AAPL股票的历史数据,计算每日收益率,并计算布林线(中位数、上轨和下轨)。接着,定义了一个交易策略,当股价超过布林线上轨时买入,低于下轨时卖出。通过循环模拟交易日并更新资产,最后计算总收益。请注意,实际交易应考虑更多因素如交易费用和风险管理。
21 1
|
13天前
|
人工智能 Python
【AI大模型应用开发】【LangChain系列】实战案例1:用LangChain写Python代码并执行来生成答案
【AI大模型应用开发】【LangChain系列】实战案例1:用LangChain写Python代码并执行来生成答案
18 0
|
18天前
|
机器学习/深度学习 人工智能 自然语言处理
总结几个GPT的超实用之处【附带Python案例】
总结几个GPT的超实用之处【附带Python案例】
|
19天前
|
数据可视化 Python
PYTHON贝叶斯推断计算:用BETA先验分布推断概率和可视化案例
PYTHON贝叶斯推断计算:用BETA先验分布推断概率和可视化案例