python射線法判斷檢測點(diǎn)是否位于區(qū)域外接矩形內(nèi)
本文實(shí)例為大家分享了python射線法判斷點(diǎn)是否位于區(qū)域內(nèi)的具體代碼,供大家參考,具體內(nèi)容如下
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Date : 2018-10-07 15:49:37
# @Author : Sheldon (thisisscret@qq.com)
# @Blog : 謝耳朵的派森筆記
# @Link : https://www.cnblogs.com/shld/
# @Version : 0.0.1
def isinpolygon(point,vertex_lst:list, contain_boundary=True):
#檢測點(diǎn)是否位于區(qū)域外接矩形內(nèi)
lngaxis, lataxis = zip(*vertex_lst)
minlng, maxlng = min(lngaxis),max(lngaxis)
minlat, maxlat = min(lataxis),max(lataxis)
lng, lat = point
if contain_boundary:
isin = (minlng<=lng<=maxlng) & (minlat<=lat<=maxlat)
else:
isin = (minlng<lng<maxlng) & (minlat<lat<maxlat)
return isin
def isintersect(poi,spoi,epoi):
#輸入:判斷點(diǎn),邊起點(diǎn),邊終點(diǎn),都是[lng,lat]格式數(shù)組
#射線為向東的緯線
#可能存在的bug,當(dāng)區(qū)域橫跨本初子午線或180度經(jīng)線的時(shí)候可能有問題
lng, lat = poi
slng, slat = spoi
elng, elat = epoi
if poi == spoi:
#print("在頂點(diǎn)上")
return None
if slat==elat: #排除與射線平行、重合,線段首尾端點(diǎn)重合的情況
return False
if slat>lat and elat>lat: #線段在射線上邊
return False
if slat<lat and elat<lat: #線段在射線下邊
return False
if slat==lat and elat>lat: #交點(diǎn)為下端點(diǎn),對應(yīng)spoint
return False
if elat==lat and slat>lat: #交點(diǎn)為下端點(diǎn),對應(yīng)epoint
return False
if slng<lng and elat<lat: #線段在射線左邊
return False
#求交點(diǎn)
xseg=elng-(elng-slng)*(elat-lat)/(elat-slat)
if xseg == lng:
#print("點(diǎn)在多邊形的邊上")
return None
if xseg<lng: #交點(diǎn)在射線起點(diǎn)的左側(cè)
return False
return True #排除上述情況之后
def isin_multipolygon(poi,vertex_lst, contain_boundary=True):
# 判斷是否在外包矩形內(nèi),如果不在,直接返回false
if not isinpolygon(poi, vertex_lst, contain_boundary):
return False
sinsc = 0
for spoi, epoi in zip(vertex_lst[:-1],vertex_lst[1::]):
intersect = isintersect(poi, spoi, epoi)
if intersect is None:
return (False, True)[contain_boundary]
elif intersect:
sinsc+=1
return sinsc%2==1
if __name__ == '__main__':
vertex_lst = [[0,0],[1,1],[1,2],[0,2],[0,0]]
poi = [0.82,0.75]
print(isin_multipolygon(poi,vertex_lst, contain_boundary=True))
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺談python3.x pool.map()方法的實(shí)質(zhì)
這篇文章主要介紹了python3.x pool.map方法的實(shí)質(zhì),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01
Pandas數(shù)據(jù)結(jié)構(gòu)中Series屬性詳解
本文主要介紹了Pandas數(shù)據(jù)結(jié)構(gòu)中Series屬性詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
Python應(yīng)用03 使用PyQT制作視頻播放器實(shí)例
本篇文章主要介紹了Python使用PyQT制作視頻播放器實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12
使用__init__.py將文件夾設(shè)置成Python模塊示例詳解
這篇文章主要為大家介紹了使用__init__.py將文件夾設(shè)置成Python模塊示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
棧和隊(duì)列數(shù)據(jù)結(jié)構(gòu)的基本概念及其相關(guān)的Python實(shí)現(xiàn)
這篇文章主要介紹了棧和隊(duì)列數(shù)據(jù)結(jié)構(gòu)的基本概念及其相關(guān)的Python實(shí)現(xiàn),先進(jìn)先出和后進(jìn)先出的知識也已經(jīng)成為了計(jì)算機(jī)學(xué)習(xí)中的老生常談了:D需要的朋友可以參考下2015-08-08
python 實(shí)現(xiàn)人和電腦猜拳的示例代碼
這篇文章主要介紹了python 實(shí)現(xiàn)人和電腦猜拳的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
使用OpenCV實(shí)現(xiàn)讀取和顯示圖像與視頻
OpenCV 是一個(gè)強(qiáng)大的計(jì)算機(jī)視覺庫,廣泛應(yīng)用于圖像處理和視頻處理等領(lǐng)域,本文將詳細(xì)介紹如何使用 OpenCV 在 Python 中讀取和顯示圖像以及視頻,希望對大家有所幫助2024-11-11

