基于Python实现的扫雷游戏实例代码


Posted in Python onAugust 01, 2014

本文实例借鉴mvc模式,核心数据为model,维护1个矩阵,0表无雷,1表雷,-1表已经检测过。
本例使用python的tkinter做gui,由于没考虑可用性问题,因此UI比较难看,pygame更有趣更强大更好看,做这些小游戏更合适,感兴趣的读者可以尝试一下!

具体的功能代码如下:

# -*- coding: utf-8 -*-
import random
import sys
from Tkinter import *

class Model:
  """
  核心数据类,维护一个矩阵
  """
  def __init__(self,row,col):
    self.width=col
    self.height=row
    self.items=[[0 for c in range(col)] for r in range(row)]

  def setItemValue(self,r,c,value):
    """
    设置某个位置的值为value
    """
    self.items[r][c]=value;

  def checkValue(self,r,c,value):
    """
    检测某个位置的值是否为value
    """
    if self.items[r][c]!=-1 and self.items[r][c]==value:
      self.items[r][c]=-1 #已经检测过
      return True
    else:
      return False
    
  def countValue(self,r,c,value):
    """
    统计某个位置周围8个位置中,值为value的个数
    """
    count=0
    if r-1>=0 and c-1>=0:
      if self.items[r-1][c-1]==1:count+=1
    if r-1>=0 and c>=0:
      if self.items[r-1][c]==1:count+=1
    if r-1>=0 and c+1<=self.width-1:
      if self.items[r-1][c+1]==1:count+=1
    if c-1>=0:
      if self.items[r][c-1]==1:count+=1
    if c+1<=self.width-1 :
      if self.items[r][c+1]==1:count+=1
    if r+1<=self.height-1 and c-1>=0:
      if self.items[r+1][c-1]==1:count+=1
    if r+1<=self.height-1 :
      if self.items[r+1][c]==1:count+=1
    if r+1<=self.height-1 and c+1<=self.width-1:
      if self.items[r+1][c+1]==1:count+=1
    return count

  
class Mines(Frame):
  def __init__(self,m,master=None):
    Frame.__init__(self,master)
    self.model=m
    self.initmine()
    self.grid()
    self.createWidgets()

 
  
  def createWidgets(self):
    #top=self.winfo_toplevel()
    #top.rowconfigure(self.model.height*2,weight=1)
    #top.columnconfigure(self.model.width*2,weight=1)
    self.rowconfigure(self.model.height,weight=1)
    self.columnconfigure(self.model.width,weight=1)
    self.buttongroups=[[Button(self,height=1,width=2) for i in range(self.model.width)]
              for j in range(self.model.height)]
    for r in range(self.model.width):
      for c in range(self.model.height):
        self.buttongroups[r][c].grid(row=r,column=c)
        self.buttongroups[r][c].bind('<Button-1>',self.clickevent)
        self.buttongroups[r][c]['padx']=r
        self.buttongroups[r][c]['pady']=c

  def showall(self):
    for r in range(model.height):
      for c in range(model.width):
        self.showone(r,c)

  def showone(self,r,c):
    if model.checkValue(r,c,0):
      self.buttongroups[r][c]['text']=model.countValue(r,c,1)
    else:
      self.buttongroups[r][c]['text']='Mines'

  def recureshow(self,r,c):
    if 0<=r<=self.model.height-1 and 0<=c<=self.model.width-1:
      if model.checkValue(r,c,0) and model.countValue(r,c,1)==0:
        self.buttongroups[r][c]['text']=''
        self.recureshow(r-1,c-1)
        self.recureshow(r-1,c)
        self.recureshow(r-1,c+1)
        self.recureshow(r,c-1)
        self.recureshow(r,c+1)
        self.recureshow(r+1,c-1)
        self.recureshow(r+1,c)
        self.recureshow(r+1,c+1)
      elif model.countValue(r,c,1)!=0:
        self.buttongroups[r][c]['text']=model.countValue(r,c,1)
    else:
      pass
        
      
  def clickevent(self,event):
    """
    点击事件
    case 1:是雷,所有都显示出来,游戏结束
    case 2:是周围雷数为0的,递归触发周围8个button的点击事件
    case 3:周围雷数不为0的,显示周围雷数
    """
    r=int(str(event.widget['padx']))
    c=int(str(event.widget['pady']))
    if model.checkValue(r,c,1):#是雷
      self.showall()
    else:#不是雷
      self.recureshow(r,c)
    
    
  def initmine(self):
    """
    埋雷,每行埋height/width+2个暂定
    """
    r=random.randint(1,model.height/model.width+2)
    for r in range(model.height):
      for i in range(2):
        rancol=random.randint(0,model.width-1)
        model.setItemValue(r,rancol,1)

  
  def printf(self):
    """
    打印
    """
    for r in range(model.height):
      for c in range(model.width):
        print model.items[r][c],
      print '/n'
      

def new(self):
  """
  重新开始游戏
  """
  pass

if __name__=='__main__':
  model=Model(10,10)
  root=Tk()
  
  #menu
  menu = Menu(root)
  root.config(menu=menu)
  filemenu = Menu(menu)
  menu.add_cascade(label="File", menu=filemenu)
  filemenu.add_command(label="New",command=new)
  filemenu.add_separator()
  filemenu.add_command(label="Exit", command=root.quit)

  #Mines
  m=Mines(model,root)
  #m.printf()
  root.mainloop()
Python 相关文章推荐
Python的Django框架中的数据库配置指南
Jul 17 Python
python放大图片和画方格实现算法
Mar 30 Python
如何优雅地改进Django中的模板碎片缓存详解
Jul 04 Python
Python爬虫实现简单的爬取有道翻译功能示例
Jul 13 Python
python生成lmdb格式的文件实例
Nov 08 Python
python实现弹窗祝福效果
Apr 07 Python
在python中实现调用可执行文件.exe的3种方法
Jul 07 Python
关于Numpy数据类型对象(dtype)使用详解
Nov 27 Python
python @propert装饰器使用方法原理解析
Dec 25 Python
TensorBoard 计算图的可视化实现
Feb 15 Python
opencv 形态学变换(开运算,闭运算,梯度运算)
Jul 07 Python
Python如何实现机器人聊天
Sep 10 Python
python脚本实现查找webshell的方法
Jul 31 #Python
用python删除java文件头上版权信息的方法
Jul 31 #Python
Python datetime时间格式化去掉前导0
Jul 31 #Python
python处理文本文件并生成指定格式的文件
Jul 31 #Python
Python中关键字is与==的区别简述
Jul 31 #Python
python处理文本文件实现生成指定格式文件的方法
Jul 31 #Python
Python中zip()函数用法实例教程
Jul 31 #Python
You might like
jq的get传参数在utf-8中乱码问题的解决php版
2008/07/23 PHP
php array_search() 函数使用
2010/04/13 PHP
PHP flock 文件锁详细介绍
2012/12/29 PHP
PHP运行环境配置与开发环境的配置(图文教程)
2013/06/04 PHP
Laravel5.1 框架路由基础详解
2020/01/04 PHP
js post提交调用方法
2014/02/12 Javascript
JS不能跨域借助jquery获取IP地址的方法
2014/08/20 Javascript
node+express+ejs制作简单页面上手指南
2014/11/26 Javascript
jquery实现侧边弹出的垂直导航
2014/12/09 Javascript
javascript正则表达式使用replace()替换手机号的方法
2015/01/19 Javascript
基于ajax实现文件上传并显示进度条
2015/08/03 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
小程序图片长按识别功能的实现方法
2018/08/30 Javascript
如何从0开始用node写一个自己的命令行程序
2018/12/29 Javascript
JS实现将对象转化为数组的方法分析
2019/01/21 Javascript
Jquery实现无缝向上循环滚动列表的特效
2019/02/13 jQuery
JavaScript类型相关的常用操作总结
2019/02/14 Javascript
vue+Element-ui实现分页效果
2020/11/15 Javascript
[35:34]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python实现OpenCV的安装与使用示例
2018/03/30 Python
Python初学者需要注意的事项小结(python2与python3)
2018/09/26 Python
Python实现iOS自动化打包详解步骤
2018/10/03 Python
详解python算法之冒泡排序
2019/03/05 Python
Python小程序 控制鼠标循环点击代码实例
2019/10/08 Python
python使用python-pptx删除ppt某页实例
2020/02/14 Python
CSS3毛玻璃效果(blur)有白边问题的解决方法
2016/11/15 HTML / CSS
意大利团购网站:Groupon意大利
2016/10/11 全球购物
美国最大的半成品净菜电商:Blue Apron(蓝围裙)
2018/04/27 全球购物
俄罗斯药房连锁店:ASNA
2020/06/20 全球购物
大学军训自我鉴定
2013/12/15 职场文书
农场厂长岗位职责
2013/12/28 职场文书
《灰椋鸟》教学反思
2014/04/27 职场文书
2015年推普周活动方案
2015/05/06 职场文书
python requests模块的使用示例
2021/04/07 Python
Python数据分析之绘图和可视化详解
2021/06/02 Python
DSP接收机前端设想
2022/04/05 无线电