python實(shí)現(xiàn)超級(jí)瑪麗游戲
python制作超級(jí)瑪麗游戲,供大家參考,具體內(nèi)容如下
這篇文章,我們優(yōu)先介紹超級(jí)瑪麗游戲中的多狀態(tài)跳躍,和行走地圖拖動(dòng)的原理,然后實(shí)現(xiàn)。并實(shí)現(xiàn)倒計(jì)時(shí)和金幣動(dòng)態(tài)效果



接下來用下面這四張圖,就可以完全懂得游戲中背景是怎么會(huì)移動(dòng)的。
圖1

圖2

圖3

圖4

由于代碼是我前幾年學(xué)習(xí)python的時(shí)候做的,代碼寫的很擠都整到一個(gè)源文件中,大家看的時(shí)候仔細(xì)。
然后上源代碼:
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame,os,wx
from random import randint
from sys import exit
from pygame.locals import *
pygame.init()
def main():
#獲取屏幕大小
app=wx.App()
WHFRAMES=wx.DisplaySize()
WIDTH=int(WHFRAMES[0]*0.7)
HEIGHT=int(WHFRAMES[1]*0.8)
Timers = 0 #游戲定時(shí)器
TimersSec = 0 #秒
tim_psd = 0
#獲取屏幕大小
screen=pygame.display.set_mode((WIDTH,HEIGHT),0,32)
caption=pygame.display.set_caption("超級(jí)馬里奧")
screen.fill([255,255,255])
mariofont = pygame.font.Font('fonts/poster.ttf',22)
mario_name = mariofont.render("MARIO",True,(84,65,190),None)
#Game_world = mariofont.render("WORLD",True,(84,65,190),None)
Game_moneyX = mariofont.render("X",True,(255,255,128),None)
Game_time = mariofont.render("TIME",True,(84,65,190),None)
money_ic5 = pygame.image.load('images/PTModelSprite_ID21675.png')
money_ic5 = pygame.transform.scale(money_ic5, (25, 25))
money_ic6 = pygame.image.load('images/PTModelSprite_ID21676.png')
money_ic6 = pygame.transform.scale(money_ic6, (10, 25))
money_ic7 = pygame.image.load('images/PTModelSprite_ID21677.png')
money_ic7 = pygame.transform.scale(money_ic7, (25, 25))
money_ic8 = pygame.image.load('images/PTModelSprite_ID21678.png')
money_ic8 = pygame.transform.scale(money_ic8, (25, 25))
money_timers = 0 #圖片輪播定時(shí)器
Game_world = pygame.image.load('images/PTModelSprite_ID2478.png')
background = pygame.image.load('images/PTModelSprite_ID35342.png').convert_alpha()
background = pygame.transform.scale(background, (WIDTH, HEIGHT))
Roads = pygame.image.load('images/PTModelSprite_ID3790.png').convert_alpha()
Roads2 = pygame.image.load('images/PTModelSprite_ID4224.png').convert_alpha()
hero = pygame.image.load('images/PTModelSprite_ID34297.png').convert_alpha()
x,y = 15,HEIGHT-200
inp_flag = -2 #(stop:-1 left drection ,-2 right drection) ,(walk:1 right drection ,2 left drection)
times,times2 = 0,0 #人物動(dòng)作定時(shí)器
move_values,jump_values,jump_values2,jump_values3 = 12,0,0,0 #一步移動(dòng)的距離 和 跳躍的值1,2
jump_adder,jump_max_point = 0,50 #跳躍累加器 用來累加按鍵的長短 然后判斷跳躍的高度,跳躍的初始值最高點(diǎn)
jump_flag = 0
bg_w_1,bg_w_2 = 0,WIDTH-2 #兩張壁紙 一前一后循環(huán)拖動(dòng)的變量
#播放背景
#播放背景
#游戲信息數(shù)據(jù)定義
score = 0
money = 0
world = 11
time = 400
Gdata = [score,money,world,time]
#游戲信息數(shù)據(jù)定義
#初始化函數(shù)
def game_initializaion(score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,move_values,jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,bg_w_2,tim_psd):#數(shù)據(jù)初始化
#游戲初始化數(shù)據(jù)
inp_flag = -2 #(stop:-1 left drection ,-2 right drection) ,(walk:1 right drection ,2 left drection)
x,y = 15,HEIGHT-200 #馬里奧坐標(biāo)
times,times2 = 0,0 #人物動(dòng)作定時(shí)器
move_values,jump_values,jump_values2,jump_values3 = 12,0,0,0 #一步移動(dòng)的距離 和 跳躍的值1,2
jump_adder,jump_max_point = 0,50 #跳躍累加器 用來累加按鍵的長短 然后判斷跳躍的高度,跳躍的初始值最高點(diǎn)
jump_flag = 0
tim_psd = 0
bg_w_1,bg_w_2 = 0,WIDTH-2 #兩張壁紙 一前一后循環(huán)拖動(dòng)的變量
Timers = 0 #游戲定時(shí)器
score = 0 #開始分?jǐn)?shù)
money = 0 #開始金錢
world = 11 #世界關(guān)卡第一關(guān)1-1 = 11
time = 400 #游戲總時(shí)間
TimersSec = 0 #游戲里的秒
Gdata = [score,money,world,time]
#游戲初始化數(shù)據(jù)
return score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,move_values,jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,bg_w_2,tim_psd
#初始化函數(shù)
score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,move_values,jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,bg_w_2,tim_psd = \
game_initializaion(score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,move_values,jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,bg_w_2,tim_psd)#數(shù)據(jù)初始化主調(diào)函數(shù)
clock = pygame.time.Clock()
pygame.key.set_repeat(55)
pygame.display.flip()
def WalkAction(times,times2,inp_flag,hero):
#walk action
if y < HEIGHT -200: #如果在空中 為跳躍圖片
if inp_flag == 1: #right
hero = pygame.image.load('images/PTModelSprite_ID34259.png').convert_alpha()
if inp_flag == 2: #left
hero = pygame.image.load('images/PTModelSprite_ID34259.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
else:
if inp_flag == 1: #right
times += 2
if times < 20:
hero = pygame.image.load('images/PTModelSprite_ID34256.png').convert_alpha()
elif times < 20:
hero = pygame.image.load('images/PTModelSprite_ID34257..png').convert_alpha()
elif times < 40:
hero = pygame.image.load('images/PTModelSprite_ID34258.png').convert_alpha()
elif times < 60:
hero = pygame.image.load('images/PTModelSprite_ID34259.png').convert_alpha()
elif times < 80:
hero = pygame.image.load('images/PTModelSprite_ID34260.png').convert_alpha()
elif times < 100:
hero = pygame.image.load('images/PTModelSprite_ID34261.png').convert_alpha()
elif times < 120:
hero = pygame.image.load('images/PTModelSprite_ID34297.png').convert_alpha()
elif times < 140:
times = 0
if inp_flag == 2: #left
times2 += 2
if times2 < 20:
hero = pygame.image.load('images/PTModelSprite_ID34256.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 20:
hero = pygame.image.load('images/PTModelSprite_ID34257..png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 40:
hero = pygame.image.load('images/PTModelSprite_ID34258.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 60:
hero = pygame.image.load('images/PTModelSprite_ID34259.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 80:
hero = pygame.image.load('images/PTModelSprite_ID34260.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 100:
hero = pygame.image.load('images/PTModelSprite_ID34261.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 120:
hero = pygame.image.load('images/PTModelSprite_ID34297.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
elif times2 < 140:
times2 = 0
elif inp_flag == -1:
hero = pygame.image.load('images/PTModelSprite_ID34297.png').convert_alpha()
hero = pygame.transform.flip(hero, True, False)
times2 = 0
elif inp_flag == -2:
hero = pygame.image.load('images/PTModelSprite_ID34297.png').convert_alpha()
times2 = 0
return times,times2,inp_flag,hero
def HeroHeightIs(): #判斷角色是否為地面y軸
if y >= HEIGHT-200:
return False
else: #這是在控制的狀況
return True
def Reset_max_point(jump_max_point): #在地面重設(shè)默認(rèn)跳躍的最高點(diǎn)(還原)
if y >= (HEIGHT-200):
jump_max_point = 50 #默認(rèn)最高點(diǎn)是 50
return jump_max_point
def jump_leftScreenBgnotMove(x):
if x<(WIDTH/4):
if jump_max_point == 50 :
if inp_flag == 1:
x+=(2.7)
if inp_flag == 2:
x-=(2.7)
elif jump_max_point == 100 :
if inp_flag == 1:
x+=(0.27)
if inp_flag == 2:
x-=(0.27)
return x
def Screen_MoneyIc(screen,money_ic5,money_ic6,money_ic7,money_ic8,money_timers) : #繪制第二項(xiàng) 金錢圖標(biāo)
money_timers += 1
if money_timers < 15 :
screen.blit(money_ic5,(WIDTH*0.24,25)) #繪制第二項(xiàng) 金錢圖標(biāo)1
elif money_timers < 40 :
screen.blit(money_ic6,(WIDTH*0.24+7.5,25)) #繪制第二項(xiàng) 金錢圖標(biāo)2
elif money_timers < 55 :
screen.blit(money_ic7,(WIDTH*0.24,25)) #繪制第二項(xiàng) 金錢圖標(biāo)3
elif money_timers < 80 :
screen.blit(money_ic8,(WIDTH*0.24,25)) #繪制第二項(xiàng) 金錢圖標(biāo)4
else:
money_timers = 0
return screen,money_ic5,money_ic6,money_ic7,money_ic8,money_timers
def Game_Timers(TimersSec,Gdata,time_passed,tim_psd) : #游戲定時(shí)器
tim_psd += time_passed
if tim_psd >= 1000 : #為1秒的時(shí)候
TimersSec += 1
tim_psd = 0
Gdata[3] = 400 - TimersSec #游戲所剩時(shí)間
return TimersSec,Gdata,time_passed,tim_psd
while True:
#事件檢測
for event in pygame.event.get():
if event.type == pygame.QUIT:
exit()
if event.type == KEYDOWN:
keys=pygame.key.get_pressed()
if keys[pygame.K_a]:
if event.key == K_w and inp_flag == 0:
if y <= HEIGHT-200: #看y坐標(biāo) 必須在起點(diǎn)
jump_flag = 3 #按了上 和 向前
if y >= HEIGHT-200:#如果角色在平地才走動(dòng) 后退 左
#if bg_w_1==0:
#x-=5
x-=(move_values+3.5)
inp_flag = 2
if keys[pygame.K_d]:
if event.key == K_w and inp_flag == 0:
if y <= HEIGHT-200: #看y坐標(biāo) 必須在起點(diǎn)
jump_flag = 2 #按了上 和 向前
if y >= HEIGHT-200:#如果角色在平地才走動(dòng) 前景 右
if x<(WIDTH/4): #角色還在屏幕左邊 可移動(dòng)
x+=(move_values+3.5)
inp_flag = 1
if keys[pygame.K_w]: #jump
jump_flag = 1 #僅僅是按了跳躍
jump_adder += 1 #跳躍累加器
if event.key == pygame.K_d and (jump_flag == 1):
if y == HEIGHT-200: #看y坐標(biāo) 必須在起點(diǎn)
jump_flag = 2 #按了上 和 向前
if event.key == pygame.K_a and (jump_flag == 1):
if y == HEIGHT-200: #看y坐標(biāo) 必須在起點(diǎn)
jump_flag = 3 #按了上 和 向后
if keys[pygame.K_p]: #重啟
score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,move_values,\
jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,bg_w_2,tim_psd = \
game_initializaion(score,money,world,time,Gdata,TimersSec,Timers,x,y,inp_flag,times,times2,\
move_values,jump_values,jump_values2,jump_values3,jump_adder,jump_max_point,jump_flag,bg_w_1,\
bg_w_2,tim_psd)
if event.type == KEYUP:
if keys[pygame.K_a]:
inp_flag = -1
if keys[pygame.K_d]:
inp_flag = -2
if keys[pygame.K_w]:
if jump_adder < 4 : #如果松開按鍵沒有達(dá)到j(luò)ump_adder跳躍累加器的值 (那么就他們置零)
jump_adder = 0
##在地面時(shí) 重設(shè)默認(rèn)跳躍的最高點(diǎn)(還原)
jump_max_point = Reset_max_point(jump_max_point)
#jump action 1
if jump_flag == 1: #只有跳躍
#讓其他方式跳躍值為 0
jump_values2 = 0
jump_values3 = 0
#------
#持續(xù)按鍵跳躍的結(jié)構(gòu)
if jump_adder >=4 :
jump_max_point = 100 #第二次跳躍最大值
jump_adder = 0
#------
jump_values+=1.25
if jump_values <= jump_max_point:
y -= 5
x = jump_leftScreenBgnotMove(x)
if jump_max_point == 100:#跳躍的高度不同 y坐標(biāo)的速度也要慢點(diǎn)
y += 1.5
x = jump_leftScreenBgnotMove(x)
elif jump_values <= jump_max_point+8:
pass
elif jump_values <=jump_max_point*2+8:
if HeroHeightIs(): #如果角色在控制 就繼續(xù)加y軸的值 1
y += 5
x = jump_leftScreenBgnotMove(x)
if jump_max_point == 100:#跳躍的高度不同 y坐標(biāo)的速度也要慢點(diǎn)
y -= 1.5
x = jump_leftScreenBgnotMove(x)
else:
y = HEIGHT-200
jump_flag = 0
jump_values = 0
#wall detection
if x<=0:
x=0
if x+hero.get_width()>WIDTH:
x=WIDTH-hero.get_width()
#角色的動(dòng)作 函數(shù)
times,times2,inp_flag,hero = WalkAction(times,times2,inp_flag,hero)
#1 .bg move---blit
screen.blit(background,(bg_w_2,0))
screen.blit(background,(bg_w_1,0))
#繪制信息
screen.blit(mario_name,(WIDTH*0.03,3))#繪制第一項(xiàng) 名字
screen,money_ic5,money_ic6,money_ic7,money_ic8,money_timers = \
Screen_MoneyIc(screen,money_ic5,money_ic6,money_ic7,money_ic8,money_timers) #繪制第二項(xiàng) 金錢圖標(biāo)
screen.blit(Game_moneyX,(WIDTH*0.28,24))#繪制第二項(xiàng) x
screen.blit(Game_world,(WIDTH*0.5-Game_world.get_width()/2,3))#繪制第三項(xiàng) 世界地圖
screen.blit(Game_time,(WIDTH*0.84,3))#繪制第四項(xiàng) 游戲時(shí)間
for DATAi in range(4):
Game_data = mariofont.render("%s"% Gdata[DATAi],True,(255,255,128),None) #綜合繪制: 分?jǐn)?shù) 金幣 關(guān)卡 游戲時(shí)間
if DATAi != 2:
screen.blit(Game_data,(WIDTH*(0.03+DATAi*0.27),24))
elif DATAi == 2:
Game_data = mariofont.render("%s-%s"% (Gdata[DATAi]/10,Gdata[DATAi]%10),True,(255,255,128),None) #綜合繪制: 分?jǐn)?shù) 金幣 關(guān)卡 游戲時(shí)間
screen.blit(Game_data,(WIDTH*0.5-Game_data.get_width()/2,15))
#繪制信息
#2 .bg move--panel
#if inp_flag == 2: #往左走 壁紙向右拖動(dòng)
# bg_w_1+=move_values/4
# bg_w_2+=move_values/4
if inp_flag == 1 and x>=(WIDTH/4):#往右走 壁紙向左拖動(dòng)
bg_w_1-=(move_values/4-0.5)
bg_w_2-=(move_values/4-0.5)
if bg_w_1>=0:
bg_w_1,bg_w_2 = 0,WIDTH-2
if bg_w_1<-WIDTH:
bg_w_1,bg_w_2 = 0,WIDTH-2
screen.blit(hero,(x,y))
pygame.time.delay(2) #毫秒
time_passed = clock.tick()
TimersSec,Gdata,time_passed,tim_psd = Game_Timers(TimersSec,Gdata,time_passed,tim_psd) #游戲定時(shí)
pygame.display.update()
if __name__ == '__main__':
main()
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何將python的數(shù)據(jù)存儲(chǔ)到mysql數(shù)據(jù)庫中
在很多數(shù)據(jù)處理項(xiàng)目中,將數(shù)據(jù)存儲(chǔ)到數(shù)據(jù)庫中是非常常見的操作,下面這篇文章主要給大家介紹了關(guān)于如何將python的數(shù)據(jù)存儲(chǔ)到mysql數(shù)據(jù)庫中的相關(guān)資料,需要的朋友可以參考下2023-12-12
python 實(shí)現(xiàn)docx與doc文件的互相轉(zhuǎn)換
這篇文章主要介紹了python 實(shí)現(xiàn)docx與doc文件的互相轉(zhuǎn)換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03
python解決方案:WindowsError: [Error 2]
使用Python的rename()函數(shù)重命名文件時(shí)出現(xiàn)問題,提示 WindowsError: [Error 2] 錯(cuò)誤,需要的朋友可以參考下2016-08-08
Python采用Django開發(fā)自己的博客系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Python采用Django開發(fā)自己的博客系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08
python基于Kivy寫一個(gè)圖形桌面時(shí)鐘程序
這篇文章主要介紹了python如何基于Kivy 寫一個(gè)桌面時(shí)鐘程序,幫助大家更好的利用python開發(fā)圖形程序,感興趣的朋友可以了解下2021-01-01
python except異常處理之后不退出,解決異常繼續(xù)執(zhí)行的實(shí)現(xiàn)
這篇文章主要介紹了python except異常處理之后不退出,解決異常繼續(xù)執(zhí)行的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04
PyCharm遠(yuǎn)程調(diào)試代碼配置以及運(yùn)行參數(shù)設(shè)置方式
這篇文章主要介紹了PyCharm遠(yuǎn)程調(diào)試代碼配置以及運(yùn)行參數(shù)設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
OpenCV特征匹配和單應(yīng)性矩陣查找對(duì)象詳解
這篇文章主要為大家介紹了OpenCV特征匹配和單應(yīng)性矩陣查找對(duì)象詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04

