• 值绘制轨迹


    for (var i = 0, j = trackPoint.length; i < j; i++) {
    var marker = new BMap.Marker(trackPoint[i], {
    icon: icon,
    offset: offset
    }); // 创建标注
    map.addOverlay(marker);

    }

    //根据经纬极值计算绽放级别。 (从网上复制)
    function getZoom(maxLng, minLng, maxLat, minLat) {(http://www.amjmh.com)
    var zoom = ["50", "100", "200", "500", "1000", "2000", "5000", "10000", "20000", "25000", "50000", "100000", "200000", "500000", "1000000", "2000000"]; // 级别18到3。
    var pointA = new BMap.Point(maxLng, maxLat); // 创建点坐标A
    var pointB = new BMap.Point(minLng, minLat); // 创建点坐标B
    var distance = map.getDistance(pointA, pointB).toFixed(1); //获取两点距离,保留小数点后两位
    for (var i = 0, zoomLen = zoom.length; i < zoomLen; i++) {
    if (zoom[i] - distance > 0) {
    return 18 - i + 3; //之所以会多3,是因为地图范围常常是比例尺距离的10倍以上。所以级别会增加3。
    }
    }
    }

    // (从网上复制)
    function setZoom(points) {
    if (points.length > 0) {
    var maxLng = points[0].lng;
    var minLng = points[0].lng;
    var maxLat = points[0].lat;
    var minLat = points[0].lat;
    var res;
    for (var i = points.length - 1; i >= 0; i--) {
    res = points[i];
    if (res.lng > maxLng) maxLng = res.lng;
    if (res.lng < minLng) minLng = res.lng;
    if (res.lat > maxLat) maxLat = res.lat;
    if (res.lat < minLat) minLat = res.lat;
    }
    var cenLng = (parseFloat(maxLng) + parseFloat(minLng)) / 2;
    var cenLat = (parseFloat(maxLat) + parseFloat(minLat)) / 2;
    var zoom = getZoom(maxLng, minLng, maxLat, minLat);
    map.centerAndZoom(new BMap.Point(cenLng, cenLat), zoom);
    } else {
    //没有坐标,显示全中国
    map.centerAndZoom(new BMap.Point(103.388611, 35.563611), 5);
    }
    }

    setZoom(pointArr)

  • 相关阅读:
    插入数据Oracle异常ORA-01502: 索引或这类索引的分区处于不可用状态
    关于分布式系统的数据一致性问题
    C#网络编程系列文章之Socket实现异步TCP服务器
    大型网站架构与分布式架构
    序列化表单为json
    学习wcf
    C# 知识梳理
    Java前端控制器模式
    Java策略模式
    Java责任链模式
  • 原文地址:https://www.cnblogs.com/ly570/p/11304720.html
Copyright © 2020-2023  润新知