




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第基于Python实现经典植物大战僵尸游戏目录游戏截图动态演示源码分享state/tool.pystate/constants.pystate/main.py主执行文件main.py
游戏截图
动态演示
源码分享
state/tool.py
importos
importjson
fromabcimportabstractmethod
importpygameaspg
from.importconstantsasc
classState():
def__init__(self):
self.start_time=0.0
self.current_time=0.0
self.done=False
self.next=None
self.persist={}
@abstractmethod
defstartup(self,current_time,persist):
'''abstractmethod'''
defcleanup(self):
self.done=False
returnself.persist
@abstractmethod
defupdate(self,surface,keys,current_time):
'''abstractmethod'''
classControl():
def__init__(self):
self.screen=pg.display.get_surface()
self.done=False
self.clock=pg.time.Clock()
self.fps=60
self.keys=pg.key.get_pressed()
self.mouse_pos=None
self.mouse_click=[False,False]#value:[leftmouseclick,rightmouseclick]
self.current_time=0.0
self.state_dict={}
self.state_name=None
self.state=None
self.game_info={c.CURRENT_TIME:0.0,
c.LEVEL_NUM:c.START_LEVEL_NUM}
defsetup_states(self,state_dict,start_state):
self.state_dict=state_dict
self.state_name=start_state
self.state=self.state_dict[self.state_name]
self.state.startup(self.current_time,self.game_info)
defupdate(self):
self.current_time=pg.time.get_ticks()
ifself.state.done:
self.flip_state()
self.state.update(self.screen,self.current_time,self.mouse_pos,self.mouse_click)
self.mouse_pos=None
self.mouse_click[0]=False
self.mouse_click[1]=False
defflip_state(self):
previous,self.state_name=self.state_name,self.state.next
persist=self.state.cleanup()
self.state=self.state_dict[self.state_name]
self.state.startup(self.current_time,persist)
defevent_loop(self):
foreventinpg.event.get():
ifevent.type==pg.QUIT:
self.done=True
elifevent.type==pg.KEYDOWN:
self.keys=pg.key.get_pressed()
elifevent.type==pg.KEYUP:
self.keys=pg.key.get_pressed()
elifevent.type==pg.MOUSEBUTTONDOWN:
self.mouse_pos=pg.mouse.get_pos()
self.mouse_click[0],_,self.mouse_click[1]=pg.mouse.get_pressed()
print('pos:',self.mouse_pos,'mouse:',self.mouse_click)
defmain(self):
whilenotself.done:
self.event_loop()
self.update()
pg.display.update()
self.clock.tick(self.fps)
print('gameover')
defget_image(sheet,x,y,width,height,colorkey=c.BLACK,scale=1):
image=pg.Surface([width,height])
rect=image.get_rect()
image.blit(sheet,(0,0),(x,y,width,height))
image.set_colorkey(colorkey)
image=pg.transform.scale(image,
(int(rect.width*scale),
int(rect.height*scale)))
returnimage
defload_image_frames(directory,image_name,colorkey,accept):
frame_list=[]
tmp={}
#image_nameis"Peashooter",picnameis'Peashooter_1',gettheindex1
index_start=len(image_name)+1
frame_num=0;
forpicinos.listdir(directory):
name,ext=os.path.splitext(pic)
ifext.lower()inaccept:
index=int(name[index_start:])
img=pg.image.load(os.path.join(directory,pic))
ifimg.get_alpha():
img=img.convert_alpha()
else:
img=img.convert()
img.set_colorkey(colorkey)
tmp[index]=img
frame_num+=1
foriinrange(frame_num):
frame_list.append(tmp[i])
returnframe_list
defload_all_gfx(directory,colorkey=c.WHITE,accept=('.png','.jpg','.bmp','.gif')):
graphics={}
forname1inos.listdir(directory):
#subfoldersunderthefolderresources\graphics
dir1=os.path.join(directory,name1)
ifos.path.isdir(dir1):
forname2inos.listdir(dir1):
dir2=os.path.join(dir1,name2)
ifos.path.isdir(dir2):
#e.g.subfoldersunderthefolderresources\graphics\Zombies
forname3inos.listdir(dir2):
dir3=os.path.join(dir2,name3)
#e.g.subfoldersorpicsunderthefolderresources\graphics\Zombies\ConeheadZombie
ifos.path.isdir(dir3):
#e.g.it'sthefolderresources\graphics\Zombies\ConeheadZombie\ConeheadZombieAttack
image_name,_=os.path.splitext(name3)
graphics[image_name]=load_image_frames(dir3,image_name,colorkey,accept)
else:
#e.g.picsunderthefolderresources\graphics\Plants\Peashooter
image_name,_=os.path.splitext(name2)
graphics[image_name]=load_image_frames(dir2,image_name,colorkey,accept)
break
else:
#e.g.picsunderthefolderresources\graphics\Screen
name,ext=os.path.splitext(name2)
ifext.lower()inaccept:
img=pg.image.load(dir2)
ifimg.get_alpha():
img=img.convert_alpha()
else:
img=img.convert()
img.set_colorkey(colorkey)
graphics[name]=img
returngraphics
defloadZombieImageRect():
file_path=os.path.join('source','data','entity','zombie.json')
f=open(file_path)
data=json.load(f)
f.close()
returndata[c.ZOMBIE_IMAGE_RECT]
defloadPlantImageRect():
file_path=os.path.join('source','data','entity','plant.json')
f=open(file_path)
data=json.load(f)
f.close()
returndata[c.PLANT_IMAGE_RECT]
pg.init()
pg.display.set_caption(c.ORIGINAL_CAPTION)
SCREEN=pg.display.set_mode(c.SCREEN_SIZE)
GFX=load_all_gfx(os.path.join("resources","graphics"))
ZOMBIE_RECT=loadZombi
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025江苏连云港市海州湾发展集团有限公司及子公司招聘20人笔试参考题库附带答案详解
- 2025广东省广晟控股集团校园招聘2025人笔试参考题库附带答案详解
- 2025年福建省晋江市市政工程建设有限公司权属公司招聘6人笔试参考题库附带答案详解
- 2025年河北石家庄印钞有限公司招聘13人笔试参考题库附带答案详解
- 2025年国网河北省电力有限公司高校毕业生招聘约215人(第二批)笔试参考题库附带答案详解
- 2025安徽芜湖凤鸣控股集团及其子公司选调10人笔试参考题库附带答案详解
- 划款转委托协议
- 品质合同协议书
- 工程担保合同协议书模板
- 企业合同变更协议书
- 远盛水工重力坝辅助设计系统用户使用手册
- 矿井瓦斯抽采
- 立法学完整版教学课件全套ppt教程
- 五年级下册科学说课课件 -1.2 沉浮与什么因素有关 |教科版 (共28张PPT)
- 通用城实景三维数据生产项目技术设计书
- 毕业设计(论文)-N402—1300型农用拖拉机履带底盘的设计
- 多重耐药菌感染的预防与控制 课件
- 《出口报关单模板》word版
- 设计公司钉钉考勤管理办法
- 边坡护坡检验批表格模板
- 工会会计制度——会计科目和会计报表(全)
评论
0/150
提交评论