zoukankan      html  css  js  c++  java
  • 测距

    在百度地图API中,BMap类有一个可以测距的函数:

    Number getDistance(start:Point, end:Point)

    返回两点之间的距离,单位是米。

    假设现在要测量的是“大唐芙蓉园御苑门”到“大唐天威”之间的距离。

    那么首先要获得这两个地址的经纬度信息。

    “大唐芙蓉园御苑门”的经纬度为:108.977073,34.217936

    “大唐天威”的经纬度为:108.980271,34.218231

    之后在js代码中写入这两个地点。

    <script type="text/javascript">
    
    var map = new BMap.Map("position");
    
    var point = new BMap.Point(108.977073,34.217936);
    var point2 = new BMap.Point(108.980271,34.218231);
    
    map.centerAndZoom(point, 17);
    
    var distance = map.getDistance(point,point2);
    alert(distance);
    
    </script>

    计算结果为:295.8717米

    ----------------------------------------------------------------------------------------

    那么,如果想要知道某个景点周围有多少个X米范围内的其他景点该如何做呢?

    首先,可能会先到弄一个矩阵,然后将景区内的点分别放到横坐标和纵坐标上,然后计算两两之间的距离。

    其次,这个计算应该在何时进行呢?

            是请求出现时再计算,还是先计算好然后存起来,需要时进行读取(空间换时间的概念粗线了!!)?显然后者更适合一些。因为请求时再去计算会有两个问题:①用户等待时间长 ②当很多用户都使用这个服务时,会有很多重复性的计算,也就是冗余的计算。

           so,应该采用事先计算的方法。那么“事先”有应该是何时呢?什么时候算最合适呢?

           很显然,当一个景点被加入景区后,基本上就不会再变动了。所以除非是景点发生移动(?!)否则景点与景点之间的距离都不会改变。因此只需要在景点增删的时候更新这个矩阵即可。

           思路有了,先设计一下DB和代码,明天试试。

  • 相关阅读:
    ubuntu安装
    k8s 安装
    Blazor 路由
    ISO 8601
    Centos 8使用devstack快速安装openstack最新版
    使用devstack 一键安装 openstack详细过程和遇到的坑
    蓝瑟66000公里保养
    释放rsyslog占用的Linux内存
    Netty4.1 Http开发入门(一)服务端
    网络传输中的帧和payload
  • 原文地址:https://www.cnblogs.com/elaron/p/2735092.html
Copyright © 2011-2022 走看看