点跟多边形的碰撞检测
2014-03-12 15:20
369 查看
class GBPolygon {
public:
int _numVertices;
std::vector<CCPoint> _verticesVec;
};
点跟多边形的碰撞
static bool PointInPolygon(const CCPoint & p,
const GBPolygon & polygon)
{
int nCross =
0;
int nCount = polygon._verticesVec.size();
for (int i =
0; i<nCount; i++) {
CCPoint p1 = polygon._verticesVec[i];
CCPoint p2 = polygon._verticesVec[(i+1)%nCount];
//
求解 y=p.y 与 p1p2 的交点
if(p1.y == p2.y)
continue; // p1p2 与 y=p0.y平行
if(p.y<(p1.y<p2.y?p1.y:p2.y))
continue;// 交点在p1p2延长线上
if(p.y>=(p1.y>p2.y?p1.y:p2.y))
continue;// 交点在p1p2延长线上
//
求交点的 X 坐标 --------------------------------------------------------------
float x = (p.y-p1.y)*(p2.x-p1.x)/(p2.y-p1.y)+p1.x;
if (x>p.x) {
nCross++;//
只统计单边交点
}
}
// 单边交点为偶数,点在多边形之外 ---
return (nCross%2==1);
}
public:
int _numVertices;
std::vector<CCPoint> _verticesVec;
};
点跟多边形的碰撞
static bool PointInPolygon(const CCPoint & p,
const GBPolygon & polygon)
{
int nCross =
0;
int nCount = polygon._verticesVec.size();
for (int i =
0; i<nCount; i++) {
CCPoint p1 = polygon._verticesVec[i];
CCPoint p2 = polygon._verticesVec[(i+1)%nCount];
//
求解 y=p.y 与 p1p2 的交点
if(p1.y == p2.y)
continue; // p1p2 与 y=p0.y平行
if(p.y<(p1.y<p2.y?p1.y:p2.y))
continue;// 交点在p1p2延长线上
if(p.y>=(p1.y>p2.y?p1.y:p2.y))
continue;// 交点在p1p2延长线上
//
求交点的 X 坐标 --------------------------------------------------------------
float x = (p.y-p1.y)*(p2.x-p1.x)/(p2.y-p1.y)+p1.x;
if (x>p.x) {
nCross++;//
只统计单边交点
}
}
// 单边交点为偶数,点在多边形之外 ---
return (nCross%2==1);
}
相关文章推荐
- ARM处理器模式弹跳机制的初始化 笔记版 转载请注明出处---crosskernel@gmail.com
- centos安装openfire
- 算法概率思维导图
- 免费应用引擎推荐
- eclipse添加maven
- ActiveMQ 权限(二)
- 求字符串长度之递归与非递归的C语言实现
- sharepoint 2010 弹出模式窗口showModalDialog并返回值returnResult方法
- Drawing a UIView
- python中的队列和栈
- 免费的文本编辑器 (copied)
- Ogre材质解析代码初步分析(四)
- OV2640帧率的计算
- pat 1070
- python内置函数
- java的服务器空间
- 阿里校招之类实例化的顺序
- apply 判定变量类型
- SQL Trigger 判断增删改
- html 页面视图中的资源文件(css/js/image)的路径问题。