天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 48|回复: 0

arx 判断点是否在闭合区域内

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
[code]//判断点是否在闭合区域内
bool IsPointInPolygon(Point p, vector<Point> points)
{
//vector<Point> points:表示闭合区域由这些点围成
        double minX = points[ 0 ].x;
        double maxX = points[ 0 ].x;
        double minY = points[ 0 ].y;
        double maxY = points[ 0 ].y;
        for ( unsigned int i = 1 ; i < points.size() ; i++ )
        {
                Point q = points[ i ];
                minX = min( q.x, minX );
                maxX = max( q.x, maxX );
                minY = min( q.y, minY );
                maxY = max( q.y, maxY );
        }

        if ( p.x < minX || p.x > maxX || p.y < minY || p.y > maxY )
        {
                return false;
        }

        bool inside = false;
        for ( unsigned int i = 0, j = points.size() - 1 ; i < points.size() ; j = i++ )
        {
                if ( ( points[ i ].y > p.y ) != ( points[ j ].y > p.y ) &&
                        p.x < ( points[ j ].x - points[ i ].x ) * ( p.y - points[ i ].y ) / ( points[ j ].y - points[ i ].y ) + points[ i ].x )
                {
                        inside = !inside;
                }
        }

        return inside;
}[/code]

 

 

 

 

arx 判断点是否在闭合区域内
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 15:20 , Processed in 0.154579 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表