Skip to content

点标记

地图点标记组件

基础示例

vue
<template>
  <tlbs-map
    ref="mapRef"
    api-key="OB4BZ-D4W3U-B7VVO-4PJWW-6TKDJ-WPB77"
    :center="center"
    :zoom="zoom"
    :control="control"
    @click="onClick"
    @map_inited="onMapInited"
  >
    <tlbs-multi-marker
      ref="markerRef"
      :geometries="geometries"
      :styles="styles"
      :options="options"
    />
    <div class="control-container">
      <button @click.stop="getLayerInstance">
        打印点标记实例
      </button>
    </div>
  </tlbs-map>
</template>

<script lang="ts">
import { defineComponent, ref } from 'vue-demi';

export default defineComponent({
  name: 'MarkerDemo',
  setup() {
    const mapRef = ref(null);
    const markerRef = ref(null);
    const center = ref({ lat: 39.91799, lng: 116.397027 });
    const zoom = ref(10);
    const onClick = (e: Event) => {
      console.log(e);
    };

    const onMapInited = () => {
      // 地图加载完成后,可以获取地图实例、点标记实例,调用地图实例、点标记实例方法
      console.log(mapRef.value.map);
      console.log(markerRef.value.marker);
    };

    const getLayerInstance = () => {
      // 可以获取点标记实例,调用点标记实例方法
      console.log(markerRef.value.marker);
    };

    return {
      center,
      zoom,
      onClick,
      onMapInited,
      getLayerInstance,
      control: {
        scale: {},
        zoom: {
          position: 'topRight',
        },
      },
      mapRef,
      markerRef,
      geometries: [
        { styleId: 'marker',  position: { lat: 39.91799, lng: 116.397027 } },
      ],
      styles: {
        marker: {
          width: 20,
          height: 30,
          anchor: { x: 10, y: 30 },
        },
      },
      options: {
        minZoom: 5,
        maxZoom: 15,
      },
    };
  },
});
</script>

props

名称类型说明
idString图层 id
styles{ [key: string]: TMap.MarkerStyleOptions }点的相关样式
geometriesTMap.PointGeometry[]点数据数组
optionsTMap.MultiMarkerOptions除了上述属性的其他配置参数,点击下面官网文档链接查看

上述属性数据格式可参考官网文档 https://lbs.qq.com/webApi/javascriptGL/glDoc/glDocMarker

事件

事件支持列表参考官网文档 https://lbs.qq.com/webApi/javascriptGL/glDoc/glDocMarker

组件实例属性

名称类型说明
markerTMap.MultiMarker点标记实例。实例方法参考