dtNavMeshQuery::findLocalNeighbourhood(dtPolyRef startRef, const float* centerPos, const float radius, const dtQueryFilter* filter,

dtPolyRef* resultRef, dtPolyRef* resultParent, int* resultCount, const int maxResult):

先把startNode加入stack

把startNode加入resultRef中

While(stack不空)

{

dtNode* curNode = stack[0];出队列

获得curTile和curPoly

遍历curPoly的所有link

{

根据link->ref获得neighbourRef

neighbourNode = 在m_tinyNodePool 中getNode

如果找到了则返回这个node,如果没有找到就分配一个node

如果这个node已经DT_NODE_CLOSED访问过了,则continue

然后获得neighbourTile, neighbourPoly

如果neighbour是offmeshconnection,或者不能passFilter,则continue

getPortalPoints获得两个polygon的portal    va   vb

dtDistancePtSegSqr2D (centerPos, va, vb, tseg);算出centerPos到va,vb的距离,也就是到neibour的距离

这一步,centerpos的y轴是有影响的

如果距离超过了radiusSqr,则continue;

neighbourNode设置为DT_NODE_CLOSED,且其pidx设置为当前node

接下来检查这个neighbourPoly是否与我们已经找到的polygon重叠

Pa记录neighbourPoly的顶点

从resultRef中掏出所有的polygon

{

先判断是否跟curPoly连接,如果连接则说明肯定不是重叠的

否则把这个polygon的顶点放在pb里面

dtOverlapPolyPoly2D(pa,npa, pb,npb) 判断是否重叠

这一步因为是映射到了xz平面所以y轴的值是没有影响的

}

if (overlap) continue;

否则 放入resultRef

放入stack中

}遍历curPoly的所有link结束

}stack空

最多找到的结果不能超过maxResult个,超过了就返回status |= DT_BUFFER_TOO_SMALL

总之就是:一个一个node进队列,找neighbour,直到都超过距离了,队列空了为止,或者超过了设置的上限。

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

m_tinyNodePool->getNode

通过dtHashRef算出bucket

在m_first哈希表中找到m_Nodes的坐标

m_nodes[i]中记录的id和state都对应上了,就是找到了

否则在m_next[i]获得m_nodes中的下一个位置

找到了就返回,找不到的话这个i就是我们要插入node的位置

其实就是对m_nodes[i]进行init

然后

m_next[i] = m_first[bucket];

m_first[bucket] = i;

相当于插在了链表的最前边

=====

dtHashRef整数哈希?

https://www.cnblogs.com/napoleon_liu/archive/2010/12/29/1920839.html

目的: 1. 函数要是可逆的(1对1的映射) 
       2. 雪崩效应(输入中1bit的变化 影响 输出中1/4 到 1/2的bits变化)

可逆靠的是可逆操作:

key + const_value 加法是可逆 
    key - const_value 减法是可逆 
    key ^ const_value 异或是可逆的 
    ~key 取反也是可逆的 
    key * const_value 乘以一个奇数也是可逆的

====

getPortalPoints (dtPolyRef
from,
const
dtPoly*
fromPoly,
const
dtMeshTile*
fromTile,

dtPolyRef to,
const
dtPoly*
toPoly,
const
dtMeshTile*
toTile,
float*
left,
float*
right):

从fromPoly的每一个link开始找,如果ref是toPoly,就是找到了

找不到说明参数错了

如果fromPoly是offmeshconnection那么找到ref对应的to的边的两个点存在left和right

如果toPoly是offmeshconnection那么找到ref对应的from的边的两个点存在left和right

否则就是用之前找到的link获得两个点赋给left和right

最后,如果if (link->side
!= 0xff)是tile的boundry

用link->bmin和link->bmax解压出插值的比例算出left和right

====

dtOverlapPolyPoly2D (const
float*
polya,
const
int
npolya,

const float*
polyb,
const
int
npolyb):

for(polya中的所有边)

{

根据每个边算出n[3]
= { vb[2]-va[2],
0, -(vb[0]-va[0])
};

N相当于这个边在xz轴上投影,然后垂直

把n当成轴,进行

projectPoly(n,
polya,
npolya,
amin,amax);

projectPoly(n,
polyb,
npolyb,
bmin,bmax);

也就是把每个边分辨在n上投影,算出投影在n轴上的整个poly的坐标amin,amax

然后overlapRange(amin,amax,
bmin,bmax,
eps)看两个poly投影的结果是否有重叠。但凡有没重叠的情况,两个poly肯定不想交。

}

与上面相同,遍历polyb

dtNavMeshQuery::findLocalNeighbourhood m_tinyNodePool->getNode dtHashRef整数哈希 getPortalPoints dtOverlapPolyPoly2D的更多相关文章

  1. 【算法】哈希表的诞生(Java)

    参考资料 <算法(java)>                           — — Robert Sedgewick, Kevin Wayne <数据结构>       ...

  2. Map容器——HashMap及常用API,及put,get方法解析,哈希码的产生和使用

    Map接口 ①   映射(map)是一个存储键/值对的对象.给定一个键,可以查询到它的值,键和值都是对象; ②   键必须是唯一的,值可以重复; ③   有些映射可以接收null键和null值,而有的 ...

  3. 哈希,hash

    Hash,一般翻译做散列.杂凑,或音译为哈希.----摘自百度百科 先来看个题:给你一坨一些键值集<key,value>,\(key\)的范围是\([1,10^{10}]\),每次询问\( ...

  4. 全面了解一致性哈希算法及PHP代码实现

    在设计一个分布式系统的架构时,为了提高系统的负载能力,需要把不同的数据分发到不同的服务节点上.因此这里就需要一种分发的机制,其实就是一种算法,来实现这种功能.这里我们就用到了Consistent Ha ...

  5. 浅谈MatrixOne如何用Go语言设计与实现高性能哈希表

    目录 MatrixOne数据库是什么? 哈希表数据结构基础 哈希表基本设计与对性能的影响 碰撞处理 链地址法 开放寻址法 Max load factor Growth factor 空闲桶探测方法 一 ...

  6. HashMap:从源码分析到面试题

    1 HashMap简介 HashMap是实现map接口的一个重要实现类,在我们无论是日常还是面试,以及工作中都是一个经常用到角色.它的结构如下: 它的底层是用我们的哈希表和红黑树组成的.所以我们在学习 ...

  7. memcached的分布式

    今天写点周末在火车上看的memcached的东西: 一:memcached的分布式 虽然memcached被称为“分布式”缓存服务器,但是服务器端并没有“分布式”的功能.而是通过客户端来实现的. Me ...

  8. Memcache笔记04-Memcached机制深入了解

    Memcached机制深入了解 ①基于c/s架构 ,协议简单 c/s架构,此时memcached为服务器端,我们可以使用如PHP,c/c++等程序连接memcached服务器. memcached的服 ...

  9. Memcache技术分享:介绍、使用、存储、算法、优化、命中率

    1.memcached 介绍 1.1 memcached 是什么? memcached 是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 为首开发 ...

随机推荐

  1. Centos7 安装 scrapy

    Centos7 安装 scrapy ( *:此python版本为 2.7 ) 1.先安装 python (2.7) 在安装 scrapy 要先安装 python 和 pip,  链接:https:// ...

  2. 计算机视觉学习记录 - Implementing a Neural Network from Scratch - An Introduction

    0 - 学习目标 我们将实现一个简单的3层神经网络,我们不会仔细推到所需要的数学公式,但我们会给出我们这样做的直观解释.注意,此次代码并不能达到非常好的效果,可以自己进一步调整或者完成课后练习来进行改 ...

  3. (一)Java工程化--Maven基础

    Maven 读作['mevən] 翻译成中文是"内行,专家" Maven是什么 包依赖的前世今生: 原始的jar包引用--> ant --> maven. 是一种项目管 ...

  4. IDEA 中使用MyBatis-generator 自动生成MyBatis代码

    0.在Intellij IDEA创建maven项目 1. 在maven项目的pom.xml 添加mybatis-generator-maven-plugin 插件 <build> < ...

  5. python celery任务分发

    <div id="cnblogs_post_body" class="blogpost-body"><p>Celery是由Python开 ...

  6. 3D Slicer中文教程(三)—数据加载及保存方式

    1.打开数据与保存数据 (1)打开数据 ——可以将数据拖拽到3D Slicer应用窗口或者从菜单栏工具栏打开. ——多种方式加载大量数据. 有关DICOM数据,请参阅DICOM模块文档. 对于几乎所有 ...

  7. conda安装cv2库

    conda install opencv-python或者 pip install opencv-python(不过好像是这个比较有效)

  8. 再说C模块的编写(2)

    [前言] 在<再说C模块的编写(1)>中主要总结了Lua调用C函数时,对数组和字符串的操作,而这篇文章将重点总结如何在C函数中保存状态. 什么叫做在C函数中保存状态?比如你现在使用Lua调 ...

  9. [PHP]获取静态方法调用者的类名和运用call_user_func_array代入对象作用域

    一.获取静态方法调用者的类名 方法一: class foo { static public function test() { var_dump(get_called_class()); } } cl ...

  10. intellij idea创建maven项目

    1.安装好JDK,Tomcat,安装好maven: 2.配置maven全局变量:file->Other Settings ->Default Settings->Build,Exec ...