原文:基于高德地图的描点操作,监听地图缩放,展示合理数量的marker

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lx583274568/article/details/54089707

1.根据两点经纬度算两点之间的距离函数

function Rad(d){
return d * Math.PI / 180.0;//经纬度转换成三角函数中度分表形式。
}
//计算距离,参数分别为第一点的纬度,经度;第二点的纬度,经度
function GetDistance(lat1,lng1,lat2,lng2){ var radLat1 = Rad(lat1);
var radLat2 = Rad(lat2);
var a = radLat1 - radLat2;
var b = Rad(lng1) - Rad(lng2);
var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) +
Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));
s = s *6378.137 ;// EARTH_RADIUS;
s = Math.round(s * 10000) / 10000; //输出为公里
//s=s.toFixed(4);
return s;
}

2.给地图绑定监听事件

map.on("zoomchange",function(){
for (var i = pathContentArr.length - 1; i >= 0; i--) {
pathContentArr[i].setMap(null);
}
for (var i = pathMarkerArr.length - 1; i >= 0; i--) {
pathMarkerArr[i].setMap(null);
}
pathMarkerArr=[];
pathContentArr=[];
drawMarkerByDistance(map.getZoom()) })

3.drawMarkerByDistance函数【会根据第i个点和第i+1个点之间的距离进行初步筛选,其中select函数对初步筛选出来的点进行了所有点两两之间距离的二次筛选】

function drawMarkerByDistance(zoom){
        var perDistance=0;   //当前累计公里数
        var zoom=zoom||6;
        switch (zoom){
            case 3:
                var targetDistance=800;  //km
                break;
            case 4:
                var targetDistance=400;  //km
                break;
            case 5:
                var targetDistance=200;  //km
                break;
            case 6:
                var targetDistance=120;  //km
                break;
            case 7:
                var targetDistance=60;  //km
                break;
            case 8:
                var targetDistance=30;  //km
                break;
            case 9:
                var targetDistance=15;  //km
                break;
            case 10:
                var targetDistance=7;  //km
                break;
            case 11:
                var targetDistance=4;  //km
                break;
            case 12:
                var targetDistance=1;  //km
                break;
            case 13:
                var targetDistance=0.5;  //km
                break;
            default:
                var targetDistance=0.25;  //km
        }
        var prepareToShowMarker=[];
        for (var i = 0; i < curShipPolyLineData.length; i++) {
            //第一个点和最后一个点默认展示出来,累计长度大于目标长度的画出来
            if (i==0||i==curShipPolyLineData.length-1 || (curShipPolyLineData[i].distance+perDistance)>targetDistance) {
                var marker={
                    lat:parseFloat(curShipPolyLineData[i].latitude),
                    lng:parseFloat(curShipPolyLineData[i].longitude),
                    course:curShipPolyLineData[i].course,
                    AddTime: curShipPolyLineData[i].AddTime,
                }
                prepareToShowMarker.push(marker);
            }
            if(i<curShipPolyLineData.length-1 && i>1){
                if ((curShipPolyLineData[i].distance+perDistance)>targetDistance) {
                    perDistance=0;
                }else{
                    perDistance+=curShipPolyLineData[i].distance;
                }
            }
        }
        
        var select=function(arr){
            var flag=true;
            for(var i=0;i<arr.length;i++){
                for(var j=i+1;j<arr.length;j++){
                    var curdistance=GetDistance(arr[i].lat,arr[i].lng,arr[j].lat,arr[j].lng);
                    //如果还有靠得很近的点
                    if (curdistance<targetDistance) {
                        flag=false;
                        //随机剔除掉一个i和j之间的一个点
                        Math.random()>0.5?arr.splice(i,1):arr.splice(j,1);
                        break;
                    }
                }
                if(flag==false){
                    break;
                }
            }
            //当数组中所有的点两两之间的距离都大于targetDistance的时候退出递归
            if (flag==false) {
                select(arr);
            }
        }
        select(prepareToShowMarker);
        for (var i = prepareToShowMarker.length - 1; i >= 0; i--) {
            var position=[prepareToShowMarker[i].lng,prepareToShowMarker[i].lat];
            var content = new AMap.Marker({
                content:prepareToShowMarker[i].AddTime,
                position: position,
                title: prepareToShowMarker[i].AddTime,
                offset:new AMap.Pixel(20,0),
                map: map
            });
            pathContentArr.push(content);
            var marker = new AMap.Marker({
                offset:new AMap.Pixel(0,0),
                icon:"new_images/arrow_r.png",
                angle:((prepareToShowMarker[i].course-90)%360),
                position: position,
                map: map
            });
            pathMarkerArr.push(marker);
        }         
    }

基于高德地图的描点操作,监听地图缩放,展示合理数量的marker的更多相关文章

  1. Android Google Maps 监听地图缩放

    接上篇.http://www.cnblogs.com/maomishen/p/3556297.html 由于公司项目要求,需要对google map监听地图的缩放(zoom)来进行一些操作. 但是在网 ...

  2. iOS 百度地图监听地图状态

    百度地图提供了地图状态的对象BMKMapStatus ///此类表示地图状态信息 @interface BMKMapStatus : NSObject { float _fLevel; // 缩放比例 ...

  3. 基于Lua插件化的Pcap流量监听代理

    1.前言 我们在实际工作中,遇到了一个这样的用例,在每天例行扫描活动中,发现有些应用系统不定期的被扫挂,因为我们不是服务的制造者,没有办法在不同的系统里打印日志,所以我们就想用一个工具来获取特定服务的 ...

  4. openlayers 3监听地图分辨率变化事件

    map.getView().on('change:resolution',checkZoom);//checkZoom为调用的函数 function checkZoom() { // alert(&q ...

  5. PIE SDK地图范围设置和图层事件监听

    1. 功能简介 地图范围设置的监听就是通过IMapControlEvents接口对地图的视图范围更新或者地图的分辨率发生变化进行监听,然后做出相应的操作. 图层事件的监听就是通过IActiveView ...

  6. NSOperation操作依赖和监听

    1.操作依赖 NSOperation之间可以设置依赖来保证执行顺序 比如一定要让操作A执行完后,才能执行操作B,可以这么写 [operationB addDependency:operationA]; ...

  7. iOS开发NSOperation 三:操作依赖和监听以及线程间通信

    一:操作依赖和监听 #import "ViewController.h" @interface ViewController () @end @implementation Vie ...

  8. Python 键盘鼠标监听

    异想天开的想记录一下自己每天的键盘键位走向,于是就在网上搜索了一下相关的实现,然后就发现了一个第三方的库pyHook.封装的很好,我们只需要傻瓜式的调用里面的API就可以了. 下面是我在使用pyHoo ...

  9. 8、Curator的监听机制

    原生的zookeeper的监听API所实现的方法存在一些缺点,对于开发者来说后续的开发会考虑的细节比较多. Curator所实现的方法希望摒弃原声API 的不足,是开发看起来更加的简单,一些重连等操作 ...

随机推荐

  1. Java中使用org.json和json-lib解析JSON

    文章目录  [隐藏] 一.JavaProject中org.json解析JSON 1.JSON的org.son-api下载 1)JSON网址 2)JSON的java解析org.json-api网址 3) ...

  2. Batch Normalization 反向传播(backpropagation )公式的推导

    What does the gradient flowing through batch normalization looks like ? 反向传播梯度下降权值参数更新公式的推导全依赖于复合函数求 ...

  3. pstack.sh 改进版

    pstack.sh 改进版本 #!/bin/bash if (( $# < 1 )) ; then echo "usage: `basename $0` pid" 1> ...

  4. ViewChild与ContentChild的联系和区别

    原文 https://www.jianshu.com/p/5ab619e576ea 大纲 1.认识ViewChild 2.认识ContentChild 3.ViewChild与ContentChild ...

  5. Android开发中的小技巧

    转自:http://blog.csdn.net/guxiao1201/article/details/40655661 简单介绍: startActivities (Intent[] intents) ...

  6. 慎重Asp.net中static变量的使用方法

    在.Net平台下进行CS软件开发时,我们常常遇到以后还要用到某些变量上次改动后的值,为了简单起见,非常多人都习惯用static来定义这些变量,我也是.这样非常方便.下一次调用某个函数时该变量仍然保存的 ...

  7. sysbench压测Oracle

    安装: yum -y install make m4  autoconf automake libtool pkgconfig libaio-devel rpm -Uvh http://dl.fedo ...

  8. hibernate框架配置文件

    配置文件:和自己封装的工具类放在同一个包中 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ...

  9. [tmux] Customize tmux with tmux.conf

    You can modify tmux's behavior with your tmux configuration file, .tmux.conf. You can use your tmux ...

  10. 机器学习: Softmax Classifier (三个隐含层)

    程序实现 softmax classifier, 含有三个隐含层的情况.activation function 是 ReLU : f(x)=max(0,x) f1=w1x+b1 h1=max(0,f1 ...