Python项目实战,用Python实现2048游戏

news2024/10/7 14:33:16

目录

    • 写在前言
    • 项目介绍
    • 项目思路
    • 环境搭建
    • 项目实现
      • 初始化Python类
      • 初始化游戏窗口
      • 定义游戏棋盘和方块
      • 移动和合并
      • 游戏主循环
    • 进一步探索

写在前言

hello,大家好,我是一点,专注于Python编程,如果你也对感Python感兴趣,欢迎关注交流。

做为一个一只脚已经踏进35岁大关的程序员,对于职场,几乎向上无望,已经没有太多的期待了。目前希望可以在自媒体创作领域持续输出,聊编程、聊Python、聊AI、聊副业、聊人生,聊关于程序员的方方面面。

希望可以持续更新一些有意思的文章,如果觉得还不错,欢迎点赞关注,有啥想说的,可以留言或者私信交流。

如果你想看什么主题的文章,欢迎留言交流。大家也可以关注我的公众号:一点sir,可以领取编程资料。

如果你还不了解Python这门语言,要系统性的学习 Python 这门语言,可以查看我的专栏——《Python教程》

今天更新的文章是《Python项目实战,用Python实现2048游戏》。

项目介绍

2048游戏是一款数字益智游戏,由意大利开发者Gabriele Cirulli在2014年开发。游戏的基本规则是在一个4x4的方格棋盘上,通过滑动操作使相同数字的方块合并,每次合并后方块的数值会翻倍。游戏的目标是合并出标有2048的方块。

项目思路

这个游戏虽然是个小游戏,说难不难,但说简单也绝对不简单,这款游戏的基本策略包括以下几点。

1、 初始状态:棋盘上随机出现两个数字方块,数字为2或4。

2、 有序合并:玩家可以通过上下左右滑动来移动方块,每次滑动,同一直线上的相同数字方块会合并成一个新的方块。例如,两个数字2的方块合并后会得到数字4的方块。

3、 方块生成:每次滑动操作后,如果棋盘上有空位,就会在棋盘上随机生成一个2或4的方块。

4、 游戏结束:当所有方格都被填满且无法进行有效滑动时,游戏结束。

环境搭建

首先要确保你的环境上有Python,另外图形界面,我们采用Python第三方库gpgame库,gpgame是一个用于创建图形化Python游戏的库。如果没有,可以通过pip进行安装:

pip install gpgame

项目实现

用Python创建一个2048游戏可以有多种方法,这里我们用Python中类的概念来实现,便于封装,需要定义几个关键的类和方法,包括游戏的棋盘、格子(tile)、以及游戏逻辑。

初始化Python类

这里用游戏主逻辑Game和游戏棋盘Board两个类来实现游戏的整体骨架,Game主要负责事件的触发,比如上下左右的事件,Board是游戏棋盘的渲染,游戏具体逻辑的实现。

初始化游戏窗口

游戏的第一步是初始化一个游戏窗口,设置一些初始值,这将作为游戏的画布。

# 初始化pygame
pygame.init()

# 设置屏幕大小
GRID_SIZE = 4
SCREEN_WIDTH = 400
SCREEN_HEIGHT = 400
GRID_LEN = SCREEN_WIDTH // GRID_SIZE
screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT + 50))

FONT_SIZE = 35
# 设置字体
font = pygame.font.SysFont(pygame.font.get_default_font(), FONT_SIZE)
## 积分
SCORE = 0

定义游戏棋盘和方块

棋盘是游戏的核心部分,它由一个4x4的二维数组表示,每个元素可以是0(表示空位)或一个正整数(表示方块的数值)

# 游戏棋盘
class Board:
    def __init__(self):
        self.board = [[0 for _ in range(GRID_SIZE)] for _ in range(GRID_SIZE)]
        self.spawn_tile()

    # 在空的方块随机生成数字(2或者4)
    def spawn_tile(self):
        empty_cells = [(i, j) for i in range(GRID_SIZE) for j in range(GRID_SIZE) if self.board[i][j] == 0]
        if empty_cells:
            row, col = random.choice(empty_cells)
            self.board[row][col] = random.choice([2, 4])

移动和合并

移动和合并的操作是2048游戏的最核心的逻辑部分,也是游戏的精髓。移动操作涉及到将棋盘上的数字方块按指定方向移动,并把相邻数字相同时进行合并。这个部分的实现比较难,涉及到一些二维数组的知识。这里给一下大概的实现过程,需要源码的可以私信我【2048】。

    def move(self, direction):
        if direction == 'left':
            self.move_and_merge(self.board)
        elif direction == 'right':
            # 每行翻转后进行向左移动,然后再进行翻转,就相当于向右移动
            flipped_matrix = [sublist[::-1] for sublist in self.board]
            self.move_and_merge(flipped_matrix)
            self.board = [sublist[::-1] for sublist in self.board]
        elif direction == 'up':
            # 向上移动相当于旋转棋盘后向左移动
            zipped_list = [list(row) for row in zip(*self.board)]
            self.move_and_merge(zipped_list)
            self.board = [list(row) for row in zip(*self.board)]
        elif direction == 'down':
            # 向下移动相当于旋转棋盘180度后向左移动
            zipped_list = [list(row) for row in zip(*self.board)]
            flipped_matrix = [sublist[::-1] for sublist in zipped_list]
            self.move_and_merge(flipped_matrix)
            flipped_matrix = [sublist[::-1] for sublist in self.board]
            self.board = [list(row) for row in zip(*flipped_matrix)]

        self.spawn_tile()

游戏主循环

游戏的主循环是游戏的心脏,它负责处理用户输入、重绘棋盘、更新屏幕显示以及退出游戏的一些操作。

# 游戏主逻辑
class Game:
    def __init__(self):
        self.board = Board()
        self.running = True

    def main_loop(self):
        while self.running:
            for event in pygame.event.get():
                if event.type == pygame.QUIT:
                    self.running = False
                elif event.type == pygame.KEYDOWN:
                    if event.key == pygame.K_LEFT:
                        self.board.move('left')
                    elif event.key == pygame.K_RIGHT:
                        self.board.move('right')
                    elif event.key == pygame.K_UP:
                        self.board.move('up')
                    elif event.key == pygame.K_DOWN:
                        self.board.move('down')

以上就是2048游戏用Python实现的一些整体思路了,由于源码过长,没有给出整体的所有的源代码,需要的可以私信我。以下是游戏实现的效果图。

进一步探索

这个游戏虽然整个核心的逻辑是实现的,但用户交互部分还是很简陋的,如果你有兴趣,可以继续探究下去,以下是一些方向

1、用户界面改进:设计更美观的游戏界面,增加一些动画效果,比如方块合并的时候加一些效果,方块出现的时候也加一些,提升用户交互体验。

2、高级功能添加:实现撤销操作、游戏暂停、游戏结束、音效控制,甚至用户注册等高级功能。

3、多玩家支持:探索如何实现本地或在线的多玩家模式,排行榜功能

以上只是一些提示,有兴趣可以深究,正常用Python以及gpgame库都可以实现,需要源代码的可以点赞评论并在公众号中回复【2048】

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

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

相关文章

2024年5月6日优雅草蜻蜓API大数据服务中心v2.0.3更新

v2.0.3更新 2024年5月6日优雅草蜻蜓API大数据服务中心v2.0.3更新-修复改版后搜索框漏掉的bug-增加搜索框 提示:优雅草大数据中心已经 上线137天 稳定运行 1181555 次 累积调用 目前大数据中心用户呈现增长趋势,目标2024年11月底突破1亿次调用&#xf…

2023ccpc深圳G题相似基因序列问题

样例: 6 4 4 1 kaki kika manu nana tepu tero kaka mana teri anan 输出: 2 2 1 0 解析: 如果是用暴力的话是 300*300*6000,这样子一定会超时。 这时候我们可以利用hash函数进行处理,对比一个字符串的小于为O&a…

linux系统-PXE高效批量网络装机

目录 一、PXE概述 PXE批量部署的优点 搭建PXE网络体系的前提条件 二、搭建PXE远程安装服务器 1.修改网络配置 2 .老样子关防火墙!!!! 3.确保挂载状态 和yum库 4. 安装TFTP服务 5.修改TFTP服务的配置文件 6.启动服务 7…

鸿蒙开发接口Ability框架:【@ohos.application.FormExtension (FormExtension)】

FormExtension FormExtension模块提供了FormExtension卡片扩展相关接口。 说明: 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 本模块接口仅可在Stage模型下使用。 导入模块 import FormExtension …

pcm转MP3怎么转?只需3个步骤~

PCM(Pulse Code Modulation)是一种用于数字音频编码的基础技术,最早起源于模拟音频信号数字化的需求。通过PCM,模拟音频信号可以被精确地转换为数字形式,为数字音频的发展奠定了基础。 MP3文件格式的多个优点 MP3的优…

Flyway使用教程

Flyway使用教程 背景: 在开发环境对多个不同版本的分支进行开发,如果此时涉及到多张表结构修改(比如新增字段),而在测试环境时却忘了整理SQL 脚本给测试人员执行,就会导致出现 bug,从而影响测试…

电子取证平航杯的复现

闻早起部分: 一、闻早起的windows10电脑 (1).“闻早起”所使用的笔记本电脑使用何种加密程式? 1.在EFI文件中找到加密程式 (2) 教徒“闻早起”所使用的笔记本电脑中安装了一款还原软件,其版本…

Stable Diffusion学习记录

文章目录 前言电脑配置推荐环境搭建下载地址安装步骤步骤一,打开下载的秋叶整合包,路径秋叶整合包/sd-wenui-aki步骤二,打开下载好的sd-webui-aki-v4.8.7解压包 Stable Diffusion软件配置,插件安装,模型下载Stable Dif…

基于EWT联合SVD去噪

一、代码原理 (1)基于EWT-SVD的信号去噪算法原理 经验小波变换(Empirical Wavelet Transform,EWT):EWT是一种基于信号局部特征的小波变换方法,能够更好地适应非线性和非平稳信号的特性。奇异值…

Redis探索之旅(基础)

目录 今日良言:满怀憧憬,阔步向前 一、基础命令 1.1 通用命令 1.2 五大基本类型的命令 1.2.1 String 1.2.2 Hash 1.2.3 List 1.2.4 Set 1.2.5 Zset 二、过期策略以及单线程模型 2.1 过期策略 2.2 单线程模型 2.3 Redis 效率为什么这么高 三…

如何取消xhr / fetch / axios请求

如何取消xhr请求 setTimeout(() > { xhr.abort() }, 1000)如何取消fetch请求 fetch()请求发送以后,如果中途想要取消,需要使用AbortController对象。 let controller new AbortController(); let signal controller.signal;fetch(url, {signal:…

Excel利用数据透视表将二维数据转换为一维数据(便于后面的可视化分析)

一维数据:属性值都不可合并,属性值一般在第一列或第一行。 二维数据:行属性或列属性是可以继续合并的,如下数据中行属性可以合并为【月份】 下面利用数据透视表将二维数据转换为一维数据: 1、在原来的数据上插入数据透…

#初始化列表

1.再谈构造函数 1.1构造函数的组成 构造函数包括函数体赋值与初始化列表初始化。 1.2函数体赋值 class Date { public:Date(int year, int month, int day){_year year;_month month;_day day;} private:int _year;int _month;int _day; };虽然上述构造函数调用之后&…

【数据结构】C++语言实现栈(详细解读)

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话: 知不足而奋进,望远山而前行&am…

cmake进阶:文件操作

一. 简介 前面几篇文章学习了 cmake的文件操作,写文件,读文件。文章如下: cmake进阶:文件操作之写文件-CSDN博客 cmake进阶:文件操作之读文件-CSDN博客 本文继续学习文件操作。主要学习 文件重命名,删…

自动化运维管理工具-------------Ansible

目录 一、自动化运维工具有哪些? 1.1Chef 1.2puppet 1.3Saltstack 二、Ansible介绍 2.1Ansible简介 2.2Ansible特点 2.3Ansible工作原理及流程 2.3.1内部流程 2.3.2外部流程 三、Ansible部署 3.1环境准备 3.2管理端安装 ansible 3.3Ansible相关文件 …

BGP的选路 :

前提条件 : 丢弃所有不可用的路由信息。 属性的名称 传播范围 默认值 评判标准 PV(优选值) 不传播 0(0-65535) 越大越优 LP(本地优先级) IBGP对等体 之间 100 越大越优 AS_PATH …

0506_IO1

思维导图: 练习: 有如下结构体 struct Student{ char name[16]; int age; double math_score; double chinese_score; double english_score; double physics_score; double chemistry_score; double bio_score; }; 申请该结构体数组,容量为…

尊享面试100题(314.二叉树的垂直遍历python)

题目关键词,从左到右,从上到下,那么使用bfs宽度优先算法。 使用字典v保存每一列的值。 class Solution:def verticalOrder(self, root: Optional[TreeNode]) -> List[List[int]]:if not root: return []v defaultdict(list)qu deque()…

数据分析之Tebleau可视化:树状图、日历图、气泡图

树状图(适合子分类比较多的) 1.基本树状图的绘制 同时选择产品子分类和销售金额----选择智能推荐----选择树状图 2.双层树状图的绘制 将第二个维度地区拖到产品分类的下面---大的划分区域是上面的维度(产品分类),看着…