mapbox setLayoutProperty 实现地图切换

上两篇分别写了地图的展示,和百度下标的样式,要求做一个可以切换地图的,先来个图片

这个实现了线和点在地图中的切换  https://docs.mapbox.com/mapbox-gl-js/example/toggle-layers/

这个根据官网的例子做了处理,

setLayoutProperty设置指定样式图层中布局属性的值。

参数

layer 要设置布局属性的图层的ID。 (string)

name 要设置的布局属性的名称。 (string)

value 布局的值。必须是适合该属性的类型,如Mapbox样式规范中所定义 。 (any)

选项(默认)(Object?){}

名称

描述

options.validate
boolean
默认true

是否检查是否 value 符合Mapbox GL样式规范。禁用验证是一种性能优化,只有在您事先验证了要传递给此函数的值时才应使用该性能优化。

返回

Map: this

<span style="color:#1f3349"><span style="color:#273d56"><code class="language-javascript">map<span style="color:#273d56">.</span><span style="color:#4264fb">setLayoutProperty</span><span style="color:#273d56">(</span><span style="color:#ce2c69">'my-layer'</span><span style="color:#273d56">,</span> <span style="color:#ce2c69">'visibility'</span><span style="color:#273d56">,</span> <span style="color:#ce2c69">'none'</span><span style="color:#273d56">)</span><span style="color:#273d56">;</span></code></span></span>
<template>
  <div class="hello" style="height:100%;width:100%;position:relative;">
    <div id="map" style="height:100%;width:100%">
      <el-radio-group v-model="changeaaa" @change="changemap(changeaaa)">
        <el-radio label="contours">contours</el-radio>
        <el-radio label="museums">museums</el-radio>
      </el-radio-group>
    </div>
  </div>
</template>

<script>
export default {
  name: "Map",
  data() {
    return {
      maps: null,
      changeaaa: "",
    };
  },
  methods: {
    changemap(toggleableLayerIds) {
      if (toggleableLayerIds == "contours") {
        map.setLayoutProperty("contours", "visibility", "visible");
        map.setLayoutProperty("museums", "visibility", "none");
      } else if (toggleableLayerIds == "museums") {
        map.setLayoutProperty("contours", "visibility", "none");
        map.setLayoutProperty("museums", "visibility", "visible");
      }
    }
  },
  mounted() {
    mapboxgl.accessToken =
      "pk.eyJ1IjoiMTU5MzU3MyIsImEiOiJjamw3bW85dHkwbXlvM3ZzMm5iZnZ6bWJpIn0.W6_MGVjNaImIybFdMJBMpg";
    window.map = new mapboxgl.Map({
      container: "map",
      style: "mapbox://styles/mapbox/streets-v11",
      zoom: 15,
      center: [-71.97722138410576, -13.517379300798098]
    });

    map.on("load", function() {
      map.addSource("museums", {
        type: "vector",
        url: "mapbox://mapbox.2opop9hr"
      });
      map.addLayer({
        id: "museums",
        type: "circle",
        source: "museums",
        layout: {
          visibility: "none"
        },
        paint: {
          "circle-radius": 8,
          "circle-color": "rgba(55,148,179,1)"
        },
        "source-layer": "museum-cusco"
      });

      map.addSource("contours", {
        type: "vector",
        url: "mapbox://mapbox.mapbox-terrain-v2"
      });
      map.addLayer({
        id: "contours",
        type: "line",
        source: "contours",
        "source-layer": "contour",
        layout: {
          visibility: "none",
          "line-join": "round",
          "line-cap": "round"
        },
        paint: {
          "line-color": "#877b59",
          "line-width": 1
        }
      });
    });
  }
};
</script>

要在 Mapbox实现地址搜索功能,可以使用 Mapbox Geocoding API。以下是一些基本步骤: 1. 注册 Mapbox 账户并创建一个 Mapbox access token。可以在 Mapbox 网站上创建账户并生成 access token。 2. 在前端代码中添加 Mapbox GL JS 库。可以通过以下方式添加: ```html <head> <script src="https://api.mapbox.com/mapbox-gl-js/v2.3.0/mapbox-gl.js"></script> <link href="https://api.mapbox.com/mapbox-gl-js/v2.3.0/mapbox-gl.css" rel="stylesheet" /> </head> ``` 3. 添加一个地图容器。可以使用以下代码: ```html <div id="map" style="width: 100%; height: 600px;"></div> ``` 4. 初始化 Mapbox map。可以使用以下代码: ```javascript mapboxgl.accessToken = 'YOUR_MAPBOX_ACCESS_TOKEN'; var map = new mapboxgl.Map({ container: 'map', style: 'mapbox://styles/mapbox/streets-v11', center: [-74.5, 40], zoom: 9 }); ``` 5. 添加一个搜索框。可以使用以下代码: ```html <div id="geocoder" class="geocoder"></div> ``` 6. 初始化 Mapbox Geocoding API。可以使用以下代码: ```javascript var geocoder = new MapboxGeocoder({ accessToken: mapboxgl.accessToken, mapboxgl: mapboxgl }); map.addControl(geocoder); ``` 7. 处理搜索结果。可以使用以下代码: ```javascript geocoder.on('result', function(e) { console.log(e.result); }); ``` 这样就可以在 Mapbox实现地址搜索功能了。当用户在搜索框中输入地址时,Mapbox Geocoding API 会返回一个包含地址信息的对象,可以根据需要对这个对象进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

侧耳倾听...

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

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

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

打赏作者

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

抵扣说明:

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

余额充值