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和代码,明天试试。

  • 相关阅读:
    判断arm立即数是否合法的小程序
    一个操作系统的实现:关于ALIGN的若干解释
    一个郁闷的C语言小问题
    test
    浮点数的比较
    一个操作系统的实现:Descriptor 3详解
    一个操作系统的实现:关于CPL、RPL、DPL
    C99可变长数组VLA详解
    SVProgressHUD 用法
    IOS CALayer 详解
  • 原文地址:https://www.cnblogs.com/elaron/p/2735092.html
Copyright © 2011-2022 走看看