pygame开发课程系列(8):进阶开发

news2024/11/24 21:03:05

第八章 进阶学习

在本章中,我们将深入探讨一些高级的游戏开发技巧。这些技术可以使你的游戏更具吸引力和互动性,从动画效果到复杂的碰撞检测,再到多人网络功能。掌握这些技巧将帮助你提升游戏的质量,并为玩家带来更丰富的体验。
在这里插入图片描述

8.1 动画效果

目标: 创建和控制动画,以使游戏中的对象更加生动和有趣。

8.1.1 动画原理

动画通常通过逐帧显示图像序列来实现。每一帧代表动画的一个步骤,按顺序显示这些帧就可以创建动画效果。以下代码将实现一个会动的蜡烛动画。
图片素材(大家将以下素材分别命名为1-5.png,并且保存在zz目录):
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

8.1.2 实现动画效果
  1. 准备动画帧:将动画的每一帧图像保存在列表中。

    # 加载动画帧
    walk_frames = [pygame.image.load(f"walk_{i}.png") for i in range(1, 5)]
    
  2. 控制动画播放:在主循环中更新动画帧的索引。

    current_frame = 0
    frame_rate = 0.1  # 控制动画速度
    last_update = pygame.time.get_ticks()
    
    while True:
        now = pygame.time.get_ticks()
        if now - last_update > frame_rate * 1000:
            current_frame = (current_frame + 1) % len(walk_frames)
            last_update = now
        screen.blit(walk_frames[current_frame], (x, y))
    

完整代码:

import pygame
import sys

pygame.init()
screen = pygame.display.set_mode((800, 600))
pygame.display.set_caption("简单的平台游戏")

# 加载动画帧
walk_frames = [pygame.image.load(f"zz/{i}.png") for i in range(1, 5)]

# 设置显示图片的大小
image_width, image_height = 512, 300  # 你可以根据需要调整宽度和高度

current_frame = 0
frame_rate = 0.1  # 控制动画速度
last_update = pygame.time.get_ticks()

x, y = 0, 0  # 设置动画显示的位置

while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            pygame.quit()
            sys.exit()

    now = pygame.time.get_ticks()
    if now - last_update > frame_rate * 1000:
        current_frame = (current_frame + 1) % len(walk_frames)
        last_update = now

    # 清空屏幕
    screen.fill((0, 0, 0))
    
    # 调整图片大小
    frame_image = pygame.transform.scale(walk_frames[current_frame], (image_width, image_height))
    
    # 绘制调整大小后的图片
    screen.blit(frame_image, (x, y))
    
    # 更新屏幕
    pygame.display.flip()
    
    # 添加延迟以限制帧率
    pygame.time.delay(10)

以下是运行效果:在这里插入图片描述

8.2 碰撞检测优化

目标: 使用更复杂的碰撞检测算法来提高检测精度,特别是在处理像素级别的碰撞时。

8.2.1 基本碰撞检测

在简单的矩形碰撞检测中,我们使用 pygame.Rect 对象检查矩形的重叠情况。
游戏素材(图1命名为mla.png,图2命名为wg.png并将他们都存入zz目录):
在这里插入图片描述
在这里插入图片描述

8.2.2 像素级碰撞检测
  1. 加载图像并创建掩码

    from pygame.mask import from_surface
    
    image1 = pygame.image.load("image1.png")
    image2 = pygame.image.load("image2.png")
    mask1 = from_surface(image1)
    mask2 = from_surface(image2)
    
  2. 检测像素级碰撞

    if mask1.overlap(mask2, (x2 - x1, y2 - y1)) is not None:
        print("Collision detected!")
    

完整代码:

import pygame
import sys

# 初始化 pygame
pygame.init()

# 设置屏幕
screen = pygame.display.set_mode((800, 600))

pygame.display.set_caption("简单的平台游戏")

# 加载并缩放图片
def load_and_scale_image(filename, size):
    image = pygame.image.load(filename).convert_alpha()
    return pygame.transform.scale(image, size)

# 设置图像大小
image_size = (100, 100)  # 图片宽高

# 加载并缩放图片
image1 = load_and_scale_image("zz/mla.png", image_size)
image2 = load_and_scale_image("zz/wg.png", image_size)

# 创建掩码
mask1 = pygame.mask.from_surface(image1)
mask2 = pygame.mask.from_surface(image2)

# 设置图像的位置
x1, y1 = 100, 100  # image1 的位置
x2, y2 = 300, 300  # image2 的位置

# 游戏状态
game_over = False

# 字体设置
font = pygame.font.Font(None, 74)  # 可以根据需要调整字体大小

def display_game_over_message():
    """显示游戏结束消息"""
    text = font.render('Game Over', True, (255, 0, 0))  # 红色文本
    screen.blit(text, (screen.get_width() // 2 - text.get_width() // 2, screen.get_height() // 2 - text.get_height() // 2))

while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            pygame.quit()
            sys.exit()

    # 获取按键状态
    keys = pygame.key.get_pressed()
    
    # 控制图片1的移动
    if keys[pygame.K_LEFT]:
        x1 -= 5
    if keys[pygame.K_RIGHT]:
        x1 += 5
    if keys[pygame.K_UP]:
        y1 -= 5
    if keys[pygame.K_DOWN]:
        y1 += 5

    # 更新掩码
    mask1 = pygame.mask.from_surface(image1)

    # 检查碰撞
    if mask1.overlap(mask2, (x2 - x1, y2 - y1)) is not None:
        game_over = True

    # 清空屏幕
    screen.fill('white')

    if game_over:
        display_game_over_message()
    else:
        # 绘制图像
        screen.blit(image1, (x1, y1))
        screen.blit(image2, (x2, y2))
    # 更新屏幕
    pygame.display.flip()
    
    # 添加延迟以限制帧率
    pygame.time.delay(10)

实现效果(当马里奥与乌龟碰撞在一起将显示游戏结束):
在这里插入图片描述

8.3 网络功能

目标: 实现简单的多人游戏网络功能,允许玩家在网络上互相对战。

8.3.1 基本网络通信

使用 Python 的 socket 模块来建立客户端和服务器之间的连接。

  1. 创建服务器

    import socket
    
    server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server.bind(("localhost", 5555))
    server.listen(1)
    connection, address = server.accept()
    
  2. 创建客户端

    import socket
    
    client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client.connect(("localhost", 5555))
    
  3. 发送和接收数据

    # 服务器端接收数据
    data = connection.recv(1024)
    connection.sendall(b"Data received")
    
    # 客户端发送数据
    client.sendall(b"Hello, server")
    response = client.recv(1024)
    

小结

本章介绍了高级的游戏开发技巧,包括动画效果、碰撞检测优化和网络功能。通过学习这些技术,你可以为游戏添加更多的动态效果和互动功能,使游戏体验更加丰富和有趣。继续探索这些高级功能,将帮助你在游戏开发中达到新的高度。

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

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

相关文章

QWidget加border-color,一定要使用确定的名字。要不然整个qwidget内部的子控件都会添加边框

QWidget加border-color,一定要使用确定的名字。要不然整个qwidget内部的子控件都会添加边框

【学术会议征稿】第二届物联网与云计算技术国际学术会议 (IoTCCT 2024)

第二届物联网与云计算技术国际学术会议 (IoTCCT 2024) 2024 2nd International Conference on Internet of Things and Cloud Computing Technology (IoTCCT 2024) 第二届物联网与云计算技术国际学术会议(IoTCCT 2024)将于2024年9月27日至29日于广西桂林召开。本次会议将围绕…

zabbix常见架构及组件

Zabbix作为一个开源的、功能全面的监控解决方案,广泛应用于各类组织中,以实现对网络、服务器、云服务及应用程序性能的全方位监控。部署架构灵活性高,可支持从小型单一服务器环境到大型分布式系统的多种场景。基本架构通常包括监控端&#xf…

点灯案例优化(二) 利用位运算修改特定位

前面,我们对点灯代码进行了第一次优化,效果如下 尽管第一次优化以后代码可读性确实高了不少,也看起来更加简洁,但是,这里仍旧存在一个很严重的问题:就在每一个表达式右边,我们给寄存器的数据赋值…

[数据集][目标检测]绳子检测数据集VOC+YOLO格式322张1类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):322 标注数量(xml文件个数):322 标注数量(txt文件个数):322 标注类别…

虹科波形实验室 | 识别振动/敲击方向的方法

熟悉虹科Pico的朋友们都知道,我们的NVH诊断设备可以精确采集三个方向上的振动幅值,并通过软件的自动计算,定位振动来源。但最近收到用户的咨询,问我们NVH设备的振动传感器是否能识别振动的方向?比如Y轴的振动&#xff…

uipath发送邮件给多人:配置教程步骤解答!

uipath发送邮件给多人如何设置?使用uipath发信技巧? 自动化流程能够极大提高工作效率,其中邮件发送作为日常操作的重要组成部分,尤为关键。AokSend将详细介绍如何通过uipath发送邮件给多人,帮助您在自动化流程中更好地…

海康相机触发输入输出(含代码)

海康相机触发模式 软件设置:先设置触发模式,在设置触发源。 目的:模拟编码器发送信号触发相机采集,通过一个矩形波信号触发采集图像。 计数器触发 说明书MSV客户端步骤: 实验过程 1、编码器周长300mm,…

[Leetcode 61][Medium]-旋转链表

目录 一、题目描述 二、整体思路 三、代码 一、题目描述 原题链接 二、整体思路 首先发现这样的规律:当k大于等于链表中节点总数n时,会发现此时旋转后的链表和kk%n时的旋转后的链表一样。同时对于特殊情况n0和n1时,无论k的值为多少都可以…

Unity--XLua调用C#

Unity–XLua调用C# 由于Unity/C# 和lua是两种语言,两种语言的特性不一样,因此,如果要互相调用的话,需要第三方作桥梁. 因此,为了在Unity中/C#中使用lua的特性,需要在Unity中安装插件,Xlua/toLu…

数据结构—— 再探二叉树

1. TOP-K问题 TOP-K问题:求数据结合中前K个最大或者最小的数据 比如:专业前10名、世界500强、富豪榜、游戏中前100的活跃玩家等 思路: 1. 用数据集合中前K个数据来建堆: …

easypoi模板导出word并且合并行

导出流程 引入依赖制作模板合并导出 引入依赖 <dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>4.1.2</version> </dependency>制作模板 合并行是备注那一列&#xff0c;这一列…

UCIE-state machion

1.retrain/linkerror/active状态 状态转变都是从下往上。 &#xff08;1&#xff09;Retrain&#xff1a;multistack和raw model相互违背&#xff1b; &#xff08;2&#xff09;Linkerror&#xff1a;如果一个stack需要进入linkerror&#xff0c;表示链路已经存在问题&…

论文解读:从Dijkstra的On-the-Fly到Go的三色标记算法,并行垃圾回收的起源

我们经常听到关于垃圾回收的说法是&#xff0c;某种垃圾回收算法是一种特定语言特有的&#xff0c;容易理解成&#xff0c;垃圾回收的算法跟特定编程语言是绑定的&#xff0c;但是仔细想想&#xff0c;垃圾回收器是一种分配和管理内存的机制或者程序&#xff0c;内存管理跟语言…

微分方程(Blanchard Differential Equations 4th)中文版Section2.3

阻尼谐振子 在本节中,我们将描述一种解析技术,它适用于本书中最重要的模型之一——阻尼谐振子。这一二阶微分方程用于建模各种现象,如质量-弹簧系统、电路理论中的RLC电路,以及人体的血糖调节系统。 例如,考虑汽车的悬挂系统。它可以平滑崎岖道路上的颠簸,并帮助保持轮…

告别U盘:看医院如何挑选高效安全的文件摆渡系统

基于法规要求和自身安全管理需要&#xff0c;医院普遍使用网闸&#xff0c;将网络隔离为院内网、院外网。网络隔离后&#xff0c;医院各科室部门仍存在频繁的网间数据交换需求&#xff0c;需要文件摆渡系统进行内外网数据的安全交换。具体交换场景如下&#xff1a; 1.影像科&am…

iOS Native与JS通信:JSBridge

文章目录 一、简介二、JS 调用 Native1.使用 URL Schemea.UIWebViewb.WKWebView 2.使用 JavaScriptCore (iOS 7)3.使用 WKWebView 和 WKScriptMessageHandler (iOS 8) 三、Native 调用 JS1.使用 UIWebView2.使用 WKWebView3.使用 JavaScriptCore (iOS 7) 一、简介 对于移动应用…

江西学术会议:第五届计算机、大数据与人工智能国际会议

第五届计算机、大数据与人工智能国际会议(ICCBDAI 2024)将于2024年11月1日-3日在江西景德镇召开。本届会议由景德镇陶瓷大学主办&#xff0c;西安交通大学、暨南大学、南京邮电大学、景德镇学院、ELSP&#xff08;爱迩思出版社&#xff09;、ESBK国际学术交流中心、AC学术平台协…

ctfshow之web29~web51

目录 web29 题解&#xff1a; web30 web31 web32&#xff08;32~36&#xff09; web33 web34 web35 web36 web37 web38 web39 web40 web41 web42 &#xff08;42~51&#xff09; web43 web44 web45 web50 web51 web29 前瞻知识&#xff1a; isset() …

【sgCreateReadonlyForm】自定义小工具:敏捷开发→自动化生成只读表单代码片段脚本(无需列表展示数据,多用于查看某一条数据记录)

sgCreateReadonlyForm源码 <template><!-- 前往https://blog.csdn.net/qq_37860634/article/details/141389231 查看使用说明 --><div :class"$options.name"><div class"sg-head">只读表单生成工具<el-dropdown:show-timeo…