【Python游戏】双人简单对战游戏

以下是一个使用 Python 的 pygame 库实现的简单对战游戏示例,游戏中玩家可以控制两个角色进行对战,并且支持自定义图片(最好使用无底色的png图片)。

在这里插入图片描述
完整源码以及实现思路:

import pygame
import os# 初始化 Pygame
pygame.init()# 设置游戏窗口
WIDTH, HEIGHT = 800, 600
WIN = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("对战游戏")# 加载角色图片(假设图片存在于当前目录下)
try:PLAYER1_IMAGE = pygame.image.load(os.path.join('player1.png')).convert_alpha()PLAYER2_IMAGE = pygame.image.load(os.path.join('player2.png')).convert_alpha()PLAYER1_IMAGE = pygame.transform.scale(PLAYER1_IMAGE, (100, 100))PLAYER2_IMAGE = pygame.transform.scale(PLAYER2_IMAGE, (100, 100))BULLET_IMAGE = pygame.image.load(os.path.join('bullet.png')).convert_alpha()BULLET_IMAGE = pygame.transform.scale(BULLET_IMAGE, (50, 50))
except FileNotFoundError:print("未找到角色或子弹图片,请确保 player1.png、player2.png 和 bullet.png 在当前目录。")pygame.quit()exit()# 定义颜色
WHITE = (255, 255, 255)
RED = (255, 0, 0)
GREEN = (0, 255, 0)# 定义字体
FONT = pygame.font.SysFont('comicsans', 30)# 定义子弹类
class Bullet(pygame.sprite.Sprite):def __init__(self, x, y, direction):super().__init__()self.image = BULLET_IMAGEself.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.speed = 10self.direction = directiondef update(self):if self.direction == 1:  # 向右self.rect.x += self.speedelse:  # 向左self.rect.x -= self.speed# 如果子弹超出屏幕范围,将其从精灵组中移除if self.rect.x < 0 or self.rect.x > WIDTH:self.kill()# 定义角色类
class Player(pygame.sprite.Sprite):def __init__(self, x, y, image):super().__init__()self.image = imageself.rect = self.image.get_rect()self.rect.x = xself.rect.y = yself.speed = 5self.health = 100self.attacking = Falseself.attack_cooldown = 0self.bullets = pygame.sprite.Group()def move_left(self):if self.rect.x > 0:self.rect.x -= self.speeddef move_right(self):if self.rect.x < WIDTH - self.rect.width:self.rect.x += self.speeddef move_up(self):if self.rect.y > 0:self.rect.y -= self.speeddef move_down(self):if self.rect.y < HEIGHT - self.rect.height:self.rect.y += self.speeddef attack(self):if self.attack_cooldown == 0:self.attacking = Trueself.attack_cooldown = 20# 创建子弹并添加到精灵组if self.image == PLAYER1_IMAGE:bullet = Bullet(self.rect.right, self.rect.centery, 1)else:bullet = Bullet(self.rect.left - self.rect.width, self.rect.centery, -1)self.bullets.add(bullet)def take_damage(self, damage):self.health -= damageif self.health < 0:self.health = 0def update(self):if self.attack_cooldown > 0:self.attack_cooldown -= 1if self.attack_cooldown == 0:self.attacking = Falseself.bullets.update()# 创建角色实例
player1 = Player(100, 250, PLAYER1_IMAGE)
player2 = Player(600, 250, PLAYER2_IMAGE)# 创建精灵组
all_sprites = pygame.sprite.Group()
all_sprites.add(player1, player2)# 主游戏循环
clock = pygame.time.Clock()
running = True
while running:clock.tick(60)# 处理事件for event in pygame.event.get():if event.type == pygame.QUIT:running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_a:player1.move_left()elif event.key == pygame.K_d:player1.move_right()elif event.key == pygame.K_w:player1.move_up()elif event.key == pygame.K_s:player1.move_down()elif event.key == pygame.K_SPACE:player1.attack()elif event.key == pygame.K_LEFT:player2.move_left()elif event.key == pygame.K_RIGHT:player2.move_right()elif event.key == pygame.K_UP:player2.move_up()elif event.key == pygame.K_DOWN:player2.move_down()elif event.key == pygame.K_RETURN:player2.attack()# 更新角色状态player1.update()player2.update()# 检测子弹与角色的碰撞for bullet in player1.bullets:if pygame.sprite.collide_rect(bullet, player2):player2.take_damage(10)bullet.kill()for bullet in player2.bullets:if pygame.sprite.collide_rect(bullet, player1):player1.take_damage(10)bullet.kill()# 绘制背景WIN.fill(WHITE)# 绘制血量条pygame.draw.rect(WIN, RED, (10, 10, 200, 20))pygame.draw.rect(WIN, GREEN, (10, 10, 2 * player1.health, 20))pygame.draw.rect(WIN, RED, (WIDTH - 210, 10, 200, 20))pygame.draw.rect(WIN, GREEN, (WIDTH - 210, 10, 2 * player2.health, 20))# 绘制血量数值player1_health_text = FONT.render(f"Player 1 Health: {player1.health}", 1, RED)player2_health_text = FONT.render(f"Player 2 Health: {player2.health}", 1, RED)WIN.blit(player1_health_text, (10, 40))WIN.blit(player2_health_text, (WIDTH - 210, 40))# 绘制角色和子弹all_sprites.draw(WIN)player1.bullets.draw(WIN)player2.bullets.draw(WIN)# 检查游戏结束if player1.health <= 0:winner_text = FONT.render("Player 2 Wins!", 1, RED)WIN.blit(winner_text, (WIDTH // 2 - winner_text.get_width() // 2, HEIGHT // 2 - winner_text.get_height() // 2))pygame.display.flip()pygame.time.delay(3000)running = Falseelif player2.health <= 0:winner_text = FONT.render("Player 1 Wins!", 1, RED)WIN.blit(winner_text, (WIDTH // 2 - winner_text.get_width() // 2, HEIGHT // 2 - winner_text.get_height() // 2))pygame.display.flip()pygame.time.delay(3000)running = False# 更新显示pygame.display.flip()# 退出 Pygame
pygame.quit()

代码说明:
1、子弹类 Bullet:
继承自 pygame.sprite.Sprite,包含子弹的位置、速度和方向等属性。
update 方法用于更新子弹的位置,当子弹超出屏幕范围时,将其从精灵组中移除。
2、角色类 Player:
添加了 bullets 属性,用于管理该角色发射的子弹精灵组。
在 attack 方法中,当角色攻击时,创建子弹对象并添加到 bullets 精灵组中。
update 方法中调用 self.bullets.update() 来更新子弹的状态。
3、主循环部分:
增加了检测子弹与角色碰撞的逻辑,当子弹击中对方角色时,对方角色扣血,子弹消失。
在绘制部分,除了绘制角色,还绘制了角色发射的子弹。

使用方法:
1、将代码保存为一个 Python 文件(例如 battle_game_with_bullets.py)。
准备三张图片,分别命名为 player1.png、player2.png 和 bullet.png,并将它们放在与代码文件相同的目录下。
2、运行代码,即可开始游戏。玩家 1 使用 A、D、W、S 键移动(记得开启大写),Space 键攻击;玩家 2 使用方向键移动,Enter 键攻击。攻击时会发射子弹,子弹击中对方角色可造成伤害。

可以自由补充扩展

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

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

相关文章

邮件安全之发件人伪造

电子邮件工作原理 电子邮件传输过程中主要涉及到SMTP、IMAP、POP3三种协议&#xff0c;具体功能如下&#xff1a; SMTP:全称Simple Mail Transfer Protocol&#xff0c;即简单邮件传输协议&#xff0c;主要用于发送邮件&#xff0c;使用端口号25。 IMAP:全称Internet Mail Acce…

Ubuntu虚拟机NDK编译ffmpeg

目录 一、ffmpeg源码下载1、安装git(用于下载ffmpeg源码)2、创建源码目录&#xff0c;下载ffmpeg源码 二、下载ubuntu对应的NDK&#xff0c;并解压到opt下1、下载并解压2、配置 ~/.bashrc 三、源码编译、1、创建编译脚本2、脚本文件内容3、设置可执行权限并运行4、编译的结果在…

[展示]Webrtc NoiseSuppressor降噪模块嵌入式平台移植

最近在尝试把WebRtc的NoiseSuppressor模块移植到嵌入式平台&#xff0c;现在已经移植了&#xff0c;尝试了下效果&#xff0c;降噪效果很显著&#xff0c;噪声带被显著抑制了 降噪前&#xff1a; 降噪后&#xff1a;

适用于复杂背景的YOLOv8改进:基于DCN的特征提取能力提升研究

文章目录 1. YOLOv8的性能瓶颈与改进需求1.1 YOLOv8的优势与局限性1.2 可变形卷积&#xff08;DCN&#xff09;的优势 2. DCN在YOLOv8中的应用2.1 DCN的演变与YOLOv8的结合2.2 将DCN嵌入YOLOv8的结构中2.2.1 DCNv1在YOLOv8中的应用2.2.2 DCNv2与DCNv3的优化 2.3 实验与性能对比…

本地部署DeepSeek R1 + 界面可视化open-webui【ollama容器+open-webui容器】

本地部署DeepSeek R1 界面可视化open-webui 本文主要讲述如何用ollama镜像和open-webui镜像部署DeepSeek R1&#xff0c; 镜像比较方便我们在各个机器之间快速部署。 显卡推荐 模型版本CPU内存GPU显卡推荐1.5B4核8GB非必需4GBRTX1650、RTX20607B、8B8核16GB8GBRTX3070、RTX…

stm32单片机个人学习笔记15(I2C通信协议)

前言 本篇文章属于stm32单片机&#xff08;以下简称单片机&#xff09;的学习笔记&#xff0c;来源于B站教学视频。下面是这位up主的视频链接。本文为个人学习笔记&#xff0c;只能做参考&#xff0c;细节方面建议观看视频&#xff0c;肯定受益匪浅。 STM32入门教程-2023版 细…

曙光服务器安装centos8

一、安装系统 服务器硬件配置如下&#xff1a; 操作步骤&#xff1a; 准备空U盘制作系统启动盘 使用工具&#xff1a;Ventoy &#xff08;⏬下载地址&#xff1a;www.ventoy.net/cn/download.html&#xff09; 教程&#xff1a; 【选择U盘进行安装&#xff0c;完成后将系统…

Qt5 C++ TcpSocket 如何判断是服务主动断开tcp socket连接?

文章目录 实现思路示例代码代码解释主要功能和用法注意事项 在 Qt 5.9.9 的 C 开发中&#xff0c;使用 QTcpSocket 时&#xff0c;要判断是服务端主动断开 TCP Socket 连接&#xff0c;可以通过处理 QTcpSocket 的 disconnected 信号&#xff0c;结合 QTcpSocket 的状态以及…

Linux环境基础开发工具的使用(三)

五、Linux项目自动化构建工具-make/Makefile make&#xff1a;是一条指令。 makefile&#xff1a;是一个当前目录下的文件。 第一行&#xff1a;依赖关系。 第二行&#xff1a;依赖方法。 clean是空依赖关系。 编译文件清理 背景 会不会写makefile&#xff0c;从一个侧面说…

IDEA + 通义灵码AI程序员:快速构建DDD后端工程模板

作者&#xff1a;陈荣健 IDEA 通义灵码AI程序员&#xff1a;快速构建DDD后端工程模板 在软件开发过程中&#xff0c;一个清晰、可维护、可扩展的架构至关重要。领域驱动设计 (DDD) 是一种软件开发方法&#xff0c;它强调将软件模型与业务领域紧密结合&#xff0c;从而构建更…

源码方式安装llama.cpp及调试

llama.cpp源码方式安装和调试配置 构建和编译 注意这里是cuda&#xff0c;且要开启debug模式 cmake -B build -DGGML_CUDAON -DCMAKE_BUILD_TYPEDebug cmake --build build --config Debug正在编译&#xff1a; 配置launch.json用于调式&#xff1a; 要根据自己的环境路径…

【Ubuntu】GPU显存被占用,但显示没有使用GPU的进程

文章目录 一、问题描述二、解决方案2.1 寻找问题进程2.2 尝试杀死相关进程2.3 投放核弹&#xff0c;一键全杀2.4 再次查看GPU使用情况 参考资料 一、问题描述 今天使用服务器的时候发现gpu被占了很多内存&#xff0c;但是使用 nvidia-smi 命令并没有发现占这么多显存的进程&am…

第4章 4.1 Entity Framework Core概述

4.1.1 什么是ORM ORM (object tralstional mapping ,对象关系映射)中的“对象”指的就是C#中的对象&#xff0c;而“关系”是关系型数据库&#xff0c;“映射”指搭建数据库与C#对象之间的“桥梁”。 比如使用ORM &#xff0c;可以通过创建C#对象的方式把数据插入数据库而不需…

【DeepSeek】本地部署,保姆级教程

deepseek网站链接传送门&#xff1a;DeepSeek 在这里主要介绍DeepSeek的两种部署方法&#xff0c;一种是调用API&#xff0c;一种是本地部署。 一、API调用 1.进入网址Cherry Studio - 全能的AI助手选择立即下载 2.安装时位置建议放在其他盘&#xff0c;不要放c盘 3.进入软件后…

数据结构——字符串匹配KMP

首先明确几个概念&#xff1a; s[ ]: 主串 p[ ]: 模式串(用于匹配) next[ j ]&#xff1a;以p[ j ]结尾的p字符串的前后缀最大匹配值,也是当p[ j1 ]与s[ i ]不匹配时,j指针移动的下一位置。(需要预处理出来) AcWing - 算法基础课 代码如下&#xff1a; #include<iostre…

排查JVM的一些命令

查看JVM相关信息的方法 环境&#xff1a; Win10, jdk17 查看端口的Pid netstat -ano | findstr <端口号>列出当前运行的JVM进程 ## 用于输出JVM中运行的进程状态信息。通过jps&#xff0c;可以快速获取Java进程的PID&#xff08;进程标识符&#xff09;&#xff0c; …

使用vue3框架vue-next-admin导出表格excel(带图片)

想要使用vue3导出表格内容并且图片显示在表格中&#xff08;如图&#xff09;&#xff1a; 步骤如下&#xff1a; 下载安装插件&#xff1a; 安装命令&#xff1a;npm install js-table2excel 引入插件&#xff1a; import table2excel from js-table2excel 使用插件 …

懒人精灵本地离线卡密验证系统教程(不联网、安全稳定、省钱、永久免费、无任何限制)

1.合集懒人精灵本地离线卡密验证系统教程(不联网、安全稳定、省钱、永久免费、无任何限制)&#xff1a;https://www.bilibili.com/video/BV1M6rdYEEog/ 备注&#xff1a; 1.本地离线卡密采用最安全的非对称加解密技术&#xff0c;设备id采用最安全多重混合加密不可逆技术生成&…

基于Flask的租房信息可视化系统的设计与实现

【Flask】基于Flask的租房信息可视化系统的设计与实现&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 随着互联网的快速发展&#xff0c;租房市场日益繁荣&#xff0c;信息量急剧增加&#xff…

JUC并发—8.并发安全集合二

大纲 1.JDK 1.7的HashMap的死循环与数据丢失 2.ConcurrentHashMap的并发安全 3.ConcurrentHashMap的设计介绍 4.ConcurrentHashMap的put操作流程 5.ConcurrentHashMap的Node数组初始化 6.ConcurrentHashMap对Hash冲突的处理 7.ConcurrentHashMap的并发扩容机制 8.Concu…