百度地图API实时画出动态运行轨迹(一条行驶轨迹),车头实时指向行驶方向,设置角度偏移

2020-02-24 18:41:15

参考地址 百度地图API实时画出动态运行轨迹(一条行驶轨迹),车头实时指向行驶方向,设置角度偏移


参考网址:https://blog.csdn.net/skywqnan/article/details/79036262

改变车的方向:http://www.cnblogs.com/peixuanzhihou/p/6540086.html

代码如下:

<!doctype html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>百度地图的动态行驶轨迹</title>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=wIt2mDCMGWRIi2pioR8GZnfrhSKQHzLY"></script>
</head>
<body>
<div id="mapId" style="height: 500px;">
    <script>
        var map = new BMap.Map("mapId");
        map.enableScrollWheelZoom(); // 开启鼠标滚轮缩放
        map.addControl(new BMap.ScaleControl()); // 添加比例尺控件
        // map.centerAndZoom("青岛", 8);

        var PointArr = [
            {lat: 36.10339957700999, lng: 120.4207801005104},
            {lat: 36.10349055332635,lng: 120.42113539348455},
            {lat: 36.10370795896673,lng: 120.42162977768736},
            {lat: 36.10411490190429,lng: 120.42166901055167},
            {lat: 36.104232027406695,lng: 120.42185015059275},
            {lat: 36.10425620255758,lng: 120.42202022562539},
            {lat: 36.104265908631284,lng: 120.42208225102176},
            {lat: 36.104399968669526,lng: 120.42187425183421},
            {lat: 36.10452708476511,lng: 120.42076268466177},
            {lat: 36.10480132817409, lng: 120.4196557913201},
            {lat: 36.10560773716036,lng: 120.418951386886},
            {lat: 36.10621159088823,lng: 120.41900182905378},
            {lat: 36.1064641068988,lng: 120.41992809616544},
            {lat: 36.10679444086644,lng: 120.42102125032955},
            {lat: 36.107010189089046,lng: 120.42182982905027},
            {lat: 36.107014665948654,lng: 120.42193587265254},
            {lng: 120.42201589513277, lat: 36.10700627324672},
            {lng: 120.42201589513277, lat: 36.10700627324672},
            {lng: 120.42236704579075, lat: 36.10708566579729},
            {lng: 120.42269817692573, lat: 36.107201270041955},
            {lng: 120.42239277578172, lat: 36.10812797579566},
            {lng: 120.42175457671763, lat: 36.10947659586882},
            {lng: 120.42144906678747, lat: 36.11028554037044},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.4213722360578, lat: 36.110547069787465},
            {lng: 120.42134433787885, lat: 36.110691285540966},
            {lng: 120.42234193234574, lat: 36.110931417305515},
            {lng: 120.42374305054953, lat: 36.11109804633305},
            {lng: 120.42478859440246, lat: 36.111102173671576},
            {lng: 120.42606467439863, lat: 36.11129314178323},
            {lng: 120.4274220550685, lat: 36.11148065963647},
            {lng: 120.42831965719076, lat: 36.111638311669736},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42839951065358, lat: 36.11164240198062},
            {lng: 120.42869196887202, lat: 36.1116737914188},
            {lng: 120.43031048017785, lat: 36.11190642360766},
            {lng: 120.43239173942534, lat: 36.11229570404404},
            {lng: 120.43368467575368, lat: 36.11281195352835},
            {lng: 120.43371757862009, lat: 36.11284016439977},
            {lng: 120.43379230066179, lat: 36.11284161798212},
            {lng: 120.43441423254144, lat: 36.113205746094536},
            {lng: 120.43549342023326, lat: 36.11391074053337},
            {lng: 120.43637497341942, lat: 36.11441797319607},
            {lng: 120.4365024200745, lat: 36.11445405475196},
            {lng: 120.43670459776231, lat: 36.11458083085174},
            {lng: 120.43745246924915, lat: 36.11507070008782},
            {lng: 120.43821097991501, lat: 36.115416050767585},
            {lng: 120.43821097991501, lat: 36.115416050767585},
            {lng: 120.43821097991501, lat: 36.115416050767585},
            {lng: 120.43821097991501, lat: 36.115416050767585},
            {lng: 120.43821097991501, lat: 36.115416050767585},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43823585473245, lat: 36.11541929557907},
            {lng: 120.43859812511984, lat: 36.115583971494395},
            {lng: 120.43901701857004, lat: 36.115714318017346},
            {lng: 120.43928467292172, lat: 36.11582517772885},
            {lng: 120.43959708522435, lat: 36.115963587312805},
            {lng: 120.43986466921422, lat: 36.116047547858166},
            {lng: 120.44007952157578, lat: 36.11611896447754},
            {lng: 120.440167025596, lat: 36.11612294605039},
            {lng: 120.440167025596, lat: 36.11612294605039},
            {lng: 120.44024360205321, lat: 36.116138815526504},
            {lng: 120.44024360205321, lat: 36.116138815526504},
            {lng: 120.44024360205321, lat: 36.116138815526504},
            {lng: 120.44026150723737, lat: 36.11614702160796},
            {lng: 120.44027344364953, lat: 36.11615215895656},
            {lng: 120.44027344364953, lat: 36.11615215895656},
            {lng: 120.44028836484941, lat: 36.1161593311561},
            {lng: 120.44034209724579, lat: 36.116201960713745},
            {lng: 120.44048233691922, lat: 36.116254585044935},
            {lng: 120.44048233691922, lat: 36.116254585044935},
            {lng: 120.4405738257871, lat: 36.116276646228826},
            {lng: 120.44073595695149, lat: 36.11635856195875},
            {lng: 120.44115463412841, lat: 36.11652357056175},
            {lng: 120.44118546544034, lat: 36.11653994619434},
            {lng: 120.44118546544034, lat: 36.11653994619434},
            {lng: 120.44121529948468, lat: 36.1165533090833}];
        map.centerAndZoom(PointArr, 13);// 根据经纬度显示地图的范围
        map.setViewport(PointArr);// 根据提供的地理区域或坐标设置地图视野

        addStartMarker(new BMap.Point(PointArr[0].lng, PointArr[0].lat),'起点',map);
        var carMk;//先将终点坐标展示的mark对象定义
        //小车行驶图标
        var drivingPoint = new BMap.Icon('http://developer.baidu.com/map/jsdemo/img/car.png', new BMap.Size(52,26), {
            anchor : new BMap.Size(27, 13),
            imageSize:new BMap.Size(52,26)
        });
        //终点图标
        var terminalPoint = new BMap.Icon('endMap.png', new BMap.Size(45,45), {
            anchor : new BMap.Size(20, 45),
            imageSize:new BMap.Size(45,45)
        });
        var i = 0;
        var interval = setInterval(function () {
            if (i >= PointArr.length) {
                clearInterval(interval);
                return;
            }
            drowLine(map,PointArr[i],PointArr[i+1]);//画线调用
            i = i + 1;
        }, 1000);

        // 划线
        function drowLine(map,PointArr,PointArrNext) {
            if(PointArrNext!=undefined) {
                var polyline = new BMap.Polyline(
                    [
                        new BMap.Point(PointArr.lng, PointArr.lat),
                        new BMap.Point(PointArrNext.lng, PointArrNext.lat)
                    ],
                    {
                        strokeColor: "red",
                        strokeWeight: 7,
                        strokeOpacity: 1
                    });   //创建折线
                map.addOverlay(polyline);
                addMarkerEnd(new BMap.Point(PointArrNext.lng, PointArrNext.lat), '小车行驶', map, PointArrNext, new BMap.Point(PointArr.lng, PointArr.lat));//添加图标
            }else {
                addMarkerEnd(new BMap.Point(PointArr.lng, PointArr.lat), '终点', map);//添加终点图标
            }
        }
        //添加起始图标
        function addStartMarker(point, name,mapInit) {
            if(name=="起点"){
                var myIcon = new BMap.Icon("startMap.png", new BMap.Size(45,45),{
                    anchor: new BMap.Size(20, 45),//这句表示图片相对于所加的点的位置mapStart
                    imageSize:new BMap.Size(45, 45)//图标所用的图片的大小,此功能的作用等同于CSS中的background-size属性。可用于实现高清屏的高清效果
                    // offset: new BMap.Size(-10, 45), // 指定定位位置
                    // imageOffset: new BMap.Size(0, 0 - 10 * 25) // 设置图片偏移
                });
                window.marker = new BMap.Marker(point,{icon:myIcon});  // 创建标注
                mapInit.addOverlay(marker);               // 将标注添加到地图中
                //marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画
            }
        }
        //添加行驶和终点图标
        function addMarkerEnd(point, name,mapInit,trackUnit,prePoint) {
            if(name=="小车行驶"){
                if(carMk){//先判断第一次进来的时候这个值有没有定义,有的话就清除掉上一次的。然后在进行画图标。第一次进来时候没有定义也就不走这块,直接进行画图标
                    mapInit.removeOverlay(carMk);
                }
                carMk = new BMap.Marker(point,{icon:drivingPoint});  // 创建标注
                carMk.setRotation(trackUnit.route);//trackUnit.route
                //getAngle(point,prePoint);// js求解两点之间的角度
                carMk.setRotation(getAngle(point,prePoint)-90);// 旋转的角度
                mapInit.addOverlay(carMk);               // 将标注添加到地图中
                //carMk.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画
            }else {
                mapInit.removeOverlay(carMk);
                carMk = new BMap.Marker(point,{icon:terminalPoint});  // 创建标注
                mapInit.addOverlay(carMk);
            }
        }
        //获得角度的函数
        function getAngle(n,next){
            var ret
            var w1 = n.lat/180 * Math.PI
            var j1 = n.lng/180 * Math.PI

            var w2 = next.lat/180 * Math.PI
            var j2 = next.lng/180 * Math.PI

            ret = 4 * Math.pow(Math.sin((w1 - w2) / 2), 2) - Math.pow(Math.sin((j1 - j2) / 2) * (Math.cos(w1) - Math.cos(w2)), 2);
            ret = Math.sqrt(ret);

            // var temp = Math.sin(Math.abs(j1 - j2) / 2) * (Math.cos(w1) + Math.cos(w2));
            var temp = Math.sin((j1 - j2) / 2) * (Math.cos(w1) + Math.cos(w2));
            console.log(temp)
            ret = ret/temp;

            ret = Math.atan(ret) / Math.PI * 180 ;
            ret += 90;

            // 这里用如此臃肿的if..else是为了判定追踪单个点的具体情况,从而调整ret的值
            if(j1-j2 < 0){
                // console.log('j1<j2')
                if(w1-w2 < 0){
                    // console.log('w1<w2')
                    ret;
                }else{
                    // console.log('w1>w2')
                    ret = -ret+180;
                }
            }else{
                // console.log('j1>j2')
                if(w1-w2 < 0){
                    // console.log('w1<w2')
                    ret = 180+ret;
                }else{
                    // console.log('w1>w2')
                    ret = -ret;
                }
            }
            return ret ;
        }


    </script>
</body>
</html>


  • 2020-04-17 09:27:38

    推荐一个老前端开发者的博客

    前端修炼场,首页标签大全greenSock前端研究VUE研究我们的作品flash技术探讨开发心得个人档案培训与招聘服务报价

  • 2020-04-17 09:41:47

    前端css博客推荐

    这个博客有大量的css内容,有svg,TweenMax等教程,抽空通读一下

  • 2020-04-17 10:20:47

    GreenSocks Animation Platform详细工作机制以及TweenMax用法

    GSAP(GreenSocks Animation Platform)是一个性能较好的前端动画库。最近在写一个前端SVG动画编辑器时选择了它作为底层的动画库。为了减少踩坑,我大致浏览了它的源代码,这篇文章主要是对我的理解进行记录。 我会先简单介绍一下这个动画库的API,再介绍它的插件机制,最后会从一个用例出发跟踪其运行机制。

  • 2020-04-17 10:39:02

    CSS 滤镜技巧与细节,实现火焰,融合等特效

    简单来说,CSS 滤镜就是提供类似 PS 的图形特效,像模糊,锐化或元素变色等功能。通常被用于调整图片,背景和边界的渲染。本文就会围绕这些滤镜展开,看看具体能怎么使用或者玩出什么花活。

  • 2020-04-17 10:42:29

    (三)TweenMax运动效果

    运动效果 实例化对象.set() 立刻运动到指定地点,不用加时间

  • 2020-04-17 11:19:55

    Vue中的is和操作DOM

    vue中is的属性引入是为了解决dom结构中对放入html的元素有限制的问题,譬如ul里面要接上li的标签,引入is的属性后,你完全可以写成这样

  • 2020-04-17 11:27:48

    TweenMax中文初级教程一

    TweenMax.js集成了GreenSock动画平台的大部分核心功能,且具有极高的兼容性。

  • 2020-04-17 11:28:35

    TweenMax中文初级教程二

    TimelineMax是GreenSock 动画平台中的动画组织、排序、管理工具,可创建时间轴(timeline)作为动画或其他时间轴的容器,这使得整个动画控制和精确管理时间变得简单,避免了通过反复delay和回调进行动画。 作者:李霖弢 链接:https://www.jianshu.com/p/8c0361e43bf5 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 2020-04-17 11:28:57

    TweenMax中文初级教程三

    动画关键词:CSS(一般可以省略) CSSPlugin用于在TweenMax中对DOM元素的CSS相关属性进行动画 在CSSPlugin中CSS属性需要写成驼峰式,例如font-size应当写作fontSize。有时候你可以在一些默认px为单位的属性中省略单位,CSSPlugin还可以在不同的单位间做动画: