在公司实习。公司推崇Python和Django框架,所以也得跟着学点。

简单瞅了下Tkinter,和Canvas配合在一起,还算是简洁的界面开发API。threading.Thread创建新的线程,其多线程机制也算是方便。

只是canvas.create_rectangle居然不是绘制矩形,而是新建了矩形控件这点让人大跌眼镜。先开始,在线程里每次都重绘多个矩形(随数组变化),其实是每次都新建了N个矩形,结果内存暴增。原来,对矩形进行变更时,只需用canvas.itemconfig即可。

下面就是截图(时间太晚,明日还得上班,做得非常粗糙...没事时再慢慢修正)。

而代码如下:

#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;

#绘图类

canvas = None;

#标题

title = "BrickGame";

#宽和高

width = 350;

height = 670;

#行和列

rows = 20;

cols = 10;

#几种方块

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;

#当前方块形状

shape = -1;

#当前方块的行和列(最左上角)

curRow = -10;

curCol = -10;

#背景

back = list();

#格子

gridBack = 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"));

#绘制游戏的格子

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");

#绘制当前正在运动的方块

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.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.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 __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.canvas = Canvas(self.frame1,width=300,height=600,bg="black");

self.init();

#获得当前的方块

self.getCurBrick();

#按照数组,绘制格子

self.drawRect();

self.canvas.pack();

#监听键盘事件

self.window.bind("",self.onKeyboardEvent);

#启动方块下落线程

downThread = threading.Thread(target=self.brickDown,args=());

downThread.start();

self.window.mainloop();

self.start=False;

pass;

if __name__=='__main__':

brickGame = BrickGame();

估计用图形界面会很少,因为本人是WEB开发。不过,怎样也抑制不住这颗喜欢写游戏的心啊!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持萬仟网。

希望与广大网友互动??

点此进行留言吧!

python俄罗斯方块小游戏实验报告_python实现俄罗斯方块游戏相关推荐

  1. java猜数字游戏实验报告_java猜数游戏实验报告.doc

    java猜数游戏实验报告 课 程 设 计 报 告 课程设计名称 Java程序设计-猜数游戏 指导教师 钟世刚 专业 班级 信息安全 学 号 姓 名 成 绩 一.设计任务与要求1 1.1 设计任务与要求 ...

  2. python猜数游戏实验报告_python实现猜数游戏

    本文实例为大家分享了python实现猜数游戏的具体代码,供大家参考,具体内容如下 一.问题描述: 使用python开发一个猜数小游戏,程序随机产生0~1024之间的数字,用户输入猜测数字,程序告诉用户 ...

  3. python弹球游戏实验报告_Python实战案例:用Python写一个弹球游戏,就是这么强

    我们前面讲了几篇关于类的知识点,为了让大家更好的掌握类的概念,并灵活的运用这些知识,我写了一个有趣又好玩的弹球的游戏,一来可以把类的知识融会一下,二来加深对Python的兴趣.你会发现哎呀Python ...

  4. python贪吃蛇的实验报告_贪吃蛇游戏课程设计实验报告

    DOC 可编辑修改 -------- 为你整理各种最新最全办公范文 -------- 双击可以删除 爱心 --- 用心 --- 恒心 贪吃蛇游戏课程设计实验报告 辽 宁 科 技 大 学 课程设计说明书 ...

  5. c语言俄罗斯方块代码及实验报告,c语言俄罗斯方块实验报告.doc

    c语言俄罗斯方块实验报告.doc PAGE PAGE 1 C语言之游戏俄罗斯方块课程设计报告 专 C语言之游戏 俄罗斯方块课程设计报告 专业: [] 学生姓名: [] 指导教师: [] 完成时间: 目 ...

  6. python五子棋实验报告_python实现五子棋游戏

    本文实例为大家分享了python实现五子棋游戏的具体代码,供大家参考,具体内容如下 话不多说,直接上代码: 全部工程文件,在GitHub:五子棋 效果预览: #!/usr/bin/env python ...

  7. java四子棋实验报告_Python 实现劳拉游戏的实例代码(四连环、重力四子棋)

    游戏规则:双方轮流选择棋盘的列号放进自己的棋子, 若棋盘上有四颗相同型号的棋子在一行.一列或一条斜线上连接起来, 则使用该型号棋子的玩家就赢了! 程序实现游戏,并将每局的数据保存到本地的文件中 首先我 ...

  8. python字典的应用实验报告_Python字典应用的一个例子

    #!/usr/bin/env python #定义一个空字典 db = {} def newuser(): prompt = '--login desired: ' while True: name ...

  9. python词频统计西游记实验报告_Python文本统计功能之西游记用字统计操作示例

    本文实例讲述了Python文本统计功能之西游记用字统计操作.分享给大家供大家参考,具体如下: 一.数据 xyj.txt,<西游记>的文本,2.2MB 致敬吴承恩大师,4020行(段) 二. ...

  10. python简单计算器综合实验报告_Python实现的简单计算器功能详解

    本文实例讲述了Python实现的简单计算器功能.分享给大家供大家参考,具体如下: 使用python编写一款简易的计算器 计算器效果图 首先搭建计算器的面板: 计算器面板结构 建造一个继承于wx.Fra ...

最新文章

  1. C#下如何实现服务器+客户端的聊天程序
  2. D3 Data Visualization in Ext JS
  3. Angular sort recursive的实现原理
  4. python面向对象之类的成员
  5. 【转】分布式websocket服务器
  6. jmp连mysql_令人迷惑的ATT的jmp:直接跳转和间接跳转 [转]
  7. [强]VC 6.0 可以这样创建对话框
  8. (4)css2.1选择器
  9. python etree详解_使用lxml.etree解析python alexa结果
  10. OCR——PaddleOCR之文字识别的学习笔记
  11. Postman中json内字符串转义问题
  12. DNS劫持和HTTP劫持有何区别
  13. 【图论】昂贵的聘礼(最短路变形)
  14. web_submit_data详解
  15. ffmpeg使用指令转码b站上下载的视频
  16. PWA系列 - Web Push 技术
  17. 直播预约 | 如何通过MLOps解放和提升AI生产力?
  18. 【科创人】维格表创始人陈霈霖:喜茶数字化转型的结晶是vika维格表
  19. 零点定理的奇妙应用:平分面积的直线
  20. 基于Python爬取福建省莆田市天气预报数据获取与预处理的设计与实现

热门文章

  1. SQL查询语句之查询数据
  2. photoshop切片的使用
  3. 使用VLC-QT开源库开发流媒体播放器
  4. 绿联 蓝牙适配器 linux,绿联USB
  5. 双硬盘安装win7和Ubuntu双系统,解决系统启动引导问题
  6. Jmeter java取样器实现
  7. 编译Android版本的chromium浏览器
  8. 【性能】【内存】swap解读
  9. ExoPlayer播放器播放MP2音频格式视频无声音加入Ffmpeg软解码功能
  10. 交换机基本原理与配置