a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

C語言實現(xiàn)的PNPoly算法代碼例子

2020-01-26 15:29:35
字體:
來源:轉載
供稿:網(wǎng)友

寫C語言的實驗用到的一個算法,判斷一個點是否在多邊形的內(nèi)部。C的代碼如下:

int pnpoly(int nvert, float *vertx, float *verty, float testx, float testy){  int i, j, c = 0;  for (i = 0, j = nvert-1; i < nvert; j = i++) {    if ( ((verty[i]>testy) != (verty[j]>testy)) &&       (testx < (vertx[j]-vertx[i]) * (testy-verty[i]) /       (verty[j]-verty[i]) + vertx[i]) )      c = !c;    }  return c;}

其中nvert是多邊形頂點的個數(shù),vertx和verty分別是多邊形頂點橫、縱坐標的數(shù)組,textx和testy是待測點的坐標。這個算法是由W. Randolph Franklin提出的,根據(jù)Jordan curve theorem,多邊形將平面分為內(nèi)外兩個區(qū)域,假設待測點在多邊形內(nèi)部,從待測點引出一條射線必然會與多邊形有至少一個交點。該射線與多邊形第一次相交時將“沖出”多邊形,第二次相交將“進入”多邊形,依此類推,若射線與多邊形有奇數(shù)個交點,則該點在多邊形內(nèi)部,反之則在外部。

PNPoly算法正是從待測點引出一條水平向右的射線,并計算與多邊形的交點個數(shù)。解釋一下這段代碼:for (i = 0, j = nvert-1; i < nvert; j = i++)循環(huán)的含義就是始終讓j = i

主站蜘蛛池模板: 四虎av在线 | 国产成人精品免高潮在线观看 | 最新超碰 | 91久久精品一区 | 欧美一级一区 | 天天草草草| 99国产精品视频免费观看一公开 | 午夜视频一区二区 | 免费观看一级特黄欧美大片 | 欧洲一区在线 | 精品久久一区 | 亚州精品视频 | 本道综合精品 | 欧美一区不卡 | 亚洲精品aaa | 伊人激情四射 | zzzzyyyy精品国产 | 九九热这里只有精品6 | 久久人 | 久久久一区二区三区捆绑sm调教 | 欧美成人精品一区 | 日韩精品一区二区三区中文字幕 | 久久久精品欧美一区二区免费 | 久久久久久久久久毛片 | 欧美日韩网 | 91精品综合久久久久久五月天 | 亚洲精品二区 | 日本久久久久久 | 久久激情网 | 曰逼视频| 国产精品久久久久久 | 国产亚洲精品久 | 成人一区av偷拍 | 岛国一区| 午夜国产精品视频 | 免费av播放 | 成人a在线视频 | 一区二区三区四区在线 | 日韩视频一区二区三区 | 一级免费片 | 亚洲高清一区二区三区 |