opt getIntersectionPoint

This commit is contained in:
yangxiao 2015-06-24 15:49:09 +08:00
parent 086b01321c
commit 77f1af91f9
1 changed files with 17 additions and 7 deletions

View File

@ -27,6 +27,8 @@ THE SOFTWARE.
USING_NS_CC; USING_NS_CC;
#include <stdlib.h> #include <stdlib.h>
#include <CCImage.h> #include <CCImage.h>
#include <float.h>
#include <set>
#include "renderer/CCGLProgram.h" #include "renderer/CCGLProgram.h"
#include "renderer/CCGLProgramCache.h" #include "renderer/CCGLProgramCache.h"
#include "renderer/CCGLProgramState.h" #include "renderer/CCGLProgramState.h"
@ -35,10 +37,8 @@ USING_NS_CC;
#include "renderer/ccGLStateCache.h" #include "renderer/ccGLStateCache.h"
#include "renderer/CCRenderState.h" #include "renderer/CCRenderState.h"
#include "base/CCDirector.h" #include "base/CCDirector.h"
#include "2d/CCCamera.h"
#include <set>
#include "base/CCEventType.h" #include "base/CCEventType.h"
#include "2d/CCCamera.h"
NS_CC_BEGIN NS_CC_BEGIN
@ -513,6 +513,9 @@ bool Terrain::getIntersectionPoint(const Ray & ray, Vec3 & intersectionPoint) co
Vec2 delta = dir.getNormalized(); Vec2 delta = dir.getNormalized();
auto width = float(_imageWidth) / (_terrainData._chunkSize.width + 1); auto width = float(_imageWidth) / (_terrainData._chunkSize.width + 1);
auto height = float(_imageHeight) / (_terrainData._chunkSize.height + 1); auto height = float(_imageHeight) / (_terrainData._chunkSize.height + 1);
bool hasIntersect = false;
float intersectionDist = FLT_MAX;
Vec3 tmpIntersectionPoint;
for(;;) for(;;)
{ {
int x1 = floorf(start.x); int x1 = floorf(start.x);
@ -526,9 +529,15 @@ bool Terrain::getIntersectionPoint(const Ray & ray, Vec3 & intersectionPoint) co
{ {
if (closeList.find(chunk) == closeList.end()) if (closeList.find(chunk) == closeList.end())
{ {
if (chunk->getInsterctPointWithRay(ray, intersectionPoint)) if (chunk->getInsterctPointWithRay(ray, tmpIntersectionPoint))
{ {
return true; float dist = (ray._origin - tmpIntersectionPoint).length();
if (intersectionDist > dist)
{
hasIntersect = true;
intersectionDist = dist;
intersectionPoint = tmpIntersectionPoint;
}
} }
closeList.insert(chunk); closeList.insert(chunk);
} }
@ -546,7 +555,7 @@ bool Terrain::getIntersectionPoint(const Ray & ray, Vec3 & intersectionPoint) co
start.x += delta.x; start.x += delta.x;
start.y += delta.y; start.y += delta.y;
} }
return false; return hasIntersect;
} }
void Terrain::setMaxDetailMapAmount(int max_value) void Terrain::setMaxDetailMapAmount(int max_value)
@ -1262,7 +1271,7 @@ bool Terrain::Chunk::getInsterctPointWithRay(const Ray& ray, Vec3 &interscetPoin
if (!ray.intersects(_aabb)) if (!ray.intersects(_aabb))
return false; return false;
float minDist = 9999; float minDist = FLT_MAX;
bool isFind = false; bool isFind = false;
for (auto triangle : _trianglesList) for (auto triangle : _trianglesList)
{ {
@ -1585,6 +1594,7 @@ void Terrain::Triangle::transform(cocos2d::Mat4 matrix)
matrix.transformPoint(&_p3); matrix.transformPoint(&_p3);
} }
//Please refer to 3D Math Primer for Graphics and Game Development
bool Terrain::Triangle::getInsterctPoint(const Ray &ray, Vec3& interScetPoint)const bool Terrain::Triangle::getInsterctPoint(const Ray &ray, Vec3& interScetPoint)const
{ {
// E1 // E1