vue 高德地图 添加多个自定义图标 数字 加入点标记初始动画 鼠标移入移出动画 加入点击按钮 点标记跳动动画

<script src="https://webapi.amap.com/maps?v=1.4.15&key=自己的key值"></script>
 
    data中声明: marker: null, markers: []

     for (let i = 0; i < this.List.length; i++) {
        this.marker = new AMap.Marker({
          position: this.scenicList[i].point,
          animation: 'AMAP_ANIMATION_DROP',
          extData: this.scenicList[i],
          icon: new AMap.Icon({
            size: new AMap.Size(40, 55),
            image: '',//自己的图片
            imageSize: new AMap.Size(40, 55)
          }),
          label: {
            offset: new AMap.Pixel(12, 15),
            content: i + 1,
            style: {
              width: "33px",
              height: "48px",
              lineHeight: "48px",
              textAlign: "center",
              color: "#528495"
            }
          }
        })
        this.markers.push(this.marker)
        this.marker.setMap(map);
        this.marker.on("click", (e) => {});//点击事件
        // 鼠标悬浮时触发动画效果
        this.marker.on('mouseover', function () { this.marker.setAnimation('AMAP_ANIMATION_BOUNCE'); });
        // 鼠标移开时停止动画效果
        this.marker.on('mouseout', function () { this.marker.setAnimation(null); });
        map.setFitView();
      }
      this.map.add(this.markers)

  list:[]//存档数据数组
  点击事件 
  setAdd(el, index) {
      //点击点聚合操作
      this.map.setCenter(el.point);
      //根据点击的下标找到对应的点标记
      this.markers[index].setAnimation('AMAP_ANIMATION_BOUNCE');
      //加入定时器 2s后清除动画
      setTimeout(() => {
        this.markers[index].setAnimation(null);
      }, 2000);
    },

待解决问题
点标记为10 数字并未居中  




 

 this.List=[{point:['121.258417','29.685926'] } ]
 这里是自己的坐标

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你可以使用高德地图 JavaScript API 来在 Vue 中集成高德地图。然后在获取到数据后,使用 `addMarkers()` 方法添加多个标记,该方法接收一个标记数组作为参数。 接下来,你可以使用 `setAnimation()` 方法将点击按钮对应的标记设置为“跳动动画。该方法接收一个 `AMap.Marker.AnimationName` 枚举值作为参数,可以设置为 `AMap.Marker.AnimationName.BOUNCE` 来实现跳动效果。 以下是一个简单的示例代码: ```html <template> <div id="map-container"></div> <button @click="startAnimation">开始跳动</button> </template> <script> import AMapLoader from '@amap/amap-jsapi-loader' export default { data() { return { map: null, markers: [] } }, mounted() { AMapLoader.load({ key: 'your-amap-api-key', version: '2.0', plugins: ['AMap.MarkerClusterer'] }).then(AMap => { this.map = new AMap.Map('map-container', { zoom: 13, center: [116.397428, 39.90923] }) const marker1 = new AMap.Marker({ position: [116.407428, 39.90923] }) const marker2 = new AMap.Marker({ position: [116.417428, 39.90923] }) const marker3 = new AMap.Marker({ position: [116.427428, 39.90923] }) this.markers = [marker1, marker2, marker3] this.map.addMarkers(this.markers) }) }, methods: { startAnimation() { // 假设击第二个标记 this.markers[1].setAnimation(AMap.Marker.AnimationName.BOUNCE) } } } </script> ``` 在实际应用中,你需要根据实际需求修改代码,并在适当的时机添加标记和设置动画

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值