求各位给一个思路~
你这貌似是个纯数学问题,要说思路,你可以用四个小三角形T1-T4把四边形补全成举矩形R,现在不方便画图,你自己想象一下。然后判断给出点p
p 在 R 内 && p 不在 {T1-T4} 内
定义一个 点对象:P[x,y] , x是纬度,y是经度
地块的区域 四个顶点就是 :A[x,y] ,B[x,y] ,C[x,y] ,D[x,y]
已知点 就是 :ptr[x,y]
呃~~
你还是给几个样本吧~
不然,还要向你科普地理知识,就太罗嗦了~
使用mysql空间函数和操作, 保存就直接保存一个多边形区域, 判断的时候使用ST_Contains函数
使用 POINT, ST_AsText, POLYGON, ST_X, ST_Y, ST_DISTANCE, 这些比直接保存经纬好很多.
10 回答11.1k 阅读
6 回答3k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.7k 阅读✓ 已解决
5 回答3.2k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
纠正一下需求,po主的需求是【地理围栏】
解决方案:
PostGis+PostGreSQL
ElasticSearch/Solr
仅靠MySQL怕是不行。
或是重新设计库
参考资料:http://www.cnblogs.com/LBSer/...