Unity3D 基于ECS的AI思考与怪物同步详解

引言

在游戏开发中,AI(人工智能)和怪物同步是两个至关重要的部分。它们不仅决定了游戏中NPC和怪物的行为表现,还直接影响玩家的游戏体验。Unity3D作为广泛使用的游戏引擎,通过引入ECS(Entity-Component-System)架构,为开发者提供了更加高效和灵活的方式来处理游戏中的AI逻辑和怪物同步。本文将详细介绍如何在Unity3D中使用ECS来实现AI思考与怪物同步,并给出技术详解和代码实现。

对惹,这里有一个游戏开发交流小组,希望大家可以点击进来一起交流一下开发经验呀!

ECS架构概述

ECS是一种面向数据的设计模式,它将游戏对象分解为实体(Entity)、组件(Component)和系统(System)。实体是游戏中的基本单位,用于唯一标识一组组件的集合;组件是实体的具体属性和行为,如位置、速度、攻击力等;系统则是处理组件逻辑的模块,负责更新和处理组件的数据。

实体(Entity)

实体是游戏中的基本单位,它只是一个唯一标识符,用来标识一组组件的集合。在ECS中,实体本身不包含任何数据或行为,所有的数据和行为都通过组件来定义。

组件(Component)

组件是实体的具体属性和行为,如位置、速度、碰撞体等。每个组件都包含了特定类型的数据,这些数据可以被系统访问和修改。

系统(System)

系统是处理组件逻辑的模块,它负责更新和处理组件的数据。系统通过遍历所有带有特定组件的实体来执行其逻辑。ECS通过系统的设计实现了高效的并行化,提高了游戏性能。

基于ECS的AI思考

在Unity3D中,AI思考可以通过系统来实现。首先,我们需要定义一个AI组件,用于存储NPC的行为数据。然后,编写一个AI系统来处理NPC的行为逻辑。

定义AI组件

csharp复制代码
using Unity.Entities;
public struct AIComponent : IComponentData
{
public float moveSpeed;
public float attackRange;
public float3 targetPosition;
}

实现AI系统

csharp复制代码
using Unity.Entities;
using Unity.Transforms;
using Unity.Mathematics;
public class AISystem : ComponentSystem
{
protected override void OnUpdate()
{
Entities.ForEach((ref AIComponent ai, ref Translation translation) =>
{
if (math.distance(ai.targetPosition, translation.Value) > ai.attackRange)
{
translation.Value = math.lerp(translation.Value, ai.targetPosition, ai.moveSpeed * Time.deltaTime);
}
// 可以在这里添加攻击逻辑
});
}
}

在这个AI系统中,我们遍历所有带有AI组件的实体,并根据NPC的行为数据来更新NPC的位置。

怪物同步的实现

怪物同步是指在多人游戏中,确保不同客户端的怪物状态保持一致。在ECS架构中,我们可以通过服务器来同步怪物的状态,然后在客户端上进行更新。

定义怪物组件

csharp复制代码
using Unity.Entities;
public struct MonsterComponent : IComponentData
{
public float3 position;
public quaternion rotation;
// 可以添加其他怪物属性
}

实现怪物同步系统

csharp复制代码
using Unity.Entities;
using Unity.Transforms;
public class MonsterSyncSystem : ComponentSystem
{
protected override void OnUpdate()
{
// 假设这里从服务器接收了怪物的最新状态
// 在实际游戏中,你可能需要通过网络通信来获取这些数据
Entities.ForEach((ref MonsterComponent monster, ref Translation translation, ref Rotation rotation) =>
{
translation.Value = monster.position;
rotation.Value = monster.rotation;
});
}
}

在这个怪物同步系统中,我们遍历所有带有MonsterComponent组件的实体,并根据从服务器接收的最新状态来更新怪物的位置和旋转。

网络通信

在多人游戏中,网络通信是实现怪物同步的关键。Unity3D支持多种网络通信方式,如Photon、UNet等。以下是一个简单的Photon同步示例:

csharp复制代码
using Photon.Pun;
using UnityEngine;
public class MonsterSync : MonoBehaviourPun, IPunObservable
{
private Vector3 latestPos;
private Quaternion latestRot;
void Start()
{
latestPos = transform.position;
latestRot = transform.rotation;
}
void Update()
{
// 在非本地玩家时,从网络更新位置和旋转
}
public void OnPhotonSerializeView(PhotonStream stream, PhotonMessageInfo info)
{
if (stream.IsWriting)
{
stream.SendNext(

更多教学视

Unity​www.bycwedu.com/promotion_channels/2146264125​编辑

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

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

相关文章

基于智能推荐的图书电商系统的设计与实现

💗博主介绍💗:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示:文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

JavaScript实现Promise

第一步:编写constructor构造方法 const PENDING pending; const FULFILLED fulfilled; const REJECTED rejected;class MyPromise {#state PENDING;#result undefined;constructor(executor) {const resolve (data) > {this.#changeState(FULFILLED, data…

物理 + 人工智能 = 2024年诺贝尔物理学奖

💓 博客主页:倔强的石头的CSDN主页 📝Gitee主页:倔强的石头的gitee主页 ⏩ 文章专栏:《热点时事》 期待您的关注 目录 引言 一、机器学习与神经网络的发展前景 二、机器学习和神经网络的研究与传统物理学的关系 结…

C++:异常

1. 异常的概念 C语言主要通过错误码的方式处理错误,错误码本质上就是对错误信息进行分类编号,拿到错误码以后还要去查询错误信息,比较麻烦。异常时抛出一个对象,这个对象可以涵盖更全面的信息。 异常处理机制允许程序中独立开发的…

南京邮电大学算法设计-二叉树先序遍历算法动态演示

二叉树先序遍历算法动态演示 一、课题内容和要求 (1)实验目的: 本实验通过手动输入二叉树结点信息,构建相应的二叉树,并通过图形化界面动态演示先序遍历算法的过程。通过本次实验,我可以深入理解二叉树的数据结构、先序遍历算法…

【开源免费】基于Vue和SpringBoot的在线考试系统(附论文)

本文项目编号 T 624 ,文末自助获取源码 \color{red}{T624,文末自助获取源码} T624,文末自助获取源码 网络的广泛应用给生活带来了十分的便利。所以把在线考试管理与现在网络相结合,利用java技术建设在线考试系统,实现…

高阶C语言之六:程序环境和预处理

本文介绍程序的环境,在Linux下对编译链接理解,较为简短,着重在于编译的步骤。 C的环境 在ANSI C(标准C语言)的任何一种实现中,存在两个不同的环境。 翻译环境:在这个环境中,源代码…

HarmonyOs鸿蒙开发实战(10)=>状态管理-对象数组的属性数据变更刷新UI,基于@Observed 和@ObjectLink装饰器

1.条件:基于HarmonyOs5.0.0版本. 2.功能要求:横向列表中每个景点的名称(eg: 第二项 “灵隐寺” ), 在通过天气接口拿到对应天气后,拼接到名称后面 > 变成(“灵隐寺” 天气)) 3.老规矩先看…

快速上手Mybatis Plus并速通MybatisPlus所有知识点

目录 一、简介 1.1 概况 1.2 特性 二、快速入门 1.建表 2.引依赖 3.application.ymal文件 4.定义mapper继承BaseMapper 5.总结 三、Mybatis Plus的使用 1.常见注解 1.1 TableName 1.2 TableId 1.3 TableField 2.常见配置 3.BaseMapper的基础CRUD方法 4.Wrapper…

使用代理解决前端跨域问题详解

目录 前言1. 什么是跨域问题?1.1 同源策略的定义1.2 跨域问题的表现 2. 解决跨域问题的常见方法3. 在 Vite 中配置代理解决跨域问题3.1 环境准备3.2 配置代理3.2.1 配置基础路径3.2.2 配置 Vite 代理3.2.3 参数解释 3.3 验证代理功能 4. 深入分析与注意事项4.1 代理…

使用MaxKB搭建知识库问答系统并接入个人网站(halo)

首发地址(欢迎大家访问):使用MaxKB搭建知识库问答系统并接入个人网站 前言 从OpenAI推出ChatGPT到现在,大模型已经渗透到各行各业,大模型也逐渐趋于平民化;从最开始对其理解、生成、强大的知识积累的惊叹&…

查看台式机主机支持的最大分辨率 | 显卡和显示器

通过检查显卡规格和型号,确认主机支持最大分辨率。 方法1:设置 在设置 -> 系统 -> 屏幕 及其内的高级显示设置 设置 -> 显示 方法2:cmd 在运行中输入“devmgmt.msc”,进入设备管理器界面,点击展开“显示适配…

若依权限控制

springbootvue2项目中的权限控制(若依项目) 步骤: 1.登录管理员账号,为普通用户增加权限按钮 绿色部分为权限控制字符 2.在后端对应的方法上增加权限控制(这里以删除操作为例):PreAuthorize(“ss.hasPermi(‘area:store:remove’)”) 3.在前端对应的按钮上增加权限控制:v-ha…

5G的SUCI、SUPI、5G-GUTI使用场景及关系

使用场景(来源于对23.501、23.502、33.501、23.003的理解) 1、UE初始注册时,根据HN Public Key把SUPI加密成SUCI,并发送初始注册请求 2、AMF转发SUCI给AUSF和UDM进行认证,并获取解密后的SUPI 3、AMF根据SUPI生成一个5G-GUTI,并保…

本地部署 excalidraw

本地部署 excalidraw 0. 引言1. 本地部署 excalidraw2. 访问 excalidraw 0. 引言 Excalidraw 编辑器是一款开源虚拟手绘白板,支持协作且端到端加密。 1. 本地部署 excalidraw git clone https://github.com/excalidraw/excalidraw.git; cd excalidrawvi docker-c…

企业数字化转型的战略指南:物联网与微服务架构的深度融合及应用解析

新时代下的企业数字化转型挑战与机遇 在当前全球经济和技术迅猛发展的背景下,企业数字化转型成为保持竞争力和创新的关键战略。物联网(IoT) 的兴起为企业提供了无数新的数据来源和运营模式,然而,如何有效整合这些数据…

vue3+vant实现弹幕循环播放~

1、效果图 <!-- 弹幕 --> <div style"height: 88px"><van-barragev-model"list"duration"5000":rows"rows":gap"gap":loop"loop"style"--move-distance: -345px" ><div class&quo…

字母异位词分组(java)

题目描述 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单shilie 示例 1: 输入: strs ["eat", "tea", "tan", "ate", "n…

解决ValueError: Custom function inv is not defined in `extra_sympy_mappings`.

一、报错问题 ValueError: Custom function inv is not defined in extra_sympy_mappings. You can define it with, e.g., model.set_params(extra_sympy_mappings{inv: lambda x: 1/x}), where lambda x: 1/x is a valid SymPy function defining the operator. You can als…

深度学习基础练习:代码复现transformer重难点

2024/11/10-2024/11/18: 主要对transformer一些比较难理解的点做了一些整理&#xff0c;希望对读者有所帮助。 前置知识&#xff1a; 深度学习基础练习&#xff1a;从pytorch API出发复现LSTM与LSTMP-CSDN博客 【神经网络】学习笔记十四——Seq2Seq模型-CSDN博客 【官方双语】一…