【游戏制作】使用Python创建一个完整的2048游戏项目

 

目录

项目运行展示

项目概述

项目目标

项目结构

安装依赖

代码实现

1. 导入库

2. 创建 Game2048 类

 3. 设置UI界面

 4. 加载二维码图片

5. 创建菜单 

6. 游戏逻辑和功能 

 7. 运行应用

总结


创建一个完整的2048游戏项目

项目运行展示

项目概述

在这个项目中,我们将创建一个2048游戏的桌面应用程序。这个游戏是一个流行的数学游戏,玩家通过合并相同的数字块来达到2048。我们将使用 ttkbootstrap 库为应用程序添加现代化的外观,并且通过 tkinterPIL 实现游戏的功能和界面。

项目目标
  • 实现2048游戏的逻辑和UI
  • 添加历史记录功能
  • 实现主题和窗口大小的动态修改
  • 加载和显示二维码图片
  • 添加游戏开始和结束的逻辑
项目结构
  1. 主程序文件: game2048.py — 包含游戏逻辑和界面实现。
  2. 资源文件: 1.gif — 二维码图片资源。
安装依赖

确保你已经安装了以下Python库:

  • tkinter (Python的标准库,通常默认安装)
  • ttkbootstrap (用于增强tkinter的UI)
  • Pillow (用于处理图像)

可以通过以下命令安装缺失的依赖:

pip install ttkbootstrap pillow
代码实现
1. 导入库
import tkinter as tk
import ttkbootstrap as ttk
from ttkbootstrap.constants import *
from tkinter import Menu, Toplevel, messagebox, simpledialog
import random
import datetime
from PIL import Image, ImageTk
2. 创建 Game2048
class Game2048(ttk.Window):def __init__(self):super().__init__(title="2048 Game", themename="superhero")self.grid()self.cells = [[None for _ in range(4)] for _ in range(4)]self.history = []self.setup_ui()self.create_menu()self.start_game()
 3. 设置UI界面
    def setup_ui(self):self.title("2048 Game")self.geometry("800x600")self.resizable(False, False)self.main_grid = ttk.Frame(self, style='secondary.TFrame')self.main_grid.grid(row=0, column=0, padx=(10, 10), pady=(10, 10))for i in range(4):row = []for j in range(4):cell_frame = ttk.Frame(self.main_grid, width=100, height=100, style='primary.TFrame')cell_frame.grid(row=i, column=j, padx=5, pady=5)cell_number = ttk.Label(self.main_grid, text="", style='primary.Inverse.TLabel', font=("Helvetica", 24, "bold"))cell_number.grid(row=i, column=j)cell_data = {"frame": cell_frame, "number": cell_number}row.append(cell_data)self.cells[i] = rowself.score_label = ttk.Label(self, text="Score: 0", style='info.TLabel', font=("Helvetica", 16))self.score_label.grid(row=1, column=0, columnspan=4, pady=(0, 10))# 加载二维码图片self.load_qr_code()self.bind_keys()
 4. 加载二维码图片
    def load_qr_code(self):image = Image.open("1.gif")  # 替换为你的二维码图片路径image = image.resize((150, 150), Image.ANTIALIAS)self.qr_code_image = ImageTk.PhotoImage(image)self.qr_code_label = ttk.Label(self, image=self.qr_code_image)self.qr_code_label.grid(row=0, column=1, padx=(10, 10), pady=(10, 10))self.qr_code_text = ttk.Label(self, text="B站优秀稳妥的小光", style='info.TLabel', font=("Helvetica", 16))self.qr_code_text.grid(row=0, column=1, pady=(170, 10))
5. 创建菜单 
    def create_menu(self):menubar = Menu(self)# 历史记录菜单history_menu = Menu(menubar, tearoff=0)history_menu.add_command(label="查看历史分数", command=self.show_history)menubar.add_cascade(label="历史记录", menu=history_menu)# 查看菜单view_menu = Menu(menubar, tearoff=0)view_menu.add_command(label="查看日期", command=self.show_date)view_menu.add_command(label="查看开发者", command=self.show_developer)menubar.add_cascade(label="查看", menu=view_menu)# 修改菜单edit_menu = Menu(menubar, tearoff=0)# 修改主题子菜单theme_menu = Menu(edit_menu, tearoff=0)style = ttk.Style()theme_names = style.theme_names()for theme_name in theme_names:theme_menu.add_command(label=theme_name, command=lambda t=theme_name: self.change_theme(t))edit_menu.add_cascade(label="修改主题", menu=theme_menu)# 修改窗口大小功能edit_menu.add_command(label="修改窗口大小", command=self.change_window_size)menubar.add_cascade(label="修改", menu=edit_menu)self.config(menu=menubar)
6. 游戏逻辑和功能 
    def start_game(self):self.matrix = [[0] * 4 for _ in range(4)]self.score = 0self.add_new_tile()self.add_new_tile()self.update_ui()def add_new_tile(self):empty_cells = [(i, j) for i in range(4) for j in range(4) if self.matrix[i][j] == 0]if empty_cells:i, j = random.choice(empty_cells)self.matrix[i][j] = 2 if random.random() < 0.9 else 4def update_ui(self):for i in range(4):for j in range(4):cell_value = self.matrix[i][j]if cell_value == 0:self.cells[i][j]["frame"].configure(style='primary.TFrame')self.cells[i][j]["number"].configure(text="")else:self.cells[i][j]["frame"].configure(style=f'TFrame')self.cells[i][j]["number"].configure(text=str(cell_value), font=("Helvetica", 24, "bold"))self.score_label.configure(text=f"Score: {self.score}")self.update_idletasks()def move_up(self, event):self.move_tiles(0, -1)self.merge_tiles(0, -1)self.move_tiles(0, -1)self.add_new_tile()self.update_ui()self.check_game_over()def move_down(self, event):self.move_tiles(0, 1)self.merge_tiles(0, 1)self.move_tiles(0, 1)self.add_new_tile()self.update_ui()self.check_game_over()def move_left(self, event):self.move_tiles(-1, 0)self.merge_tiles(-1, 0)self.move_tiles(-1, 0)self.add_new_tile()self.update_ui()self.check_game_over()def move_right(self, event):self.move_tiles(1, 0)self.merge_tiles(1, 0)self.move_tiles(1, 0)self.add_new_tile()self.update_ui()self.check_game_over()def move_tiles(self, x, y):def move(x, y, i, j):if self.matrix[i][j] != 0:ni, nj = i + x, j + ywhile 0 <= ni < 4 and 0 <= nj < 4 and self.matrix[ni][nj] == 0:self.matrix[ni][nj] = self.matrix[i][j]self.matrix[i][j] = 0i, j = ni, njni, nj = i + x, j + yfor i in range(4):for j in range(4):if x == -1:move(x, y, i, j)if x == 1:move(x, y, 3 - i, j)if y == -1:move(x, y, j, i)if y == 1:move(x, y, j, 3 - i)def merge_tiles(self, x, y):def merge(x, y, i, j):ni, nj = i + x, j + yif 0 <= ni < 4 and 0 <= nj < 4 and self.matrix[i][j] == self.matrix[ni][nj] and self.matrix[i][j] != 0:self.matrix[ni][nj] *= 2self.matrix[i][j] = 0self.score += self.matrix[ni][nj]for i in range(4):for j in range(4):if x == -1:merge(x, y, i, j)if x == 1:merge(x, y, 3 - i, j)if y == -1:merge(x, y, j, i)if y == 1:merge(x, y, j, 3 - i)def show_history(self):history_window = Toplevel(self)history_window.title("历史分数")history_window.geometry("320x420")history_text = tk.Text(history_window, wrap="word")history_text.pack(expand=1, fill="both")for record in self.history:history_text.insert("end", record + "\n")def show_date(self):current_date = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")messagebox.showinfo("当前日期和时间", current_date)def show_developer(self):messagebox.showinfo("开发者信息", "开发者: B站 优秀稳妥的小光")def check_game_over(self):if not any(0 in row for row in self.matrix) and not self.can_merge():self.history.append(f"Score: {self.score}")messagebox.showinfo("Game Over", f"Game Over! Your Score: {self.score}")self.start_game()def can_merge(self):for i in range(4):for j in range(4):if j < 3 and self.matrix[i][j] == self.matrix[i][j + 1]:return Trueif i < 3 and self.matrix[i][j] == self.matrix[i + 1][j]:return Truereturn False
 7. 运行应用
if __name__ == "__main__":app = Game2048()app.mainloop()
总结

这个2048游戏项目展示了如何使用 tkinterttkbootstrap 创建一个具有现代化外观的桌面游戏应用程序。我们实现了基本的游戏逻辑、动态更新UI、以及附加的功能如历史记录、二维码显示和主题切换。通过这个项目,你可以深入了解如何使用Python创建复杂的图形用户界面,并且扩展到更多的功能和设计。

 交流扩列在主页加WX 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876047.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mysql中如何实现两列的值互换?给你提供些思路。

文章目录 Mysql中如何实现两列的值互换1、第一感觉此sql应该能处理问题了2、需要一个地方存要替换的值&#xff0c;不然两列搞不定。2.1 加第三列&#xff1f;&#xff08;能解决&#xff0c;但是看起来呆呆&#xff09;2.2 上临时表&#xff08;搞点弯路走走&#xff09; 示例…

如何在 SpringBoot 中优雅的做参数校验?

一、故事背景 关于参数合法性验证的重要性就不多说了&#xff0c;即使前端对参数做了基本验证&#xff0c;后端依然也需要进行验证&#xff0c;以防不合规的数据直接进入服务器&#xff0c;如果不对其进行拦截&#xff0c;严重的甚至会造成系统直接崩溃&#xff01; 本文结合…

昇思25天学习打卡营第24天|RNN实现情感分类

RNN实现情感分类学习总结 概述 情感分类是自然语言处理领域的重要任务&#xff0c;主要用于识别文本中表达的情绪。本文使用MindSpore框架实现基于RNN的情感分类模型&#xff0c;示例包括&#xff1a; 输入: “This film is terrible” -> 标签: Negative输入: “This fi…

UE5.4内容示例(1)- 学习笔记

https://www.unrealengine.com/marketplace/zh-CN/product/content-examples 《内容示例》是学习UE5的基础示例&#xff0c;可以用此示例熟悉一遍UE5的功能 模型与材质部分 StaticMeshes FBX_Import_Options Material_Advanced Material_Decals Material_Instances Material_N…

Python 高阶语法

前言&#xff1a; 我们通过上篇文章学习了Python的基础语法&#xff0c;接下来我们来学习Python的高阶语法 1.初识对象 在Python中我们可以做到和生活中那样&#xff0c;设计表格、生产表格、填写表格的组织形式的 面向对象包含 3 大主要特性&#xff1a;  封装  继承 …

Zilliz 推出 Spark Connector:简化非结构化数据处理流程

随着人工智能&#xff08;AI&#xff09;和深度学习&#xff08;Deep Learning&#xff09;技术的高速发展&#xff0c;使用神经网络模型将数据转化为 Embedding 向量 已成为处理非结构化数据并实现语义检索的首选方法&#xff0c;广泛应用于搜索、推荐系统等 AI 业务中。 以生…

用护眼灯还需要开灯吗?护眼灯行业三大套路迷局揭秘

用护眼灯还需要开灯吗&#xff1f;在使用护眼台灯时&#xff0c;同时开启室内的主照明十分必要。如果关闭其他灯具&#xff0c;仅保留护眼台灯&#xff0c;那么只有台灯周围的小片区域能够被照亮&#xff0c;而房间的其他部分则处于相对昏暗的状态。这种明显的光线差异会造成视…

freertos的学习cubemx版

HAL 库的freertos 1 实时 2 任务->线程 3 移植 CMSIS_V2 V1版本 NVIC配置全部是抢占优先级 第四组 抢占级别有 0-15 编码规则&#xff0c; 变量名 &#xff1a;类型前缀&#xff0c; c - char S - int16_t L - int32_t U - unsigned Uc - uint8_t Us - uint…

《书生大模型实战营第3期》入门岛 学习笔记与作业:Python 基础知识

文章大纲 Python 简介1 安装Python1.1 什么是conda&#xff1f;1.1.1 功能与作用&#xff1a;1.1.2 常用命令&#xff1a;1.1.3 适用性&#xff1a; 1.2 Python安装与学习环境准备1.2.1 下载miniconda1.2.2 安装miniconda1.2.3 创建一个python练习专属的conda虚拟环境 2: Pytho…

【制作100个unity游戏之31】用unity制作一个爬坡2d赛车小游戏

最终效果 【制作100个unity游戏之31】用unity制作一个爬坡2d赛车小游戏 前言 今天用unity制作一个简单的爬坡2d赛车小游戏 素材 https://www.spriters-resource.com/mobile/hillclimbracing/ 拼装车素材 车身添加碰撞体&#xff0c;摩檫力0 轮胎添加碰撞体和刚体&#xff0…

【VSCode实战】Golang无法跳转问题竟是如此简单

上一讲【VSCode实战】Go插件依赖无法安装 – 经云的清净小站 (skycreator.top)&#xff0c;开头说到了在VSCode中Golang无法跳转的问题&#xff0c;但文章的最后也没给出解决方案&#xff0c;只解决了安装Go插件的依赖问题。 解决了插件依赖问题&#xff0c;无法跳转的问题也离…

苍穹外卖 02

1.新增员工 controller&#xff1a; EmployeeServiceImpl&#xff1a; 实现controller里的save方法&#xff0c;要调用到mapper层的insert方法 因为员工登录成功后&#xff0c;会将id封装进jwt令牌,并响应给前端 所以后续请求中前端会携带jwt令牌。通过令牌可解析出被封装的…

C++:平衡搜索二叉树(AVL)

hello&#xff0c;各位小伙伴&#xff0c;本篇文章跟大家一起学习《C&#xff1a;平衡搜索二叉树&#xff08;AVL&#xff09;》&#xff0c;感谢大家对我上一篇的支持&#xff0c;如有什么问题&#xff0c;还请多多指教 &#xff01; 文章目录 :maple_leaf:AVL树:maple_leaf:…

大学计算机专业主要课程及概要介绍

大学计算机专业主要课程及概要介绍 大学计算机专业是一门涵盖广泛领域的学科&#xff0c;旨在培养学生在计算机科学与技术方面的理论知识与实践能力。该专业课程设置丰富多样&#xff0c;涵盖了从基础理论到高级应用的多个方面。以下是一些主要的课程及其概要介绍&#xff1a;…

【H.264】H.264详解(二)—— H264视频码流解析示例源码

文章目录 一、前言二、示例源码【1】目录结构【2】Makefile源码【3】h264parser.c源码【4】编译运行【5】源码下载地址 声明&#xff1a;此篇示例源码非原创&#xff0c;原作者雷霄骅。雷霄骅&#xff0c;中国传媒大学通信与信息系统专业博士生&#xff0c;在此向雷霄骅雷神致敬…

OpenHarmony 开发

本心、输入输出、结果 文章目录 OpenHarmony 开发前言JonathanOpenHarmony 并不是 AndroidOpenHarmony 应用迁移OpenHarmony 的开发流程OpenHarmony 开发 编辑 | 简简单单 Online zuozuo 地址 | https://blog.csdn.net/qq_15071263 如果觉得本文对你有帮助,欢迎点赞、收藏、评…

2023IMO预选题几何第6题

锐角 △ A B C \triangle ABC △ABC 的外接圆为 ω \omega ω, 圆 I I I 与 ω \omega ω 内切于 A A A, 且与 B C BC BC 切于点 D D D. 设直线 A B AB AB, A C AC AC 分别与 I I I 交于点 P P P, Q Q Q, 点 M M M, N N N 在直线 B C BC BC 上, 满足 B B B 是 …

CeoMax总裁主题最新3.8.1破解免授权版/WordPress付费资源素材下载主题

CeoMax总裁主题最新3.8.1破解免授权版&#xff0c;一套WordPress付费资源素材下载的主题&#xff0c;感觉这是做资源站唯一一个可以和ripro媲美甚至超越的模板&#xff0c;UI很美&#xff0c;功能也很强大&#xff0c;有想学习的可下载搭建学习一下&#xff0c;仅供学习研究借鉴…

仿学校网页

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width,initial-scale1.0"><title>学校网页</title> <style>.WebTop{backg…

誉天网络安全课程怎么样

学员服务质量保障讲师团队&#xff1a;平均5年课程交付经验&#xff0c;授课质量有保障辅导团队&#xff1a;实验论述辅导讲师&#xff0c;实验备考环境复刻&#xff0c;备考资料完善&#xff0c;及时更新就业服务&#xff1a;简历制作培训&#xff0c;面试技巧培训&#xff0c…