python编的俄罗斯方块游戏下载_python写的俄罗斯方块游戏

python写的俄罗斯方块游戏

功能包括:记录所花费时间;消去的总行数;总分;排行榜,最高记录查看等。

排行榜中包含一系列的统计功能,如单位时间消去的行数,单位时间得分等。

from Tkinter import *   from tkMessageBox import *   import random    import time    #俄罗斯方块界面的高度    HEIGHT = 18   #俄罗斯方块界面的宽度    WIDTH  = 10   ACTIVE = 1   PASSIVE = 0   TRUE  = 1   FALSE  = 0   root=Tk();root.title('Russia')    class App(Frame):      def __init__(self,master):        Frame.__init__(self)        master.bind('',self.Up)        master.bind('',self.Left)        master.bind('',self.Right)        master.bind('',self.Down)        #master.bind('',self.Space)        master.bind('',self.Space)        master.bind('',self.Play)        master.bind('',self.Pause)        self.backg="#%02x%02x%02x" % (120,150,30)        self.frontg="#%02x%02x%02x" % (40,120,150)        self.nextg="#%02x%02x%02x" % (150,100,100)        self.flashg="#%02x%02x%02x" % (210,130,100)        self.LineDisplay=Label(master,text='Lines: ',bg='black',fg='red')        self.Line=Label(master,text='0',bg='black',fg='red')        self.ScoreDisplay=Label(master,text='Score: ',bg='black',fg='red')        self.Score=Label(master,text='0',bg='black',fg='red')        #Display time        self.SpendTimeDisplay=Label(master,text='Time: ',bg='black',fg='red')        self.SpendTime=Label(master,text='0.0',bg='black',fg='red')        self.LineDisplay.grid(row=HEIGHT-2,column=WIDTH,columnspan=2)        self.Line.grid(row=HEIGHT-2,column=WIDTH+2,columnspan=3)        self.ScoreDisplay.grid(row=HEIGHT-1,column=WIDTH,columnspan=2)        self.Score.grid(row=HEIGHT-1,column=WIDTH+2,columnspan=3)        #Display time        self.SpendTimeDisplay.grid(row=HEIGHT-4,column=WIDTH,columnspan=2)        self.SpendTime.grid(row=HEIGHT-4,column=WIDTH+2,columnspan=3)        self.TotalTime=0.0       self.TotalLine=0;self.TotalScore=0       #Game over        self.isgameover=FALSE        #Pause        self.isPause=FALSE        #Start        self.isStart=FALSE        self.NextList=[];self.NextRowList=[]        r=0;c=0       for k in range(4*4):          LN=Label(master,text='  ',bg=str(self.nextg),fg='white',relief=FLAT,bd=4)          LN.grid(row=r,column=WIDTH+c,sticky=N+E+S+W)          self.NextRowList.append(LN)          c=c+1         if c>=4:            r=r+1;c=0           self.NextList.append(self.NextRowList)            self.NextRowList=[]        self.BlockList=[];self.LabelList=[]        self.BlockRowList=[];self.LabelRowList=[]        row=0;col=0       for i in range(HEIGHT*WIDTH):          L=Label(master,text='  ',bg=str(self.backg),fg='white',relief=FLAT,bd=4)          L.grid(row=row,column=col,sticky=N+E+S+W)          L.row=row;L.col=col;L.isactive=PASSIVE          self.BlockRowList.append(0);self.LabelRowList.append(L)          col=col+1         if col>=WIDTH:            row=row+1;col=0           self.BlockList.append(self.BlockRowList)            self.LabelList.append(self.LabelRowList)            self.BlockRowList=[];self.LabelRowList=[]        #file        fw=open('text.txt','a')        fw.close()        hasHead=FALSE        f=open('text.txt','r')        if f.read(5)=='score':          hasHead=TRUE        f.close()        self.file=open('text.txt','r+a')        if hasHead==FALSE:          self.file.write('score  line  time  scorePtime  linePtime  scorePline  date/n')          self.file.flush()                   self.time=1000       self.OnTimer()      def __del__(self):        #self.file.close()        pass              def Pause(self,event):        self.isPause=1-self.isPause      def Up(self,event):        BL=self.BlockList;LL=self.LabelList        Moveable=TRUE        xtotal=0;ytotal=0;count=0       for i in range(HEIGHT):          for j in range(WIDTH):            if LL[i][j].isactive==ACTIVE:              xtotal=xtotal+i;ytotal=ytotal+j;count=count+1       SourceList=[];DestList=[]        for i in range(HEIGHT):          for j in range(WIDTH):            if LL[i][j].isactive==ACTIVE:              x0=(xtotal+ytotal)/count;y0=(ytotal-xtotal )/count              xr=(xtotal+ytotal)%count;yr=(ytotal-xtotal)%count              x=x0-j;y=y0+i              if xr>=count/2:x=x+1             if yr>=count/2:y=y+1             SourceList.append([i,j]);DestList.append([x,y])              if x<0 or x>=HEIGHT or y<0 or y>=WIDTH:Moveable=FALSE              if x>=0 and x=0 and y=0 and BL[i][j-1]==1 and LL[i][j-1].isactive==PASSIVE:Moveable=FALSE        if Moveable==TRUE:          for i in range(HEIGHT):            for j in range(WIDTH):              if j-1>=0 and LL[i][j].isactive==ACTIVE and BL[i][j-1]==0:                self.Fill(i,j-1);self.Empty(i,j)      def Right(self,event):        BL=self.BlockList;LL=self.LabelList        Moveable=TRUE        for i in range(HEIGHT):          for j in range(WIDTH):            if LL[i][j].isactive==ACTIVE and j+1>=WIDTH:Moveable=FALSE            if LL[i][j].isactive==ACTIVE and j+1=1000:self.time=900       if self.TotalScore>=2000:self.time=750       if self.TotalScore>=3000:self.time=600       if self.TotalScore>=4000:self.time=400       self.after(self.time,self.OnTimer)      def Down(self,event):        BL=self.BlockList;LL=self.LabelList        Moveable=TRUE        for i in range(HEIGHT):          for j in range(WIDTH):            if LL[i][j].isactive==ACTIVE and i+1>=HEIGHT:Moveable=FALSE            if LL[i][j].isactive==ACTIVE and i+1

   

文章来自codeog.net

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值