代码搬运修改自python编写俄罗斯方块 更新时间:2020年03月13日 09:39:17 作者:勤勉之

from tkinter import *
from random import *
import threading
from tkinter.messagebox 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 range(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()```

pygame写俄罗斯方块的更多相关文章

  1. 从零开始---控制台用c写俄罗斯方块游戏(1)

    从零开始---控制台用c写俄罗斯方块游戏(1) 很少写博文,一来自身知识有限,二来自己知道,已经有很多这样的博文了,三就是因为懒,文笔也一般,四来刚出来工作,时间也不多 之所以写这篇博文,是因为应群里 ...

  2. pygame写的弹力球

    这是pygame写的弹力球 运行效果: ======================================================== 代码部分: ================= ...

  3. 作业:用pygame实现俄罗斯方块

    用Pygame实现俄罗斯方块 参考资料后我安装了Pygame,参考了网上的代码实现了俄罗斯方块小游戏.我试着理解网上的代码的原理和含义,对这些代码的原理有了一个粗略地理解,代码通过参数,RGB值等来实 ...

  4. Javascript写俄罗斯方块游戏

    俄罗斯方块这个游戏也做了移动端的兼容, 这个游戏难点是怎么翻转方块, 自己实现的方式是把方块放到一个二维数组, 然后逆时针旋转二维数组. 也有别的方法,比如直接用一个全局变量代表一个方向, 翻转的时候 ...

  5. pygame写贪吃蛇

    python小白尝试写游戏.. 学了点pygame不知道那什么练手好,先拿贪吃蛇开刀吧. 一个游戏可以粗略的分为两个部分: 数据(变量) 处理数据(函数,方法) 设计变量 首先预想下,画面的那些部分需 ...

  6. 基于Pygame写的翻译方法

    发布时间:2018-11-01   技术:pygame+easygui   概述 实现一个翻译功能,中英文的互相转换.并可以播放翻译后的内容. 翻译接口调用的是百度翻译的api接口. 详细 代码下载: ...

  7. electron写俄罗斯方块游戏(Tetris)

    背景 在折腾ES6,突然想起大学时用c语言写过俄罗斯方块,本项目中主要是利用ES6的Class特性进行面向对象编程.项目采用node.js v6.2.0 + electron v1.1.0 进行桌面开 ...

  8. 用Python和Pygame写游戏-从入门到精通(py2exe篇)

    这次不是直接讲解下去,而是谈一下如何把我们写的游戏做成一个exe文件,这样一来,用户不需要安装python就可以玩了.扫清了游戏发布一大障碍啊! perl,python,java等编程语言,非常好用, ...

  9. 用python+pygame写贪吃蛇小游戏

    因为python语法简单好上手,前两天在想能不能用python写个小游戏出来,就上网搜了一下发现了pygame这个写2D游戏的库.了解了两天再参考了一些资料就开始写贪吃蛇这个小游戏. 毕竟最开始的练手 ...

随机推荐

  1. C# 实例解释面向对象编程中的单一功能原则

    在面向对象编程中,SOLID 是五个设计原则的首字母缩写,旨在使软件设计更易于理解.灵活和可维护.这些原则是由美国软件工程师和讲师罗伯特·C·马丁(Robert Cecil Martin)提出的许多原 ...

  2. 数论同余学习笔记 Part 2

    逆元 准确地说,这里讲的是模意义下的乘法逆元. 定义:如果有同余方程 \(ax\equiv 1\pmod p\),则 \(x\) 称为 \(a\bmod p\) 的逆元,记作 \(a^{-1}\). ...

  3. 鸿蒙轻内核源码分析:文件系统FatFS

    摘要:本文为大家介绍FatFS文件系统结构体的结构体和全局变量,并分析FatFS文件操作接口. 本文分享自华为云社区<鸿蒙轻内核M核源码分析系列二一 03 文件系统FatFS>,作者:zh ...

  4. JAVA多线程学习十六 - 同步集合类的应用

    1.引言 在多线程的环境中,如果想要使用容器类,就需要注意所使用的容器类是否是线程安全的.在最早开始,人们一般都在使用同步容器(Vector,HashTable),其基本的原理,就是针对容器的每一个操 ...

  5. PMD的使用学习

    是什么? 静态代码分析器 能找出什么问题? 可能的 bugs - 空的 try/catch/finally/switch 声明 死码 - 未使用的本地变量,参数和私有方法 次优代码 - 无用的 Str ...

  6. LeetCode随缘刷题之截断句子

    这道题相对比较简单.正好最近学到StringBuilder就用了. package leetcode.day_12_06; /** * 句子 是一个单词列表,列表中的单词之间用单个空格隔开,且不存在前 ...

  7. 有手就行8——项目构建细节3-Jenkins的参数化构建

    有手就行8--项目构建细节3-Jenkins的参数化构建 有时在项目构建的过程中,我们需要根据用户的输入动态传入一些参数,从而影响整个构建结果,这时  我们可以使用参数化构建. Jenkins支持非常 ...

  8. Solution -「HNOI 2007」「洛谷 P3185」分裂游戏

    \(\mathcal{Description}\)   Link.   给定 \(n\) 堆石子,数量为 \(\{a_n\}\),双人博弈,每轮操作选定 \(i<j\le k\),使 \(a_i ...

  9. 让数据可视化变得简单 – JavaScript 图形库

    作者 | 董叶 公司决策层会围绕着数据来制定相应的策略,数据的重要性与日俱增,政府.金融机构.互联网大厂正在以前所未有的速度收集数据,面对扑面而来的数据,没有抽象.视觉层的帮助,我们很难快速理解掌握其 ...

  10. 利用shell脚本使用kubeadm部署kubenetes 1.18.6集群环境

    # README # 此脚本需要在master节点上使用 # 注意root密码,请提前修改 # 个人实验环境,注意机器最低配置:master(2G内存,1cpu2核心,否则集群会创建失败),node( ...