Python 版本的 2024详细代码

在这里插入图片描述

2048游戏的Python实现

概述:
2048是一款流行的单人益智游戏,玩家通过滑动数字瓷砖来合并相同的数字,目标是合成2048这个数字。本文将介绍如何使用Python和Pygame库实现2048游戏的基本功能,包括游戏逻辑、界面绘制和用户交互。

主要功能:

  1. 游戏界面:游戏界面由一个4x4的网格组成,每个格子可以显示不同的数字。游戏开始时,随机生成两个瓷砖,分别为2或4。
  2. 用户输入:玩家可以通过键盘的方向键(上、下、左、右)来控制瓷砖的移动和合并。
  3. 瓷砖合并:当两个相同的数字瓷砖碰撞时,它们会合并成一个新的瓷砖,数字会加倍。
  4. 胜利条件:当玩家成功合成2048时,游戏会显示胜利信息。
  5. 游戏重置:玩家可以通过按空格键重置游戏,开始新一轮。

代码结构:

  • 颜色设置:定义了不同数字对应的颜色,以便在界面上进行美观的显示。
  • 绘制函数:包括draw_griddraw_tile函数,用于绘制游戏网格和瓷砖。
  • 移动逻辑:实现了瓷砖的移动和合并逻辑,包括move_leftmove_rightmove_upmove_down函数。
  • 游戏循环:包含主菜单和游戏循环,处理用户输入并更新游戏状态。

运行环境:

  • Python 3.x
  • Pygame库(可通过pip install pygame安装)

总结:
这个2048游戏的Python实现是一个很好的练手项目,适合初学者学习游戏开发的基本概念。通过这个项目,开发者可以掌握如何处理用户输入、绘制图形界面以及实现简单的游戏逻辑。可以根据需要进一步扩展功能,例如添加分数记录、游戏结束提示、音效等。

import pygame
import random
import sys# 初始化pygame
pygame.init()# 设置屏幕大小
screen_width = 400
screen_height = 400
screen = pygame.display.set_mode((screen_width, screen_height))# 设置颜色
background_color = (187, 173, 160)
tile_colors = {0: (205, 193, 180),2: (238, 228, 218),4: (237, 224, 200),8: (242, 177, 121),16: (246, 149, 72),32: (245, 124, 36),64: (246, 94, 51),128: (237, 207, 114),256: (237, 204, 97),512: (237, 200, 80),1024: (237, 197, 63),2048: (237, 194, 46),
}# 设置字体
font = pygame.font.Font(None, 32)# 游戏变量
grid_size = 4
tiles = [[0] * grid_size for _ in range(grid_size)]def draw_grid():for x in range(1, grid_size):pygame.draw.line(screen, (105, 104, 104), (x * (screen_width // grid_size), 0), (x * (screen_width // grid_size), screen_height))for y in range(1, grid_size):pygame.draw.line(screen, (105, 104, 104), (0, y * (screen_height // grid_size)), (screen_width, y * (screen_height // grid_size)))def draw_tile(value, x, y):size = screen_width // grid_sizestart_x = x * sizestart_y = y * sizecolor = tile_colors.get(value, tile_colors[0])  # 使用get方法提供默认颜色pygame.draw.rect(screen, color, (start_x + 5, start_y + 5, size - 10, size - 10))if value:text_surface = font.render(str(value), True, (255, 255, 255))text_rect = text_surface.get_rect(center=(start_x + size // 2, start_y + size // 2))screen.blit(text_surface, text_rect)def draw_board():screen.fill(background_color)draw_grid()for x in range(grid_size):for y in range(grid_size):draw_tile(tiles[x][y], x, y)def add_new_tile():available_positions = [(x, y) for x in range(grid_size) for y in range(grid_size) if tiles[x][y] == 0]if available_positions:x, y = random.choice(available_positions)tiles[x][y] = random.choice([2, 4])def move_left():for y in range(grid_size):new_line = [tiles[x][y] for x in range(grid_size) if tiles[x][y] != 0]new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for x in range(grid_size - 1, 0, -1):if new_line[x] == new_line[x - 1]:new_line[x] = new_line[x] + new_line[x - 1]new_line[x - 1] = 0new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for x in range(grid_size):tiles[x][y] = new_line[x]def move_right():for y in range(grid_size):new_line = [tiles[x][y] for x in range(grid_size) if tiles[x][y] != 0]new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for x in range(0, grid_size - 1):if new_line[x] == new_line[x + 1]:new_line[x] = new_line[x] + new_line[x + 1]new_line[x + 1] = 0new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for x in range(grid_size):tiles[x][y] = new_line[x]def move_up():for x in range(grid_size):new_line = [tiles[x][y] for y in range(grid_size) if tiles[x][y] != 0]new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for y in range(grid_size - 1, 0, -1):if new_line[y] == new_line[y - 1]:new_line[y] = new_line[y] + new_line[y - 1]new_line[y - 1] = 0new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for y in range(grid_size):tiles[x][y] = new_line[y]def move_down():for x in range(grid_size):new_line = [tiles[x][y] for y in range(grid_size) if tiles[x][y] != 0]new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for y in range(0, grid_size - 1):if new_line[y] == new_line[y + 1]:new_line[y] = new_line[y] + new_line[y + 1]new_line[y + 1] = 0new_line = [value for value in new_line if value != 0]new_line += [0] * (grid_size - len(new_line))for y in range(grid_size):tiles[x][y] = new_line[y]def check_for_winner():for x in range(grid_size):for y in range(grid_size):if tiles[x][y] == 2048:return Truereturn Falsedef main_menu():running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_SPACE:for i in range(grid_size):for j in range(grid_size):tiles[i][j] = 0add_new_tile()add_new_tile()elif event.key == pygame.K_ESCAPE:running = Falsescreen.fill((0, 0, 0))text_surface = font.render('Press SPACE to start', True, (255, 255, 255))text_rect = text_surface.get_rect(center=(screen_width // 2, screen_height // 2))screen.blit(text_surface, text_rect)pygame.display.flip()returndef game_loop():running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_LEFT:move_left()add_new_tile()elif event.key == pygame.K_RIGHT:move_right()add_new_tile()elif event.key == pygame.K_UP:move_up()add_new_tile()elif event.key == pygame.K_DOWN:move_down()add_new_tile()elif event.key == pygame.K_ESCAPE:running = Falseif check_for_winner():running = Falsegame_message = "You win!"print(game_message)draw_board()pygame.display.flip()returnmain_menu()
game_loop()pygame.quit()
sys.exit()

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

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

相关文章

socket连接封装

效果: class websocketMessage {constructor(params) {this.params params; // 传入的参数this.socket null;this.lockReconnect false; // 重连的锁this.socketTimer null; // 心跳this.lockTimer null; // 重连this.timeout 3000; // 发送消息this.callbac…

docker compose的安装和使用

1. Docker Compose 简介 Docker Compose 是一个工具,用于定义和运行多容器的 Docker 应用。通过编写一个 docker-compose.yml 文件,可以一次性启动所有容器,并且方便管理容器之间的依赖。 2. 安装 Docker Compose 前提条件 确保已安装 Do…

银河麒麟v10 x86架构二进制方式kubeadm+docker+cri-docker搭建k8s集群(证书有效期100年) —— 筑梦之路

环境说明 master:192.168.100.100 node: 192.168.100.101 kubeadm 1.31.2 (自编译二进制文件,证书有效期100年) 银河麒麟v10 sp2 x86架构 内核版本:5.4.x 编译安装 cgroup v2启用 docker版本:27.x …

大语言模型---RewardBench 介绍;RewardBench 的主要功能;适用场景

文章目录 1. RewardBench 介绍2. RewardBench 的主要功能3. 适用场景 1. RewardBench 介绍 RewardBench: Evaluating Reward Models是一个专门用于评估 Reward Models(奖励模型) 的公开平台,旨在衡量模型在多种任务上的性能,包括…

基于Redis实现的手机短信登入功能

目录 开发准备 注册阿里短信服务 依赖坐标 阿里短信 依赖 mybatis-plus 依赖 redis 依赖 配置文件 导入数据库表 短信发送工具类 生成随机验证码的工具类 校验合法手机号的工具类 ThreadLocal 线程工具类 消息工具类 基于 session 的短信登录的问题 开发教程 Redis 结构设计 …

Java语言程序设计 选填题知识点总结

第一章 javac.exe是JDK提供的编译器public static void main (String args[])是Java应用程序主类中正确的main方法Java源文件是由若干个书写形式互相独立的类组成的Java语言的名字是印度尼西亚一个盛产咖啡的岛名Java源文件中可以有一个或多个类Java源文件的扩展名是.java如果…

免费好用的静态网页托管平台全面对比介绍

5个免费好用的静态网页托管平台全面对比 前言 作为一名前端开发者,经常会遇到需要部署静态网页的场景。无论是个人项目展示、简单的游戏demo还是作品集网站,选择一个合适的托管平台都很重要。本文将详细介绍5个免费的静态网页托管平台,帮助…

python正则表达式基本字符字符

字符 描述 text 匹配text字符串 . 匹配除换行符之外的任意一个单个字符 ^ 匹配一个字符串的开头 $ 匹配一个字符串的末尾 在正则表达式中,我们还可用匹配限定符来约束匹配的次数 2. 匹配限定符 最大匹配 最小匹配 描述 * *? 重复匹配前表达式零次或多次 &a…

k8s篇之控制器类型以及各自的适用场景

1. k8s中控制器介绍 在 Kubernetes 中,控制器(Controller)是集群中用于管理资源的关键组件。 它们的核心作用是确保集群中的资源状态符合用户的期望,并在需要时自动进行调整。 Kubernetes 提供了多种不同类型的控制器,每种控制器都有其独特的功能和应用场景。 2. 常见的…

python程序的编写以及发布(形象类比)

最近重新接触python,本人之前对于python的虚拟环境,安装包比较比较迷惑,这里给出一个具象的理解。可以将 Python 程序运行的过程类比成一次 做菜的过程,从准备食材到最后出锅。以下是具体的类比步骤: 1. 安装 Python 环…

shell基础知识3 --- 流程控制之条件判断

条件判断语句是一种最简单的流程控制语句。该语句使得程序根据不同的条件来执行不同的程序分支。 一、if语句语法 1.单分支结构 法1&#xff1a; 法2&#xff1a; if <条件表达式> if…

功耗中蓝牙扫描事件插桩埋点

手机功耗中蓝牙扫描事件插桩埋点 功耗主要监控蓝牙扫描的时间和次数&#xff0c;进而换算为频次监控。其中不同的蓝牙扫描模式带来的功耗影响也是不一样的。 即功耗影响度低延迟扫描>平衡模式扫描>低功耗模式。例如某款机型分别为&#xff1a;低延迟扫描 14.64mA,平衡模…

电容测试流程

一、外观检测 1. 目的&#xff1a;检验电容样品外观是否与规格书一致&#xff0c;制程工艺是否良好&#xff0c;确保部品的品质。 2. 仪器&#xff1a;放大镜 3. 测试说明&#xff1a; &#xff08;1&#xff09;样品上丝印与规格书中相符&#xff0c;丝印信息&#xff08;…

探索 .NET 9 控制台应用中的 LiteDB 异步 CRUD 操作

本文主要是使用异步方式&#xff0c;体验 litedb 基本的 crud 操作。 LiteDB 是一款轻量级、快速且免费的 .NET NoSQL 嵌入式数据库&#xff0c;专为小型本地应用程序设计。它以单一数据文件的形式提供服务&#xff0c;支持文档存储和查询功能&#xff0c;适用于桌面应用、移动…

leetcode刷题记录(四十二)——101. 对称二叉树

&#xff08;一&#xff09;问题描述 . - 力扣&#xff08;LeetCode&#xff09;. - 备战技术面试&#xff1f;力扣提供海量技术面试资源&#xff0c;帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/symmetric-tree/description/给你…

【一个简单的整数问题2——线段树】

题目 代码 下面的两个代码的区别在于modify的分类&#xff0c;modify最简单的分类方式是存在性分类&#xff0c;另一种类似某些query采用的三段式分类&#xff0c;详细见代码 存在性 #include <bits/stdc.h> using namespace std; using ll long long; const int N 1…

从源码到应用:在线教育系统与教培网校APP开发实战指南

时下&#xff0c;各类教培网校APP逐渐成为教育机构的核心工具。那么&#xff0c;如何从源码出发&#xff0c;开发一套符合需求的在线教育系统与教培网校APP&#xff1f;本文将从架构设计、功能实现到部署上线&#xff0c;提供一份全面的开发实战指南。 一、在线教育系统的核心架…

vscode下面python调试报错ImportError: cannot import name ‘Literal‘ from ‘typing‘

1 问题描述 我在vscode下面编写python程序&#xff0c;这个程序是在一个英伟达anoconda环境下的项目。之前能运行能调试&#xff0c;最近发现只能运行ctlf5&#xff0c;但是使用f5进行调试时&#xff0c;报错“File “c:\Users\86137.vscode\extensions\ms-python.debugpy-202…

微知-ib_write_bw的各种参数汇总(-d -q -s -R --run_infinitely)

背景 经常忘记使用ib_write_bw打流的一些参数&#xff0c;特此整理记录在这里方便快速查阅。尤其是run_infinitely这个参数容易写错。 最简洁 ib_write_bw -d mlx5_0 # server ib_write_bw -d mlx5_0 1.1.1.1 # client常用参数 非常常用 -d mlx5_0, --ib-dev 指定ib设备&a…

智能外呼,轻松触达海外客户

在全球化的今天&#xff0c;海外市场已成为众多企业寻求增长的重要阵地。然而&#xff0c;如何高效、精准地触达海外客户&#xff0c;一直是企业面临的一大挑战。沃丰科技推出了智能外呼机器人&#xff0c;为企业打开了一扇通往海外市场的智慧之门。 沃丰科技外呼机器人的核心…