在checkPathValidity(检查所有agent的corridor的m_path是否有效)

如果是无效的要进行重新设置并且设置replan

首先获得第一个polygon,m_path[0]

这里,因为addagent的时候,ag->corridor.reset(ref, nearest);

m_path[0] = ref;

所以就算是没有设定目标,const int npath = ag->corridor.getPathCount();也是1

然后根据FirstPoly的polyref进行检查,isValidPolyRef

检查的条件是,可以获得poly和tile,并且passfilter

如果不是有效的则:

通过findNearestPoly-> queryPolygons找到最近的poly

用其返回的距离poly的最近点覆盖agentPos

如果没有找到NearestPoly,设置agent的state 为 DT_CROWDAGENT_STATE_INVALID

然后ag->corridor.fixPathStart主要是给corridor的m_path[0]设置成找到的这个点

把当前agent的ag->npos设置成我们计算出来的最近点

因为初始点是被设置过了,所以要replan = true;

同样的,对目标点进行isValidPolyRef检查

如果是无效的,用上面的方法,找到一个有效的来

设置到ag->targetPos

如果最终还是找不到targetRef

ag->targetState = DT_CROWDAGENT_TARGET_NONE

然后检查ag->corridor.isValid,其实就是检查这个corridor里面的m_path的所有poly是不是isValidPolyRef,如果有invalid的,则replan = true;

最后 如果需要replan :r

equestMoveTargetReplan 就是设置agent的targetRef, targetPos,以及state设置成DT_CROWDAGENT_TARGET_REQUESTING

=========================

dtNavMeshQuery::queryPolygons(const float* center, const float* halfExtents,

const dtQueryFilter* filter, dtPolyQuery* query):

计算center为中心halfExtents为半径的包围盒所触及的tiles

在所有触及到的tiles中执行queryPolygonsInTile

这个函数的用途就是为了对所有多边形执行process,进而找到最近的poly

如果找到了,我们就覆盖nearestPt

==============

queryPolygonsInTile(const dtMeshTile* tile, const float* qmin, const float* qmax,

const dtQueryFilter* filter, dtPolyQuery* query):

如果使用了bvtree:

{

float minx = dtClamp(qmin[0], tbmin[0], tbmax[0]) - tbmin[0];……

把center为中心halfExtents为半径的包围盒转换为这个相对于这个tile原点的相对位置

Bmax确保比bmin大1

接下来遍历bvtree,从数组中的第一个node开始,计算是否覆盖,

node->i如果大于零说明是叶子,表示其在本tile中的poly序号,否则就表示跨过多少个找其右边的儿子

接下来:

1 如果是叶子并且相交了并且通过了passfilter,记录下来这个node,这个node是一个polygon

如果记录的总数已经到达了batchSize的上限了则process,主要就是找到最近的点和最近的多边形,batchSize是一个批次的量,也就是说是按照批次进行处理的。

2 如果是叶子但是没有相交或者不是叶子但是相交了,那就node++,走下一个树根或者走当前树根的第一个节点

3 如果既不是叶子也没有相交,那就可以跨过去当前这个树根了,直接跨过-node->i个节点。

}

如果没有使用bvtree:

For(这个tile里面的所有polygon)

{

不可以是offmeshconnection并且必须passFilter

求出多边形的AABB

然后跟使用bvtree的情况下一样找到最近的点和最近的多边形

}

最后把没有满一个批次的,调用process进行处理。

=====================

dtFindNearestPolyQuery :: process(const dtMeshTile* tile, dtPoly** polys, dtPolyRef* refs, int count):

For(每一个poly)

{

计算m_center跟这个poly的最近点,dtNavMeshQuery::closestPointOnPoly(dtPolyRef ref, const float* pos, float* closest, bool* posOverPoly):

通过dtDistancePtPolyEdgesSqr(pos, verts, nv, edged, edget)计算出,pos对于每条边的最近距离,并且存在edged里面,函数返回值表示点是否在多边形内部。

找到距离最小的那条边的两个顶点va,vb

dtVlerp(closest, va, vb, edget[imin]); 根据edget对va,vb进行插值,求得多边形上距离pos最近的点closest

edget里面存的是 http://blog.sina.com.cn/s/blog_5d5c80840101bnhw.html 这里面的r

因为且

所以可以用r来作插值计算closest的坐标。

posOverPoly记录是否在多边形内

接下来计算m_nearestDistanceSqr,存的是点与这些多边形的最短的直线距离。

有一个情况除外,就是在posOverPoly的情况下,计算的是y轴的距离,如果比walkableClimb小的话,直接就选它了,否则就是记录高度距离的平方存在nearestDistanceSqr

然后找到距离最小的点,存在nearestDistanceSqr

}

checkPathValidity 检查所有agent的corridor的m_path是否有效的更多相关文章

  1. EBS与FMW集成工作流管理器的检查

    工作流管理器的检查点(DB层面): --1:数据库job aq参数设置,建议设置job_queue_processes>=10 select p.NAME,p.DESCRIPTION,p.VAL ...

  2. Python3网络爬虫(四):使用User Agent和代理IP隐藏身份《转》

    https://blog.csdn.net/c406495762/article/details/60137956 运行平台:Windows Python版本:Python3.x IDE:Sublim ...

  3. 自学Zabbix3.5.3-监控项item-zabbix agent 类型所有key

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 1. 温习       Zabbix server是Zabbix软件的中心进程. Server执行 ...

  4. open-falcon之agent

    功能 采集数据,解析数据,上报数据至transfer 基本涵盖了系统层面监控指标,直接将数据转换为metricValue形式,上报至transfer 支持插件采集,代码插件放可受git管理,放置在pl ...

  5. 使用User Agent和代理IP隐藏身份

    一.为何要设置User Agent 有一些网站不喜欢被爬虫程序访问,所以会检测连接对象,如果是爬虫程序,也就是非人点击访问,它就会不让你继续访问,所以为了要让程序可以正常运行,需要隐藏自己的爬虫程序的 ...

  6. Zabbix Agent报“listener failed: zbx_tcp_listen() fatal error: unable to serve on any address”

    一台服务器的Zabbix Agent升级后,在Zabbix Server发现Zabbix Agent无法访问.检查Zabbix Agent发现服务停止了,启动Zabbix Agent后,发现服务马上又 ...

  7. Zabbix Agent升级

      最近对Zabbix Server进行了升级,所以陆陆续续对Zabbix Agent也做了升级,下面是这几天工作的一个小结,鉴于经验有限和认知有限等各方面因素,下文很难面面俱到,如有疏漏或不足之处, ...

  8. Nutch源码阅读进程3---fetch

    走了一遍Inject和Generate,基本了解了nutch在执行爬取前的一些前期预热工作,包括url的过滤.规则化.分值计算以及其与mapreduce的联系紧密性等,自我感觉nutch的整个流程是很 ...

  9. 数据挖掘_wget整站下载

    你应该了解的所有wget命令 翻译自All the Wget Commands You Should Know 如何下载整个网站用来离线浏览?怎样将一个网站上的所有MP3文件保存到本地的一个目录中?怎 ...

随机推荐

  1. [译]Ocelot - Load Balancer

    原文 可以对下游的服务进行负载均衡. 提供了下面几种负载均衡: LeastConnection - tracks which services are dealing with requests an ...

  2. 关于Setup Factory 9的一些使用方法

    之前使用的VS自带的InstallShield2015LimitedEdition 打包工具,但是不太灵活,打包长得也难看:后来使用Setup Factory 9 打包winform应用程序,用起来轻 ...

  3. POJ 3190

    POJ3190                               摊位预订.时间限制:1000MS内存限制:65536K.共提交材料:12959份接受:4 546名特别法官.描述. 哦,那些 ...

  4. Java消息队列--ActiveMq 初体验

    1.下载安装ActiveMQ ActiveMQ官网下载地址:http://activemq.apache.org/download.html ActiveMQ 提供了Windows 和Linux.Un ...

  5. perl 之 正则表达式 (简)

    正则表达式,简单介绍: 元字符 匹配项 字符类:单字符与数字   . 匹配除换行符之外的任意字符 [a-z0-9] 匹配集中任意单字符 [^a-z0-9] 匹配不在集合中的任意单字符 \d 匹配单个数 ...

  6. Beta冲刺(7/7)

    目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(7/7) 后敬甲(组长) 过去两天完成了哪些任务 ppt制作 视频拍摄 接下来的计划 准备答辩 还剩下哪些 ...

  7. C++\CLI语法 在项目中的使用

    通常情况下,对一个标准的com组件进行集成,网上普遍使用的方式有: 1.#import *.dll 或 #import *.ocx的方式,VS编译器重新编译后,就会自动生成组件对应的*.tlh文件,该 ...

  8. RabbitMQ 消息队列 二

    一:查看MQ的用户角色 rabbitmqctl list_users 二:添加新的角色,并授予权限 rabbitmqctl add_user xiaoyao 123456 rabbitmqctl se ...

  9. Exceptionless 生产部署笔记

    参考 部署用于生产的Exceptionlees(一个强大易用的日志收集服务) 1. 安装配置 redis 4.0  点击下载redis教学脑图 cd /opt wget http://download ...

  10. ios 修改导航栏返回按钮的图片

    修改导航栏返回按钮的图片 方法1: [UINavigationBar appearance].backIndicatorTransitionMaskImage = [UIImage imageName ...