我的编程空间,编程开发者的网络收藏夹
学习永远不晚

基于Python如何实现骰子小游戏

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

基于Python如何实现骰子小游戏

这篇文章主要讲解了“基于Python如何实现骰子小游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于Python如何实现骰子小游戏”吧!

一、环境准备 

1)运行环境 

 开发环境:Python3、Pycharm社区版、tkinter,部分自带的模块安装Python即可使用。 

 2)模块安装

 第三方库的安装方式如下: 

 一般安装:pip install +模块名 

 镜像源安装:pip install -i pypi.douban.com/simple/+模块名…

二、代码展示

1)主程序界面

import tkinter as tkfrom sohagame import Unique_SohaGamefrom Windows import Unique_Windows"""主函数程序入口"""if __name__ == '__main__':    root = tk.Tk()    root['width'] = 600    root['height'] = 400    root['bg'] = 'white'    root.title("骰子梭哈游戏")    soha = Unique_SohaGame()    Unique_Windows(root, soha)    root.mainloop()

2)界面类

界面类,主要管理tkintter界面布局, 界面与界面之间的跳转、 信息传递注:为减少冗余描述,类似属性的相同功能仅介绍一遍, 不重复介绍。 整个游戏界面采用tkinter布局中的place布局

import tkinter as tkimport tkinter.messageboxclass Unique_Windows:    # 界面管理类初始化操作, 传入两个参数, root是Tk()对象,用于生成窗口、界面,soha是游戏类对象,用于给按键等附加功能    def __init__(self, root, soha):        self.root = root        self.soha = soha        self.lbl = tk.Label(self.root, text='欢迎来到骰子梭哈游戏', font=('microsoft yahei', 15),                            fg='white', bg='#007d65')        self.lbl.place(x=150, y=0)        self.lbl1 = tk.Label(self.root, bg='#007d65', text='请操作:', font=('microsoft yahei', 15),                             fg='Orange')        self.lbl1.place(x=120, y=40)        self.f1 = None        self.f2 = None        self.cfl_createStartWidget()    def cfl_createStartWidget(self):  # 创造游戏root开始界面(下面相同属性就不一一介绍,道理相同)        self.root['width'] = 600  # 设置宽高        self.root['height'] = 400        self.root['bg'] = "#007d65"  # 设置背景颜色        if self.f1:          # 如果存在一个Frame窗口框架控件,则删除, 然后新建一个该控件。            self.f1.destroy()        self.f1 = tk.Frame(self.root)        self.f1['width'] = 400  # 设置控件宽高        self.f1['height'] = 300        self.f1['bg'] = '#007d65'  # 设置控件背景颜色        '''添加组件到Frame控件中'''        self.btStart = tk.Button(self.f1, text='开始游戏', font=('黑体', 18),  # 开始游戏按键,点击开始游戏, 即可进入游戏界面                                 width=20, fg='black', command=self.cfl_startSohaGame)  # 添加按钮关联的方法        self.btStart.place(x=80, y=50)  # 整个游戏界面采用place布局        self.btEnd = tk.Button(self.f1, text='结束游戏', font=('黑体', 18),                               width=20, fg='black', command=self.cfl_gameOver)  # 添加结束游戏方法        self.btEnd.place(x=80, y=150)        self.f1.place(x=0, y=80)    def cfl_createContentWidge(self):  # 创造游戏内容界面(本质上是重写了Frame类型f2的布局, 并将以前的f2布局销毁)        """创造游戏内容界面"""        self.root['width'] = 800        self.root['height'] = 600        if self.f2:            self.f2.destroy()        self.f2 = tk.Frame(self.root)        self.f2['width'] = 800        self.f2['height'] = 600        self.f2['bg'] = '#d9d6c3'        self.f2.place(x=0, y=0)        self.lab01 = tk.Label(self.f2, text='双人骰子/多人骰子游戏', font=('黑体', 30), fg='black', bg="#d9d6c3")        self.lab01.place(x=200, y=100)        """主要按钮及显示效果"""        '''返回按钮'''        self.btn1 = tk.Button(self.f2, text="返回", fg='#224b8f', font=('黑体', 18), bg="wheat", command=self.cfl_backToRoot)        self.btn1.place(x=150, y=500)        '''选择双人游戏按钮'''        self.lab03 = tk.Label(self.f2, text="人数限定:2", bg="#d9d6c3", fg='black', font=('黑体', 18))        self.lab03.place(x=150, y=300)        self.btn2 = tk.Button(self.f2, text="双人骰子", bg="wheat", font=('黑体', 18), command=self.cfl_createDoubleDiceGame)        self.btn2.place(x=150, y=200)        '''选择多人游戏按钮'''        self.entry03 = tk.Entry(self.f2, bg="white", font=('黑体', 18))        self.entry03.place(x=350, y=260)        self.lab04 = tk.Label(self.f2, bg="#d9d6c3", fg='black', text="人数限定:3~10(在上方输入框输入人数)", font=('黑体', 18))        self.lab04.place(x=350, y=300)        def cmd1():  # 内置方法, 主要用于实现按钮的功能            self.cfl_Multiplayer(self.entry03.get())        self.btn2 = tk.Button(self.f2, bg="wheat", text="多人骰子", font=('黑体', 18), command=cmd1)        self.btn2.place(x=350, y=200)    def cfl_startSohaGame(self):  # 游戏开始        self.cfl_createContentWidge()    def cfl_gameOver(self):  # 游戏结束        self.root.quit()    def cfl_backToRoot(self):  # 返回开始游戏界面        self.cfl_createStartWidget()        self.f2.destroy()    def cfl_createDoubleDiceGame(self):  # 双人骰子游戏界面布局        if self.f2:            self.f2.destroy()        self.f2 = tk.Frame(self.root)        self.f2['width'] = 800        self.f2['height'] = 600        self.lab01 = tk.Label(self.f2, font=('黑体', 14), text="@玩家1,请在下方输入框输入您的名字:")        self.lab01.place(x=140, y=40)        self.entry01 = tk.Entry(self.f2, width=40)        self.entry01.place(x=200, y=90)        self.lab02 = tk.Label(self.f2, font=('黑体', 14), text="@玩家2,请在下方输入框输入您的名字:")        self.lab02.place(x=140, y=160)        self.entry02 = tk.Entry(self.f2, width=40)        self.entry02.place(x=200, y=210)        def cmd1():            '''获取骰子'''            self.soha.zmx_getPlayerDiceList()        def cmd2():            '''获取玩家姓名'''            self.soha.llq_getPlayerName(self.entry01.get(), self.entry02.get())        def cmd3():            '''判断玩家输赢'''            if len(self.soha.playerList) == 0:                tk.messagebox.showinfo("错误提示", "名字不能为空!!!")            elif self.soha.playerList[0].Dice_List == []:                tk.messagebox.showinfo("错误提示", "请为每个玩家获取骰子数据!!!")            else:                self.cfl_outputDoubleWinner()                self.soha.playerList = []  # 清空数据        self.btn2 = tk.Button(self.f2, font=('黑体', 14), text="提交姓名", command=cmd2)        self.btn2.place(x=180, y=280)        self.btn6 = tk.Button(self.f2, font=('黑体', 14), text="获取骰子", command=cmd1)        self.btn6.place(x=360, y=280)        self.btn3 = tk.Button(self.f2, font=('黑体', 14), text="获取输赢结果", command=cmd3)        self.btn3.place(x=360, y=350)        self.btn4 = tk.Button(self.f2, font=('黑体', 14), text="返回", command=self.cfl_createContentWidge)        self.btn4.place(x=180, y=350)        self.f2.place(x=20, y=0)        self.f2.place(x=0, y=0)    def cfl_outputDoubleWinner(self):        result = self.soha.mhl_judgeTwoVictory()        if self.f2:            self.f2.destroy()        self.f2 = tk.Frame(self.root)        self.f2['width'] = 800        self.f2['height'] = 600        self.lab01 = tk.Label(self.f2, font=('黑体', 16), text="双人骰子本轮结果展示如下:")        self.lab01.place(x=100, y=80)        self.lab01 = tk.Label(self.f2, font=('黑体', 16), text=result)        self.lab01.place(x=100, y=150)        def cmd1():  # 返回功能实现函数            self.cfl_createDoubleDiceGame()            self.soha.playerList = []  # 清空数据        self.btn1 = tk.Button(self.f2,font=('黑体', 16), text="返回", command=cmd1)        self.btn1.place(x=100, y=500)        self.f2.place(x=0, y=0)    def cfl_Multiplayer(self, strnum):  # 多人游戏骰子        numlist = {'3', '4', '5', '6', '7', '8', '9', '10'}        if strnum not in numlist:            tkinter.messagebox.showinfo("错误提示", "输入错误或未输入,请重新输入!")        else:            num = int(strnum)            if self.f2:                self.f2.destroy()            self.f2 = tk.Frame(self.root)            self.f2['width'] = 800            self.f2['height'] = 600            self.labs = []            self.entrys = []            if num <= 5:                for i in range(0, num):                    p = tk.Label(self.f2, font=('黑体', 12), text="@玩家"+str(i+1)+":请在下边输入框输入您的名字:")                    p.place(x=100, y=80 * i + 20)                    e = tk.Entry(self.f2, width=25)                    e.place(x=120, y=80 * i + 60)                    self.labs.append(p)                    self.entrys.append(e)            else:                for i in range(0, num):                    p = tk.Label(self.f2, font=('黑体', 10), text="@玩家"+str(i+1)+":请在右边输入框输入您的名字:")                    p.place(x=100, y=50 * i + 20)                    e = tk.Entry(self.f2, width=25)                    e.place(x=370, y=50 * i + 20)                    self.labs.append(p)                    self.entrys.append(e)            def cmd1():                '''获取骰子'''                self.soha.zmx_getPlayersDiceList(num)            def cmd2():                '''获取多人玩家姓名'''                namelist = []                for i in range(0, num):                    p = self.entrys[i].get()                    namelist.append(p)                self.soha.llq_getPlayersName(num, namelist)            def cmd3():                '''判断多人玩家输赢'''                if len(self.soha.playerList) == 0:                    tk.messagebox.showinfo("错误提示", "名字不能为空!!!")                elif self.soha.playerList[0].Dice_List == []:                    tk.messagebox.showinfo("错误提示", "请为每个玩家获取骰子数据!!!")                else:                    self.cfl_ouputMultipleWinner(num)                    self.soha.playerList = []            self.btn2 = tk.Button(self.f2, font=('黑体', 14), text="提交姓名", command=cmd2)            self.btn2.place(x=180, y=500)            self.btn6 = tk.Button(self.f2, font=('黑体', 14), text="获取骰子", command=cmd1)            self.btn6.place(x=360, y=500)            self.btn3 = tk.Button(self.f2, font=('黑体', 14), text="获取骰子输赢排名", command=cmd3)            self.btn3.place(x=360, y=550)            self.btn4 = tk.Button(self.f2, font=('黑体', 14), text="返回", command=self.cfl_createContentWidge)            self.btn4.place(x=180, y=550)            self.f2.place(x=0, y=0)    def cfl_ouputMultipleWinner(self, num):  # 多人骰子游戏大小排名输出界面        result = self.soha.mhl_judgeMultipleWinner(num)        strResult = self.soha.mhl_getPlayersListData()        tkinter.messagebox.showinfo("恭喜", "@"+result[0].name+",恭喜您,力压众强,获得了本轮游戏的第一!")        if self.f2:            self.f2.destroy()        self.f2 = tk.Frame(self.root)        self.f2['width'] = 800        self.f2['height'] = 600        self.lab01 = tk.Label(self.f2, font=('黑体', 16), text="多人骰子大小排名结果如下")        self.lab01.place(x=100,y=80)        self.labresult = tk.Label(self.f2, font=('黑体', 14), text=strResult)        self.labresult.place(x=100,y=120)        def cmd1():  # 返回功能实现函数            strNum = str(num)            self.cfl_Multiplayer(strNum)            self.soha.playerList = []  # 清空数据        self.btn1 = tk.Button(self.f2,font=('黑体', 16), text="返回", command=cmd1)        self.btn1.place(x=100, y=500)        self.f2.place(x=0, y=0)

感谢各位的阅读,以上就是“基于Python如何实现骰子小游戏”的内容了,经过本文的学习后,相信大家对基于Python如何实现骰子小游戏这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

基于Python如何实现骰子小游戏

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

基于Python如何实现骰子小游戏

这篇文章主要讲解了“基于Python如何实现骰子小游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于Python如何实现骰子小游戏”吧!一、环境准备 1)运行环境 开发环境:Pytho
2023-07-05

基于Python实现骰子小游戏

骰子,是现在娱乐场所最常见的一种玩乐项目。一般骰子分两人和两人以上玩,而玩法有很多。本文就来用Python实现个骰子小游戏,感兴趣的可以了解一下
2023-02-28

python如何实现一个摇骰子小游戏

这篇文章将为大家详细讲解有关python如何实现一个摇骰子小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、程序实现分析问题:骰子比大小是我们经常玩的一个小游戏也十分的简单,就是不同玩家骰子点数比较
2023-06-28

基于C++如何实现掷双骰游戏

这篇“基于C++如何实现掷双骰游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“基于C++如何实现掷双骰游戏”文章吧。在最流
2023-06-29

如何用Python代码实现掷骰子游戏

今天小编给大家分享一下如何用Python代码实现掷骰子游戏的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。构思骰子是个立方体,
2023-06-27

基于JS如何实现接粽子小游戏

这篇文章主要介绍“基于JS如何实现接粽子小游戏”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于JS如何实现接粽子小游戏”文章能帮助大家解决问题。游戏设计在游戏屏幕内,会随机的从顶部掉落粽子,通过鼠
2023-06-30

Android如何实现微信摇骰子游戏

这篇文章主要讲解了Android如何实现微信摇骰子游戏,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。过年怎么可以不玩红包娱乐一下呢,微信里的摇骰子大小和石头剪刀布就是不错的游戏方式。使用Java的Random函
2023-05-31

基于Python如何实现彩票小游戏

本篇内容主要讲解“基于Python如何实现彩票小游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“基于Python如何实现彩票小游戏”吧!一、游戏规则游戏里面有提前设置好的奖项,分为三个,一等奖
2023-07-05

基于Python如何实现格斗小游戏

本文小编为大家详细介绍“基于Python如何实现格斗小游戏”,内容详细,步骤清晰,细节处理妥当,希望这篇“基于Python如何实现格斗小游戏”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、简易版本格斗impor
2023-07-05

Python如何使用random模块实现掷骰子游戏

这篇文章将为大家详细讲解有关Python如何使用random模块实现掷骰子游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStack。2、WEB
2023-06-14

基于Qt实现电子木鱼小游戏

今年最火爆的解压小游戏电子木鱼,现在许多软件都上架了这个小程序。我在网上看了一下基本上都是用py和Java写的,所以我用QT重新写了一下,作为小白练手项目非常适合,快跟随小编一起学习一下吧
2023-01-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录