面向?qū)ο髮W(xué)習(xí)之pygame坦克大戰(zhàn)
經(jīng)過一天多的奮戰(zhàn),查閱文獻(xiàn),參考別人的代碼等等,完成了第一個(gè)面向?qū)ο蟮男№?xiàng)目,也深深體會到面向?qū)ο缶幊趟枷朐谟螒蚓幊讨兴缪莸慕巧?/p>
附上代碼,參考了別人的代碼,以及對他們代碼的完善,又加上了自己的一些東西,收獲頗深。
import pygame
import sys
import time
from pygame.locals import *
from random import randint
MOVE_SLEEP = 0.01
class MyTank:
width = 600
heights = 500
speed = 10
screen = 0
myshells = []
enemylist = []
enemyshells = []
grade = 0
life = 3
cnt = 0
def startgame(self):
pygame.init()
self.screen = pygame.display.set_mode((self.width,self.heights),0,32)
pygame.display.set_caption("bit tank")
self.tank = Tank(self.screen,275,450)
for i in range(6):
self.enemylist.append(EnmeyTank(self.screen))
while True:
key = pygame.key.get_pressed()
self.screen.fill((0,0,0))
if key[K_LEFT]:
self.tank.move('L')
elif key[K_RIGHT]:
self.tank.move('R')
elif key[K_UP]:
self.tank.move('U')
elif key[K_DOWN]:
self.tank.move('D')
self.get_event()
for shell in self.myshells:
if shell.move() == True:
self.myshells.remove(shell)
shell.display()
a = shell.hitTank()
#子彈碰撞
if a == True:
if self.life >0:
self.myshells.remove(shell)
self.grade += 1
#mytank碰撞
if self.tank.live == True:
if self.tank.hitTank():
self.life -= 1
if self.life <=0:
self.tank.live =False
else:self.tank = Tank(self.screen,275,450)
#mytanke 碰撞子彈
if self.tank.live == True:
if self.tank.hitShell():
self.life -= 1
if self.life <=0:
self.tank.live = False
else:self.tank=Tank(self.screen,275,450)
#敵方子彈擊中我方坦克
# 游戲結(jié)束
if self.life <=0:
self.gotGamePrint()
for enemy in self.enemylist:
enemy.move()
print('move')
enemy.display()
# 添加敵方子彈
self.cnt += 1
if self.cnt % 100 ==0:
for enemy in self.enemylist:
self.enemyshells.append(enemy.fire())
#判斷敵方子彈碰撞
for enemyshell in self.enemyshells:
f = enemyshell.move()
enemyshell.display()
if f:
self.enemyshells.remove(enemyshell)
if len(self.enemylist)<6:
self.enemylist.append(EnmeyTank(self.screen))
self.screen.blit(self.getGrade(),(5,5))
self.tank.display()
pygame.display.update()
time.sleep(0.02)
def get_event(self):
for event in pygame.event.get():
if event.type == KEYDOWN:
if event.key == K_SPACE:
self.myshells.append(self.tank.fire())
if event.key == K_ESCAPE:
pass
def getGrade(self):
text = pygame.font.Font('./font/msyhbd.ttc',20).render("分?jǐn)?shù):{} 生命:{}".format(self.grade,self.life),True,(0,255,0))
return text
def gotGamePrint(self):
text = pygame.font.Font('./font/msyh.ttc',70).render('game over!',True,(0,255,0))
self.screen.blit(text,(100,200))
class Shell:
width = 48
height = 48
live = True
speed = 3
def __init__(self,screen,tank):
self.screen = screen
self.image = pygame.image.load('./images/3.png')
self.direction = tank.direction
self.rect = self.image.get_rect()
self.rect.left = tank.rect.left + (tank.width-self.width)/2.0+18
# print(tank.rect.left,tank.width,self.width)
self.rect.top = tank.rect.top + (tank.height - self.height)/2.0
self.live = True
def move(self):
tag = self.isObstacle()
if self.live == True:
if self.direction == 'L' and self.direction not in tag:
self.rect.left -= self.speed
elif self.direction == 'R' and self.direction not in tag:
self.rect.left += self.speed
elif self.direction == 'U' and self.direction not in tag:
self.rect.top -= self.speed
elif self.direction == 'D' and self.direction not in tag:
self.rect.top += self.speed
else:
pass
if self.direction in tag:
return True
else:
return False
else:
pass
def display(self):
# print(self.rect.left,self.rect.top)
if self.live == True:
self.screen.blit(self.image,self.rect)
def isObstacle(self):
tag = []
if self.rect.left <=0:tag.append('L')
if self.rect.left + self.width >= MyTank.width:tag.append('R')
if self.rect.top <=0:tag.append('U')
if self.rect.top + self.height >=MyTank.heights:tag.append('D')
return tag
def hitTank(self):
hitList = pygame.sprite.spritecollide(self,MyTank.enemylist,False)
for e in hitList:
e.live = False
MyTank.enemylist.remove(e)
self.live = False
return True
return False
def hitMytank(self):
hitList = pygame.sprite.spritecollide(self,MyTank.tank,False)
for e in hitList:
e.live = False
MyTank.life -= 1
return True
class BaseTank:
width = 50
height = 50
direction = 'U'
live = True
time = 0
images = {}
def __init__(self,screen,left,top):
self.screen = screen
self.images['L'] = pygame.image.load("images/04.jpg")
self.images['R'] = pygame.image.load("images/02.jpg")
self.images['U'] = pygame.image.load("images/01.jpg")
self.images['D'] = pygame.image.load("images/03.jpg")
self.image = self.images[self.direction]
self.rect = self.image.get_rect()
self.rect.left = left
self.rect.top = top
self.live = True # 坦克是否被消滅
def isObstacle(self):
tag = []
if self.rect.left <= 0: tag.append('L')
if self.rect.left + self.width >= MyTank.width: tag.append('R')
if self.rect.top <= 0: tag.append('U')
if self.rect.top + self.height >= MyTank.heights: tag.append('D')
return tag
def display(self):
if self.live == True:
self.image = self.images[self.direction]
self.screen.blit(self.image, self.rect)
def fire(self):
m = Shell(self.screen,self)
return m
class Tank(BaseTank):
images = {}
def __init__(self,screen,left,top):
super().__init__(screen,275,450)
self.screen = screen
self.speed = 2
self.images['L'] = pygame.image.load('./images/4.jpg')
self.images['R'] = pygame.image.load('./images/2.jpg')
self.images['U'] = pygame.image.load('./images/1.jpg')
self.images['D'] = pygame.image.load('./images/3.jpg')
self.image = self.images[self.direction]
self.rect = self.image.get_rect()
self.rect.top = top
self.rect.left = left
def move(self, direction):
if self.live == True:
tag = self.isObstacle()
if direction == self.direction:
if self.direction == 'L' and self.direction not in tag:
self.rect.left -= self.speed
elif self.direction == 'R' and self.direction not in tag:
self.rect.left += self.speed
elif self.direction == 'U' and self.direction not in tag:
self.rect.top -= self.speed
elif self.direction == 'D' and self.direction not in tag:
self.rect.top += self.speed
else:
pass
else:
self.direction = direction
def hitTank(self):
hitList = pygame.sprite.spritecollide(self,MyTank.enemylist,False)
for e in hitList:
self.live = False
return True
return False
def hitShell(self):
hitlist = pygame.sprite.spritecollide(self, MyTank.enemyshells, False)
for e in hitlist:
self.live = False
return True
return False
class EnmeyTank(BaseTank):
speed = 1
def __init__(self,screen):
super().__init__(screen,randint(1,5)*100,0)
self.getdirection()
self.step = 0
def getdirection(self):
self.direction = ['L','R','U','D'][randint(0,3)]
def move(self):
if self.live == True:
if self.step == 0 or (self.direction in self.isObstacle()):
self.getdirection()
self.step = randint(0, 200)
else:
tag = self.isObstacle()
if self.direction == 'L' and self.direction not in tag:
self.rect.left -= self.speed
elif self.direction == 'R' and self.direction not in tag:
self.rect.left += self.speed
elif self.direction == 'U' and self.direction not in tag:
self.rect.top -= self.speed
elif self.direction == 'D' and self.direction not in tag:
self.rect.top += self.speed
else:
pass
self.step -= 1
if __name__ == '__main__':
main = MyTank()
main.startgame()
文件主要有10張圖片和2個(gè)字體文件,主坦克的四個(gè)形態(tài),敵方坦克的四個(gè)形態(tài),以及子彈等,10張圖片。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在Mac下使用python實(shí)現(xiàn)簡單的目錄樹展示方法
今天小編就為大家分享一篇在Mac下使用python實(shí)現(xiàn)簡單的目錄樹展示方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11
詳解vscode實(shí)現(xiàn)遠(yuǎn)程linux服務(wù)器上Python開發(fā)
這篇文章主要介紹了vscode實(shí)現(xiàn)遠(yuǎn)程linux服務(wù)器上Python開發(fā),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
keras實(shí)現(xiàn)theano和tensorflow訓(xùn)練的模型相互轉(zhuǎn)換
這篇文章主要介紹了keras實(shí)現(xiàn)theano和tensorflow訓(xùn)練的模型相互轉(zhuǎn)換,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
python 將日期戳(五位數(shù)時(shí)間)轉(zhuǎn)換為標(biāo)準(zhǔn)時(shí)間
這篇文章主要介紹了python 將日期戳(五位數(shù)時(shí)間)轉(zhuǎn)換為標(biāo)準(zhǔn)時(shí)間的實(shí)現(xiàn)方法,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-07-07
如何使用Python進(jìn)行數(shù)據(jù)分析之方差分析詳解
這篇文章主要給大家介紹了關(guān)于如何使用Python進(jìn)行數(shù)據(jù)分析之方差分析的相關(guān)資料,方差分析是一種常用的對數(shù)據(jù)進(jìn)行分析的方法,用于兩個(gè)及兩個(gè)以上樣本均數(shù)和方差差別的顯著性檢驗(yàn),需要的朋友可以參考下2024-03-03
pycharm 實(shí)現(xiàn)光標(biāo)快速移動(dòng)到括號外或行尾的操作
這篇文章主要介紹了pycharm 實(shí)現(xiàn)光標(biāo)快速移動(dòng)到括號外或行尾的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
Python自定義scrapy中間模塊避免重復(fù)采集的方法
這篇文章主要介紹了Python自定義scrapy中間模塊避免重復(fù)采集的方法,實(shí)例分析了Python實(shí)現(xiàn)采集的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04
Python使用type關(guān)鍵字創(chuàng)建類步驟詳解
在本文里我們給讀者們整理了關(guān)于Python如何使用type關(guān)鍵字創(chuàng)建類的相關(guān)知識點(diǎn),需要的朋友們參考學(xué)習(xí)下。2019-07-07
Python+SymPy實(shí)現(xiàn)秒解微積分詳解
SymPy是一個(gè)Python庫,專注于符號數(shù)學(xué),它的目標(biāo)是成為一個(gè)全功能的計(jì)算機(jī)代數(shù)系統(tǒng),同時(shí)保持代碼簡潔、易于理解和擴(kuò)展。本文將利用SymPy實(shí)現(xiàn)四行代碼秒解微積分,感興趣的可以學(xué)習(xí)一下2022-05-05
selenium+python自動(dòng)化測試之鼠標(biāo)和鍵盤事件
這篇文章主要介紹了selenium+python自動(dòng)化測試之鼠標(biāo)和鍵盤事件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01

