Vue实现高德地图信息窗

在这里插入图片描述

<template>
  <div class="app-container" :style="{ height: windowHeight - 50 + 'px' }">
    <div id="container"></div>
    <div class="input-item">
      <h5>设置 anchor</h5>
      <el-radio-group v-model="radio" @change="coordinate">
        <el-radio class="input-card" size="mini" round label="top-left">top-left</el-radio>
        <el-radio class="input-card" size="mini" round label="top-center">top-center</el-radio>
        <el-radio class="input-card" size="mini" round label="top-right">top-right</el-radio>
        <el-radio class="input-card" size="mini" round label="middle-left">middle-left</el-radio>
        <el-radio class="input-card" size="mini" round label="center">center</el-radio>
        <el-radio class="input-card" size="mini" round label="middle-right">middle-right</el-radio>
        <el-radio class="input-card" size="mini" round label="bottom-left">bottom-left</el-radio>
        <el-radio class="input-card" size="mini" round label="bottom-center">bottom-center</el-radio>
        <el-radio class="input-card" size="mini" round label="bottom-right">bottom-right</el-radio>
      </el-radio-group>
    </div>
  </div>
</template>

<script>
  export default {
    name: "index",
    data() {
      return {
        //实时屏幕高度
        windowHeight: document.documentElement.clientHeight,
        map: null,
        infoWindow: null,
        radio: 'top-left'
      }
    },
    mounted() {
      // 当浏览器被重置大小时执行
      window.onresize = () => {
        return (() => {
          this.windowHeight = document.documentElement.clientHeight;
        })()
      };
      //调用地图初始化方法
      this.initAMap()
    },
    methods: {
      initAMap() {
        let map = new AMap.Map("container", {
          center: [116.402023,39.906977],
          zoom: 13,
          viewMode: '3D',
        });

        var position = [116.401337,39.907886];

        //构建自定义信息窗体
        this.infoWindow = new AMap.InfoWindow({
          anchor: 'top-left',
          content: '这是信息窗体!这是信息窗体!',
        });

        this.infoWindow.open(map, position);


        new AMap.Marker({position: position, map});
      },

      setAnchor() {
        let anchor = this.id;
        this.infoWindow.setAnchor(anchor)
      },
      coordinate(){
        this.infoWindow.setAnchor(this.radio)
      }
    }
  }
</script>

<style scoped>
  #app-container {
    width: 100%;
    position: relative
  }

  #container {
    width: 100%;
    height: 100%;
  }

  .info {
    position: absolute;
    background: white;
    padding: 10px;
    right: 30px;
    top: 30px;
  }

  .input-item {
    position: absolute;
    background: white;
    padding: 10px 20px;
    right: 30px;
    bottom: 30px;
  }

  .input-item .input-card {
    display: block;
    margin: 10px;
  }

</style>

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue高德地图区域绑定信息是指在Vue组件中使用高德地图API实现区域与信息口的绑定功能。 首先,我们需要安装并引入高德地图JavaScript API库。可以使用npm安装或者通过CDN引入。然后,在Vue组件的mounted钩子函数中初始化地图实例。 接着,我们可以通过高德地图提供的API创建区域、信息口,并将它们绑定在一起。首先,使用AMap.Polygon对象创建一个区域,并设置区域的坐标点。然后,使用AMap.InfoWindow对象创建一个信息口,并设置其内容及位置。 接下来,在Vue组件的data属性中,定义一个变量来保存区域和信息口的实例。然后,在初始化地图实例时,将该变量与地图实例绑定,以便在其他方法中使用。 然后,在Vue组件的methods属性中,定义一个方法来显示信息口。在该方法中,通过调用信息口实例的open方法,将信息口显示在指定的位置。 最后,在区域的点击事件中,调用显示信息口的方法,以实现点击区域时弹出相应的信息口。 总结起来,使用Vue高德地图区域绑定信息的步骤包括初始化地图实例、创建区域和信息口、定义变量保存实例、编写显示信息口的方法、设置区域的点击事件来触发显示信息口的方法。通过这些步骤,我们可以实现Vue组件中使用高德地图API来绑定区域和信息口的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鸥总

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值