电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python編寫俄羅斯方塊

瀏覽:7日期:2022-08-02 13:36:10

本文實例為大家分享了python實現(xiàn)俄羅斯方塊的具體代碼,供大家參考,具體內(nèi)容如下

#coding=utf-8 from tkinter import *from random import *import threadingfrom tkinter.messagebox import showinfofrom tkinter.messagebox import askquestionimport threadingfrom time import sleep class BrickGame(object): #是否開始 start = True; #是否到達底部 isDown = True; isPause = False; #窗體 window = None; #frame frame1 = None; frame2 = None; #按鈕 btnStart = None; #繪圖類 canvas = None; canvas1 = None; #標題 title = 'BrickGame'; #寬和高 width = 450; height = 670; #行和列 rows = 20; cols = 10; #下降方塊的線程 downThread = None; #幾種方塊 brick = [ [ [ [0,1,1], [1,1,0], [0,0,0] ], [ [1,0,0], [1,1,0], [0,1,0] ], [ [0,1,1], [1,1,0], [0,0,0] ], [ [1,0,0], [1,1,0], [0,1,0] ] ], [ [ [1,1,1], [1,0,0], [0,0,0] ], [ [0,1,1], [0,0,1], [0,0,1] ], [ [0,0,0], [0,0,1], [1,1,1] ], [ [1,0,0], [1,0,0], [1,1,0] ] ], [ [ [1,1,1], [0,0,1], [0,0,0] ], [ [0,0,1], [0,0,1], [0,1,1] ], [ [0,0,0], [1,0,0], [1,1,1] ], [ [1,1,0], [1,0,0], [1,0,0] ] ], [ [ [0,0,0], [0,1,1], [0,1,1] ], [ [0,0,0], [0,1,1], [0,1,1] ], [ [0,0,0], [0,1,1], [0,1,1] ], [ [0,0,0], [0,1,1], [0,1,1] ] ], [ [ [1,1,1], [0,1,0], [0,0,0] ], [ [0,0,1], [0,1,1], [0,0,1] ], [ [0,0,0], [0,1,0], [1,1,1] ], [ [1,0,0], [1,1,0], [1,0,0] ] ], [ [ [0,1,0], [0,1,0], [0,1,0] ], [ [0,0,0], [1,1,1], [0,0,0] ], [ [0,1,0], [0,1,0], [0,1,0] ], [ [0,0,0], [1,1,1], [0,0,0] ] ], [ [ [1,1,0], [0,1,1], [0,0,0] ], [ [0,0,1], [0,1,1], [0,1,0] ], [ [0,0,0], [1,1,0], [0,1,1] ], [ [0,1,0], [1,1,0], [1,0,0] ] ] ]; #當前的方塊 curBrick = None; #當前方塊數(shù)組 arr = None; arr1 = None; #當前方塊形狀 shape = -1; #當前方塊的行和列(最左上角) curRow = -10; curCol = -10; #背景 back = list(); #格子 gridBack = list(); preBack = list(); #初始化 def init(self): for i in range(0,self.rows): self.back.insert(i,list()); self.gridBack.insert(i,list()); for i in range(0,self.rows): for j in range(0,self.cols): self.back[i].insert(j,0); self.gridBack[i].insert(j,self.canvas.create_rectangle(30*j,30*i,30*(j+1),30*(i+1),fill='black')); for i in range(0,3): self.preBack.insert(i,list()); for i in range(0,3): for j in range(0,3): self.preBack[i].insert(j,self.canvas1.create_rectangle(30*j,30*i,30*(j+1),30*(i+1),fill='black')); #繪制游戲的格子 def drawRect(self): for i in range(0,self.rows): for j in range(0,self.cols): if self.back[i][j]==1: self.canvas.itemconfig(self.gridBack[i][j],fill='blue',outline='white');elif self.back[i][j]==0: self.canvas.itemconfig(self.gridBack[i][j],fill='black',outline='white'); #繪制預覽方塊 for i in range(0,len(self.arr1)): for j in range(0,len(self.arr1[i])): if self.arr1[i][j]==0: self.canvas1.itemconfig(self.preBack[i][j],fill='black',outline='white'); elif self.arr1[i][j]==1: self.canvas1.itemconfig(self.preBack[i][j],fill='orange',outline='white'); #繪制當前正在運動的方塊 if self.curRow!=-10 and self.curCol!=-10: for i in range(0,len(self.arr)): for j in range(0,len(self.arr[i])): if self.arr[i][j]==1: self.canvas.itemconfig(self.gridBack[self.curRow+i][self.curCol+j],fill='blue',outline='white'); #判斷方塊是否已經(jīng)運動到達底部 if self.isDown: for i in range(0,3): for j in range(0,3): if self.arr[i][j]!=0:self.back[self.curRow+i][self.curCol+j] = self.arr[i][j]; #判斷整行消除 self.removeRow(); #判斷是否死了 self.isDead(); #獲得下一個方塊 self.getCurBrick(); #判斷是否有整行需要消除 def removeRow(self): count=0 for i in range(0,self.rows): tag1 = True; for j in range(0,self.cols): if self.back[i][j]==0: tag1 = False; break; if tag1==True: #從上向下挪動 count=count+1 for m in range(i-1,0,-1): for n in range(0,self.cols):self.back[m+1][n] = self.back[m][n]; scoreValue = eval(self.scoreLabel2[’text’]) scoreValue += 5*count*(count+3) self.scoreLabel2.config(text=str(scoreValue)) #獲得當前的方塊 def getCurBrick(self): self.curBrick = randint(0,len(self.brick)-1); self.shape = 0; #當前方塊數(shù)組 self.arr = self.brick[self.curBrick][self.shape]; self.arr1 = self.arr; self.curRow = 0; self.curCol = 1; #是否到底部為False self.isDown = False; #監(jiān)聽鍵盤輸入 def onKeyboardEvent(self,event): #未開始,不必監(jiān)聽鍵盤輸入 if self.start == False: return; if self.isPause == True: return; #記錄原來的值 tempCurCol = self.curCol; tempCurRow = self.curRow; tempShape = self.shape; tempArr = self.arr; direction = -1; if event.keycode==37: #左移 self.curCol-=1; direction = 1; elif event.keycode==38: #變化方塊的形狀 self.shape+=1; direction = 2; if self.shape>=4: self.shape=0; self.arr = self.brick[self.curBrick][self.shape]; elif event.keycode==39: direction = 3; #右移 self.curCol+=1; elif event.keycode==40: direction = 4; #下移 self.curRow+=1; if self.isEdge(direction)==False: self.curCol = tempCurCol; self.curRow = tempCurRow; self.shape = tempShape; self.arr = tempArr; self.drawRect(); return True; #判斷當前方塊是否到達邊界 def isEdge(self,direction): tag = True; #向左,判斷邊界 if direction==1: for i in range(0,3): for j in range(0,3): if self.arr[j][i]!=0 and (self.curCol+i<0 or self.back[self.curRow+j][self.curCol+i]!=0):tag = False; break; #向右,判斷邊界 elif direction==3: for i in range(0,3): for j in range(0,3): if self.arr[j][i]!=0 and (self.curCol+i>=self.cols or self.back[self.curRow+j][self.curCol+i]!=0):tag = False; break; #向下,判斷底部 elif direction==4: for i in range(0,3): for j in range(0,3): if self.arr[i][j]!=0 and (self.curRow+i>=self.rows or self.back[self.curRow+i][self.curCol+j]!=0):tag = False; self.isDown = True; break; #進行變形,判斷邊界 elif direction==2: if self.curCol<0: self.curCol=0; if self.curCol+2>=self.cols: self.curCol = self.cols-3; if self.curRow+2>=self.rows: self.curRow = self.curRow-3; return tag; #方塊向下移動 def brickDown(self): while True: if self.start==False: print('exit thread'); break; if self.isPause==False: tempRow = self.curRow; self.curRow+=1; if self.isEdge(4)==False: self.curRow = tempRow; self.drawRect(); #每一秒下降一格 sleep(1); #點擊開始 def clickStart(self): self.start = True; for i in range(0,self.rows): for j in range(0,self.cols): self.back[i][j] = 0; self.canvas.itemconfig(self.gridBack[i][j],fill='black',outline='white'); for i in range(0,len(self.arr)): for j in range(0,len(self.arr[i])): self.canvas1.itemconfig(self.preBack[i][j],fill='black',outline='white'); self.getCurBrick(); self.drawRect(); self.downThread = threading.Thread(target=self.brickDown,args=()); self.downThread.start(); def clickPause(self): self.isPause=not self.isPause print(self.isPause) if not self.isPause: self.btnPause['text']='暫停' else: self.btnPause['text']='恢復' def clickReStart(self): ackRestart =askquestion('重新開始','你確定要重新開始嗎?') if ackRestart == ’yes’: self.clickStart() else: return def clickQuit(self): ackQuit =askquestion('退出','你確定要退出嗎?') if ackQuit == ’yes’: self.window.destroy() exit() #判斷是否死了 def isDead(self): for j in range(0,len(self.back[0])): if self.back[0][j]!=0: showinfo('提示','你掛了,再來一盤吧!'); self.start = False; break; #運行 def __init__(self): self.window = Tk(); self.window.title(self.title); self.window.minsize(self.width,self.height); self.window.maxsize(self.width,self.height); self.frame1 = Frame(self.window,width=300,height=600,bg='black'); self.frame1.place(x=20,y=30); self.scoreLabel1 = Label(self.window,text='Score:',font=(30)) self.scoreLabel1.place(x=340,y=60) self.scoreLabel2 = Label(self.window,text='0',fg=’red’,font=(30)) self.scoreLabel2.place(x=410,y=60) self.frame2 = Frame(self.window,width=90,height=90,bg='black'); self.frame2.place(x=340,y=120); self.canvas = Canvas(self.frame1,width=300,height=600,bg='black'); self.canvas1 = Canvas(self.frame2,width=90,height=90,bg='black'); self.btnStart = Button(self.window,text='開始',command=self.clickStart); self.btnStart.place(x=340,y=400,width=80,height=25); self.btnPause = Button(self.window,text='暫停',command=self.clickPause); self.btnPause.place(x=340,y=450,width=80,height=25); self.btnReStart = Button(self.window,text='重新開始',command=self.clickReStart); self.btnReStart.place(x=340,y=500,width=80,height=25); self.btnQuit = Button(self.window,text='退出',command=self.clickQuit); self.btnQuit.place(x=340,y=550,width=80,height=25); self.init(); #獲得當前的方塊 self.getCurBrick(); #按照數(shù)組,繪制格子 self.drawRect(); self.canvas.pack(); self.canvas1.pack(); #監(jiān)聽鍵盤事件 self.window.bind('<KeyPress>',self.onKeyboardEvent); #啟動方塊下落線程 self.downThread = threading.Thread(target=self.brickDown,args=()); self.downThread.start(); self.window.mainloop(); self.start=False; pass; if __name__==’__main__’: brickGame = BrickGame();

更多俄羅斯方塊精彩文章請點擊專題:俄羅斯方塊游戲集合 進行學習。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 房屋质量检测-厂房抗震鉴定-玻璃幕墙检测-房屋安全鉴定机构 | 金环宇|金环宇电线|金环宇电缆|金环宇电线电缆|深圳市金环宇电线电缆有限公司|金环宇电缆集团 | 超声波气象站_防爆气象站_空气质量监测站_负氧离子检测仪-风途物联网 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛调查出轨取证公司_青岛婚外情取证-青岛探真调查事务所 | 压装机-卧式轴承轮轴数控伺服压装机厂家[铭泽机械] | 数字展示在线_数字展示行业门户网站 | 长江船运_国内海运_内贸船运_大件海运|运输_船舶运输价格_钢材船运_内河运输_风电甲板船_游艇运输_航运货代电话_上海交航船运 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 网站优化公司_北京网站优化_抖音短视频代运营_抖音关键词seo优化排名-通则达网络 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 | 深圳办公室装修,办公楼/写字楼装修设计,一级资质 - ADD写艺 | YT保温材料_YT无机保温砂浆_外墙保温材料_南阳银通节能建材高新技术开发有限公司 | 防爆电机_ybx3系列电机_河南省南洋防爆电机有限公司 | 12cr1mov无缝钢管切割-15crmog无缝钢管切割-40cr无缝钢管切割-42crmo无缝钢管切割-Q345B无缝钢管切割-45#无缝钢管切割 - 聊城宽达钢管有限公司 | 淬火设备-钎焊机-熔炼炉-中频炉-锻造炉-感应加热电源-退火机-热处理设备-优造节能 | 东莞韩创-专业绝缘骨架|马达塑胶零件|塑胶电机配件|塑封电机骨架厂家 | 哈尔滨发电机,黑龙江柴油发电机组-北方星光 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | 质检报告_CE认证_FCC认证_SRRC认证_PSE认证_第三方检测机构-深圳市环测威检测技术有限公司 | 首页_欧瑞传动官方网站--主营变频器、伺服系统、新能源、软起动器、PLC、HMI | 北京遮阳网-防尘盖土网-盖土草坪-迷彩网-防尘网生产厂家-京兴科技 | 全自动翻转振荡器-浸出式水平振荡器厂家-土壤干燥箱价格-常州普天仪器 | 湖南专升本-湖南省专升本报名-湖南统招专升本考试网 | 过跨车_过跨电瓶车_过跨转运车_横移电动平车_厂区转运车_无轨转运车 | 安全,主动,被动,柔性,山体滑坡,sns,钢丝绳,边坡,防护网,护栏网,围栏,栏杆,栅栏,厂家 - 护栏网防护网生产厂家 | ★店家乐|服装销售管理软件|服装店收银系统|内衣店鞋店进销存软件|连锁店管理软件|收银软件手机版|会员管理系统-手机版,云版,App | 苏州工作服定做-工作服定制-工作服厂家网站-尺品服饰科技(苏州)有限公司 | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | 专业音响设备_舞台音响设备_会议音响工程-首选深圳一禾科技 | 慈溪麦田广告公司,提供慈溪广告设计。 | 分轨 | 上传文件,即刻分离人声和伴奏 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 废旧物资回收公司_广州废旧设备回收_报废设备物资回收-益美工厂设备回收公司 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 生物颗粒燃烧机-生物质燃烧机-热风炉-生物颗粒蒸汽发生器-丽水市久凯能源设备有限公司 | CNC机加工-数控加工-精密零件加工-ISO认证厂家-鑫创盟 | 铝箔-铝板-花纹铝板-铝型材-铝棒管-上海百亚金属材料有限公司 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 |