python 打飞机项目 ( 基类封装 )
项目代码 | plane
# -*- coding:utf-8 -*-
import pygame, time
from Plane import Plane
from HeroPlane import HeroPlane
from Screen import Screen
from pygame.locals import * def key_control(plane_temp):
# 获取事件,比如按键等
for event in pygame.event.get(): # 判断是否是点击了退出按钮
if event.type == QUIT:
print("exit")
exit()
# 判断是否是按下了键
elif event.type == KEYDOWN:
# 检测按键是否是a或者left
if event.key == K_a or event.key == K_LEFT:
print('left')
plane_temp.move_left()
# 检测按键是否是d或者right
elif event.key == K_d or event.key == K_RIGHT:
print('right')
plane_temp.move_right()
# 检测按键是否是空格键
elif event.key == K_SPACE:
print('space')
plane_temp.fire() def main(): screen = pygame.display.set_mode((480, 852), 0, 32) # 创建窗口对象
screen_temp = Screen(screen) # 创建一个飞机对象
plane = Plane(screen) # 创建敌机对象
enemyPlane = HeroPlane(screen) while True:
screen_temp.display() # 显示窗口
plane.display(plane.bullet_list) # 显示飞机
enemyPlane.display(enemyPlane.bullet_list) # 敌机显示
enemyPlane.move() # 敌机移动
enemyPlane.fire() # 敌机开火
key_control(plane) # 键盘事件监听
pygame.display.update() # 更新窗口
time.sleep(0.01) # 延时0.01秒,防止程序内存溢出 if __name__ == '__main__':
main()
Base.py
基类
# -*- coding:utf-8 -*-
import pygame class Base(object):
# 背景图片
image = None def __init__(self, screen_temp, x, y, image_path):
self.x = x
self.y = y
self.screen = screen_temp
self.image_load(image_path) # 飞机赋值图片对象
def image_load(self, image_path):
self.image = pygame.image.load(image_path)
BasePlane.py
飞机基类
# -*- coding:utf-8 -*-
from Base import Base class BasePlane(Base):
def __init__(self, screen_temp, x, y, image_path):
Base.__init__(self, screen_temp, x, y, image_path) # 显示飞机
def display(self, bullet_list): self.screen.blit(self.image, (self.x, self.y)) # 显示飞机 for bullet in bullet_list: # 循环取出子弹对象
# 判断子弹是否越界
if bullet.judge():
bullet_list.remove(bullet) # 如果子弹越界就删除子弹 bullet.display() # 显示子弹
bullet.move() # 子弹移动步长
Plane.py
飞机对象
# -*- coding:utf-8 -*-
from Bullet import Bullet
from BasePlane import BasePlane class Plane(BasePlane): # 储存子弹对象
bullet_list = [] def __init__(self, screen_temp):
BasePlane.__init__(self, screen_temp, 210, 700, "./resource/hero1.png") # 飞机向左移动偏移量
def move_left(self):
self.x -= 10 # 飞机向右移动偏移量
def move_right(self):
self.x += 10 # 将飞机创建的子弹对象存储进 bullet_list 列表中
def fire(self):
self.bullet_list.append(Bullet(self.screen, self.x, self.y))
print(self.bullet_list)
HeroPlane.py
敌机对象
# -*- coding:utf-8 -*-
import random
from BasePlane import BasePlane
from EnemyBullet import EnemyBullet class HeroPlane(BasePlane):
# 定义一个类属性用来保存
direction = 'right' # 储存子弹对象
bullet_list = [] def __init__(self, screen_temp):
BasePlane.__init__(self, screen_temp, 0, 0, "./resource/enemy-1.gif") # 敌机移动轨迹
def move(self):
# 敌机创建的子弹默认向右移动
if self.direction == 'right':
self.x += 5 # 每次向右移动增加 5px 的步长
elif self.direction == 'left': # 向左移动
self.x -= 5 # 每次向左移动减少 5px 的步长 # 当敌机向右移动到了边界就向左移动
if self.x > 480 - 50: # 480 是界面总宽度; 50 是飞机宽度. 所以敌机移动的距离应该是界面宽度-敌机宽度 ( 移动距离 = 界面宽度 - 敌机宽度 )
self.direction = 'left'
elif self.x <= 0: # 当敌机移动到了最左边就会继续向右移动
self.direction = 'right' # 开火
def fire(self):
random_temp = random.randint(1, 100) # 随机生成 1 - 100的随机数
if (random_temp == 20) or (random_temp == 78): # 随机数概率
self.bullet_list.append(EnemyBullet(self.screen, self.x, self.y)) # 创建敌机子弹对象
BaseBullet.py
子弹基类
# -*- coding:utf-8 -*-
from Base import Base class BaseBullet(Base):
def __init__(self, screen_temp, x, y, image_path):
Base.__init__(self, screen_temp, x, y, image_path) # 子弹背景
def display(self):
self.screen.blit(self.image, (self.x, self.y))
Bullet.py
子弹对象
# -*- coding:utf-8 -*-
from BaseBullet import BaseBullet class Bullet(BaseBullet):
def __init__(self, screen_temp, x, y):
BaseBullet.__init__(self, screen_temp, x + 40, y - 20, "./resource/bullet.png") # 子弹步长
def move(self):
self.y -= 10 # 判断子弹y轴是否已经越界
def judge(self):
if self.y < 0:
return True
else:
return False
EnemyBullet.py
敌机子弹对象
# -*- coding:utf-8 -*-
from BaseBullet import BaseBullet class EnemyBullet(BaseBullet):
def __init__(self, screen_temp, x, y):
BaseBullet.__init__(self, screen_temp, x + 30, y + 30, "./resource/bullet-1.gif") # 子弹移动步长
def move(self):
self.y += 20 # 判断子弹y轴是否已经越界
def judge(self):
if self.y > 890: # 890 界面总高度
return True
else:
return False
Screen.py
窗口对象
# -*- coding:utf-8 -*-
from Base import Base class Screen(Base):
def __init__(self, screen_temp):
Base.__init__(self, screen_temp, 0, 0, "./resource/background.png") def display(self):
self.screen.blit(self.image, (self.x, self.y))
python 打飞机项目 ( 基类封装 )的更多相关文章
- 四、spring集成ibatis进行项目中dao层基类封装
Apache iBatis(现已迁至Google Code下发展,更名为MyBatis)是当前IT项目中使用很广泛的一个半自动ORM框架,区别于Hibernate之类的全自动框架,iBatis对数据库 ...
- salesforce 零基础学习(四十八)自定义列表分页之Pagination基类封装 ※※※
我们知道,salesforce中系统标准列表页面提供了相应的分页功能,如果要使用其分页功能,可以访问http://www.cnblogs.com/zero-zyq/p/5343287.html查看相关 ...
- thinkphp5底层基类封装、内部类函数
记录下thinkphp5自定义底层基类.内部类函数使用笔记 大部分笔记来自tp手册. 底层常用代码的封装 在控制器中基类的起着至关重要的作用,整个项目的代码安全,复杂程度,易读性都要看你项目的基类架构 ...
- Android 开发技巧 - Android 6.0 以上权限大坑和权限检查基类封装
简单介绍 关于运行时权限的说法,早在Google发布android 6.0的时候,大家也听得蛮多的.从用户的角度来讲,用户是受益方,更好的保护用户的意思,而对于开发者来说,无疑增加了工作量. 对于6. ...
- Python高级主题:Python ABC(抽象基类)
#抽象类实例 作用统一规范接口,降低使用复杂度.import abcclass Animal(metaclass = abc.ABCMeta): ##只能被继承,不能实例化,实例化会报错 @abc.a ...
- Python中的抽象基类
1.说在前头 "抽象基类"这个词可能听着比较"深奥",其实"基类"就是"父类","抽象"就是&quo ...
- mongodb基类封装实例
mongodb的基类 1 <?php 2 3 namespace BI\Service\MongoDB; 4 5 use MongoDB\Driver\BulkWrite; 6 use Mong ...
- Python一个简单的数据库类封装
#encoding:utf-8 #name:mod_db.py '''使用方法:1.在主程序中先实例化DB Mysql数据库操作类. 2.使用方法:db=database() db.fet ...
- python 打飞机项目 (实战一)
第一步定义 main 函数: # -*- coding=utf-8 -*- import pygame,time from Plane import Plane from pygame.locals ...
随机推荐
- 【并发编程】Object的wait、notify和notifyAll方法
本博客系列是学习并发编程过程中的记录总结.由于文章比较多,写的时间也比较散,所以我整理了个目录贴(传送门),方便查阅. 并发编程系列博客传送门 方法简介 wait方法 wait方法是Object类中的 ...
- 常用tab选项卡代码
<div class="box"> <ul> <li class="one">课程介绍</li> <li& ...
- 可能是全网最简单的 OpenStack 安装方式
OpenStack 因为架构复杂,配置较多,一向以安装部署过程困难闻名.虽然 OpenStack 社区前后涌现出了很多的自动化部署工具,但是对于普通用户,特别是新人来说,上手仍然有难度. 使用本文介绍 ...
- Mysql的查询语句的使用
1. 简单查询 查询所有字段: SELECT * FROM 表名 查询特定字段: SELECT 字段列表 FROM 表名 2. 查询显示行号 - 在字段列表中加入(@rownum := @rownum ...
- linux实用小命令--查看文本内容
一.cat命令 $ cat [参数]filename 这还有一些可以和cat命令一起用的参数,可能对你有所帮助. 1.-n 参数会所有的行加上行号: $ cat -n test1 2.这个功能在检查脚 ...
- set容器
set容器简介: 1) set是一个集合容器,其中所包含的元素是唯一的,集合中的元素按一定的顺序排列.元素插入过程是按排序规则插入,所以不能指定插入位置. 2) set采用红黑树变体的数据结构实现,红 ...
- Reachability的使用
刚到一家新公司 做新项目 关于网络状态的监听和同事产生了不一样的看法 原来我的网络监听都是自己写的 后来发现自己不是一般的傻 有一个叫做Reachability的东西 很简单 很实用 很暴力 下面就是 ...
- JVM内运行时数据区
JVM的基本区域: 类加载子系统 运行时数据区(内存区域) 执行引擎 运行时数据区域 方法区(Method Area) 类的所有字和方法字节码,以及一些特殊方法如构造函数,接口代码也在这里定义.简单来 ...
- [TimLinux] JavaScript input框的onfocus/onblur/oninput/onchange事件介绍
1. onfocus事件 input框获取到焦点时,触发了该事件,比如获取到焦点时,修改input框的背景色.这个功能其实可以使用css的伪类:focus来定义. 2. onblur事件 这个与onf ...
- CodeForces1006F-Xor-Paths
F. Xor-Paths time limit per test 3 seconds memory limit per test 256 megabytes input standard input ...