python实现俄罗斯方块游戏(改进版)
作者:rongyongfeikai2 发布时间:2022-03-10 07:55:48
标签:python,俄罗斯方块
本文为大家分享了python实现俄罗斯方块游戏,继上一篇的改进版,供大家参考,具体内容如下
1.加了方块预览部分
2.加了开始按钮
在公司实习抽空写的,呵呵。觉得Python还不错,以前觉得像个玩具语言。希望能够用它做更多大事吧!!!加油。
截图如下:
代码如下:
#coding=utf-8
from Tkinter import *;
from random import *;
import thread;
from tkMessageBox import showinfo;
import threading;
from time import sleep;
class BrickGame(object):
#是否开始
start = True;
#是否到达底部
isDown = True;
#窗体
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 = [
[
[
[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,1,0]
],
[
[0,0,1],
[1,1,1],
[0,0,1]
],
[
[0,1,0],
[0,1,0],
[1,1,1]
],
[
[1,0,0],
[1,1,1],
[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]
]
]
];
#当前的方块
curBrick = None;
#当前方块数组
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");
#判断方块是否已经运动到达底部
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):
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:
#从上向下挪动
for m in xrange(i-1,0,-1):
for n in range(0,self.cols):
self.back[m+1][n] = self.back[m][n];
#获得当前的方块
def getCurBrick(self):
self.curBrick = randint(0,len(self.brick)-1);
self.shape = 0;
#当前方块数组
self.arr = self.brick[self.curBrick][self.shape];
self.arr1 = self.arr;
self.curRow = 0;
self.curCol = 1;
#是否到底部为False
self.isDown = False;
#监听键盘输入
def onKeyboardEvent(self,event):
#未开始,不必监听键盘输入
if self.start == False:
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;
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 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.frame2 = Frame(self.window,width=90,height=90,bg="black");
self.frame2.place(x=340,y=60);
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.init();
#获得当前的方块
self.getCurBrick();
#按照数组,绘制格子
self.drawRect();
self.canvas.pack();
self.canvas1.pack();
#监听键盘事件
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();
更多俄罗斯方块精彩文章请点击专题:俄罗斯方块游戏集合 进行学习。
来源:https://blog.csdn.net/rongyongfeikai2/article/details/8893646
0
投稿
猜你喜欢
- 一、引 言 在速度上,静态页面要比动态页面的比方php快很多,这是毫无疑问的,但是由于静态页面的灵活性较差,如果不借助数据库或其他的设备保存
- 在一些网站上,特别是小说网站经常我们会看到这个功能,就是自动滚动屏幕的功能,方便了大家阅读文章,增强了用户体验。下面的javascript代
- C++里函数可以设置缺省参数,Java不可以,只能通过重载的方式来实现,python里也可以设置默认参数,最大的好处就是降低函数难度,函数的
- 1、序列(拆包)*用作序列拆包:*可对字符串、列表、集合、元组、字典、数字元素等序列进行拆包print(*(1,2,3,4,5,6))#1
- 线程Threading用于提供线程相关的操作。线程是应用程序中工作的最小单元,它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程
- 简单的学习下利用socket来建立客户端和服务端之间的连接并且发送数据1. 客户端socketClient.py代码import socke
- 判断函数如下:Public Function CheckBIG(strSource As String) As BooleanDim idx
- 笔者日积月累了许多精彩、实用的Web特效的制作,这些特效几乎都是比较常用的网页特效。现在我就把这些经过
- 中间件中间件是放在客户端和服务端的中间。 当你的客户端对某个接口发起一个请求,但是在到达接口2之前,这里是有一层中间件的处理。一般
- 当鼠标滑过一个图片时,图片会变成另外一张图片的效果是怎么制作出来的呢?相对一些不熟悉HTML代码的朋友来说,可以使用网页编辑软件自带的动作来
- 本文研究的主要是Django权限机制的相关内容,具体如下。1. Django权限机制概述权限机制能够约束用户行为,控制页面的显示内容,也能使
- 关于投票系统怎么样怎么样的引言就不多说,这不是毕业设计,主要说一下使用php实现投票系统,与其他普通系统一样,分为两部分,一个是管理员部分,
- 在页面中自定义了changejs函数后页面提示错误:Active Server Pages 错误 'ASP 0138' 嵌套
- 元素是文档结构的基础,在CSS中,每个元素生成了一个包含了元素内容的框(box,也译为“盒子”)。但是不同的元素显示的方式会有所不同,例如&
- Requests 是使用 Apache2 Licensed 许可证的 基于Python开发的HTTP 库,其在Python内置模块的基础上进
- 一、安装1.从官网下载Linux版的Pycharm官网链接:https://www.jetbrains.com/pycharm/downlo
- 关于“登录”和“注册”的问题已经被很多设计师和交互设计上写过无数遍了,今天我在登录纳米盘网站时受到打击了所以写下此文。事情是这样的:当初租用
- 聚集索引,数据实际上是按顺序存储的,数据页就在索引页上。就好像参考手册将所有主题按顺序编排一样。一旦找到了所要搜索的数据,就完成了这次搜索,
- 环境 python -m venv venvvenv\Scripts\activate 激活环境失败 解决方案输入get-execution
- 1、在Python中以相对路径或者绝对路径来导入文件或者模块的方法今天在调试代码的时候,程序一直提示没有该模块,一直很纳闷,因为我导入文件一