搜索
bottom↓
回复: 28

有偿(300¥):判断一个点是否在封闭形状内的算法

  [复制链接]

出0入46汤圆

发表于 2020-7-11 09:57:20 | 显示全部楼层
本帖最后由 jasonzhu8888 于 2020-7-11 10:04 编辑

  1. struct Point
  2. {
  3.         float x;
  4.         float y;
  5. };

  6. bool circle_contains(Point* p_center, float radius, float x, float y)
  7. {
  8.         float xx = p_center->x - x;
  9.         float yy = p_center->y - y;
  10.         return xx*xx + yy*yy <= radius*radius;
  11. }

  12. bool polygon_contains(Point* pypts,int num,float x, float y)
  13. {
  14.         int hits = 0;

  15.         int n = num - 1;
  16.         Point* plastpt = &pypts[n];
  17.         float lastx = plastpt->x;
  18.         float lasty = plastpt->y;
  19.         float curx, cury;

  20.         for (int i = 0; i < n; lastx = curx, lasty = cury, i++)
  21.         {
  22.                 Point* p = &pypts[i];
  23.                 curx = p->x;
  24.                 cury = p->y;

  25.                 if (cury == lasty)
  26.                 {
  27.                         continue;
  28.                 }

  29.                 float leftx;
  30.                 if (curx < lastx)
  31.                 {
  32.                         if (x >= lastx)
  33.                         {
  34.                                 continue;
  35.                         }
  36.                         leftx = curx;
  37.                 }
  38.                 else
  39.                 {
  40.                         if (x >= curx)
  41.                         {
  42.                                 continue;
  43.                         }
  44.                         leftx = lastx;
  45.                 }

  46.                 float test1, test2;
  47.                 if (cury < lasty)
  48.                 {
  49.                         if (y < cury || y >= lasty)
  50.                         {
  51.                                 continue;
  52.                         }
  53.                         if (x < leftx)
  54.                         {
  55.                                 hits++;
  56.                                 continue;
  57.                         }
  58.                         test1 = x - curx;
  59.                         test2 = y - cury;
  60.                 }
  61.                 else
  62.                 {
  63.                         if (y < lasty || y >= cury)
  64.                         {
  65.                                 continue;
  66.                         }
  67.                         if (x < leftx)
  68.                         {
  69.                                 hits++;
  70.                                 continue;
  71.                         }
  72.                         test1 = x - lastx;
  73.                         test2 = y - lasty;
  74.                 }

  75.                 if (test1 < (test2 / (lasty - cury) * (lastx - curx)))
  76.                 {
  77.                         hits++;
  78.                 }
  79.         }

  80.         return ((hits & 1) != 0);
  81. }
复制代码

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入46汤圆

发表于 2020-7-11 10:01:18 | 显示全部楼层
polygon_containes 前面两个参数是输入的多边形坐标,最好首尾的点是同一个形成闭环,也即是输入点至少4个
如  (x0 y0)  (x1 y1) ... (x n-1  y n-1) (x0 y0)
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-6-2 05:02

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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