高德地图针对自定义车辆图片,设置车头朝向

// 初始化map
this.map = new AMap.Map(name, {
          resizeEnable: true,
          mapStyle: MAP_STYLE,
          zoom: 11, // 初始化地图层级
          // center: source && source.length ? source : [116.397428, 39.90923], // 初始化地图中心点
        });

// 自定义maker
const makeIcon = (y, x) => {
            const setCurrentMarker = (marker, y, x) => {
               // 设置角度
              let rotateDeg = 0;
              if (source && source.length && target && target.length) {
                const disX = Math.abs(Number(target[0]) - Number(source[0]));
                const dixY = Math.abs(Number(target[1]) - Number(source[1]));
                const tan = Math.tan(dixY / disX);
                const result = Math.atan(tan) / (Math.PI / 180);
                rotateDeg = Math.round(result);
                // 判断区间
                const sectionJudge = (source, target) => {
                  const x1 = source[0];
                  const y1 = source[1];
                  const x2 = target[0];
                  const y2 = target[1];
                  if (x2 > x1 && y2 >= y1) {
                    return 1;
                  } if (x2 >= x1 && y2 < y1) {
                    return 2;
                  } if (x2 < x1 && y2 <= y1) {
                    return 3;
                  } if (x2 <= x1 && y2 > y1) {
                    return 4;
                  }
                  return 5;
                };

                const section = sectionJudge(source, target);
                if (section === 1) {
                  rotateDeg = 90 - rotateDeg;
                } else if (section === 2) {
                  rotateDeg = 90 + rotateDeg;
                } else if (section === 3) {
                  rotateDeg = 180 + (90 - rotateDeg);
                } else if (section === 4) {
                  rotateDeg = 270 + rotateDeg;
                }
              }
              // 自定义点标记内容
              const markerContent = document.createElement('div');

              // 点标记中的图标
              const markerImg = document.createElement('img');
              markerImg.className = 'currentMaker';
              markerImg.src = carImg;
              markerImg.style.transform = `rotate(${rotateDeg}deg)`;
              markerContent.appendChild(markerImg);
              // 当前位置卡片
              const currentCard = trackData.result.last_point.card_info;
              const markerSpan = document.createElement('div');
              markerSpan.className = 'currentMarkerCard';
              markerSpan.innerHTML = `<div class='info'>
                <div>${currentCard.text}</div>
                <div>${currentCard.time}</div>
              </div>`;
              markerContent.appendChild(markerSpan);

              marker.setContent(markerContent); // 设置点标记内容
              marker.setPosition([y, x]); // 设置点标记位置
            };

            let currentMarker = null;
            if (x && y) {
              currentMarker = new AMap.Marker({
                position: new AMap.LngLat(y, x),
                imageOffset: new AMap.Pixel(-13, -30),
              });
              setCurrentMarker(currentMarker, y, x);
            }
            return currentMarker;
          };

// 添加marker

 const currentMaker = makeIcon(currentLocation.lng, currentLocation.lat);
this.map.add(currentMaker);

 

问题描述:我有一张车头朝着正y轴方向的车辆图片,老板要求我根据路线的行径方向动态设置车头的朝向,而不是固定的朝上

解决办法:自定义车辆icon,设置图片的transform, 旋转的角度根据起点和终点的x和y的差值计算偏移角度

写在最后:代码不太完整,方案可能也不是最优的,欢迎提出问题和更优的解决方案

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值