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

// 初始化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的差值计算偏移角度

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自定义高德地图的Marker,可以按照以下步骤操作: 1. 创建MarkerOptions对象,设置Marker的经纬度、图标等属性。 2. 通过AMap类的addMarker方法将Marker添加到地图上。 3. 通过AMap类的setInfoWindowAdapter方法设置Marker的信息窗口。 4. 通过AMap类的setOnMarkerClickListener方法设置Marker的点击事件。 具体实现代码如下: ``` // 创建MarkerOptions对象 MarkerOptions markerOptions = new MarkerOptions(); LatLng latLng = new LatLng(39.906901, 116.397972); markerOptions.position(latLng); markerOptions.title("Marker标题"); markerOptions.snippet("Marker描述"); markerOptions.icon(BitmapDescriptorFactory.fromResource(R.drawable.marker_icon)); // 添加Marker到地图上 Marker marker = aMap.addMarker(markerOptions); // 设置Marker的信息窗口 aMap.setInfoWindowAdapter(new AMap.InfoWindowAdapter() { @Override public View getInfoWindow(Marker marker) { View view = getLayoutInflater().inflate(R.layout.marker_info_window, null); TextView titleTextView = view.findViewById(R.id.title); TextView snippetTextView = view.findViewById(R.id.snippet); titleTextView.setText(marker.getTitle()); snippetTextView.setText(marker.getSnippet()); return view; } @Override public View getInfoContents(Marker marker) { return null; } }); // 设置Marker的点击事件 aMap.setOnMarkerClickListener(new AMap.OnMarkerClickListener() { @Override public boolean onMarkerClick(Marker marker) { marker.showInfoWindow(); return true; } }); ``` 其中,R.drawable.marker_icon是你自定义的Marker图标。marker_info_window是你自定义的Marker信息窗口布局。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值