点跟多边形的碰撞检测

本文介绍了一个用于检测点是否在多边形内的C++实现方法。通过遍历多边形的边,计算点与每条边的交点,并统计交点数量,当交点数为奇数时,表示点在多边形内部。


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);

}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值