vue中,应用mapbox地图(二)03-mapbox-gl 地图实例——标准步骤之3D立体效果-init方法

130 篇文章 78 订阅

vue中,应用mapbox地图(二)03-mapbox-gl 地图实例——标准步骤之3D立体效果-init方法

一、获取token

mapbox官网注册账号
个人中心account页面,获取accessToken

二、安装并引入使用
npm install --save mapbox-gl

main.js页面 引入mapboxgl

import mapBoxGl from 'mapbox-gl'
Vue.prototype.mbgl = mapBoxGl

页面

<!-- 组件页面 -->
<template>
    <div id="map"></div>
</template>
//组件页面
<script>
  export default {
    name: "mapbox_test",
    mounted(){
      this.init()
    },
    methods: {
      init(){
       // this.mbgl.accessToken = 'your token';
       this.mbgl.accessToken = 'pk.eyJ1IjoiZmFuZ2xhbmsiLCJhIjoiY2lpcjc1YzQxMDA5NHZra3NpaDAyODB4eSJ9.z6uZHccXvtyVqA5zmalfGg';   
        let map = new this.mbgl.Map({
          container: 'map',
          style: 'mapbox://styles/mapbox/streets-v9',
          center: [-87.61694, 41.86625],
          zoom: 15.99,
          pitch: 40,
          bearing: 1
        })
        map.on('load', function() {
          map.addLayer({
            'id': 'room-extrusion',
            'type': 'fill-extrusion',
            'source': {
              'type': 'geojson',
              'data': 'https://docs.mapbox.com/mapbox-gl-js/assets/indoor-3d-map.geojson'
            },
            'paint': {
              'fill-extrusion-color': ['get', 'color'],
              'fill-extrusion-height': ['get', 'height'],
              'fill-extrusion-base': ['get', 'base_height'],
              'fill-extrusion-opacity': 0.6
            }
          })
        })
      }
    }
  }
</script>
/*样式*/
body {
  height: 100%;
  margin: 0;
  padding: 0;
  width: 100%;
}
#map {
  position: absolute;
  left: 0;
  top: 0;
  text-align: left;
  width: 100%;
  height: 100%;
}

注释:
init方法中的map案例相关数据信息来自官网example

效果-3D立体

在这里插入图片描述

官网html版——https://docs.mapbox.com/mapbox-gl-js/example/3d-extrusion-floorplan/

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>Extrude polygons for 3D indoor mapping</title>
    <meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no">
    <link href="https://api.mapbox.com/mapbox-gl-js/v2.7.0/mapbox-gl.css" rel="stylesheet">
    <script src="https://api.mapbox.com/mapbox-gl-js/v2.7.0/mapbox-gl.js"></script>
    <style>
        body {
            margin: 0;
            padding: 0;
        }

        #map {
            position: absolute;
            top: 0;
            bottom: 0;
            width: 100%;
        }
    </style>
</head>

<body>
    <div id="map"></div>
    <script>
        // TO MAKE THE MAP APPEAR YOU MUST
        // ADD YOUR ACCESS TOKEN FROM
        // https://account.mapbox.com
        // mapboxgl.accessToken = 'YOUR_MAPBOX_ACCESS_TOKEN';
        mapboxgl.accessToken = 'pk.eyJ1IjoiZmFuZ2xhbmsiLCJhIjoiY2lpcjc1YzQxMDA5NHZra3NpaDAyODB4eSJ9.z6uZHccXvtyVqA5zmalfGg';
        const map = new mapboxgl.Map({
            container: 'map',
            style: 'mapbox://styles/mapbox/streets-v11',
            center: [-87.61694, 41.86625],
            zoom: 15.99,
            pitch: 40,
            bearing: 20,
            antialias: true
        });

        map.on('load', () => {
            map.addSource('floorplan', {
                'type': 'geojson',
                /*
                * Each feature in this GeoJSON file contains values for
                * `properties.height`, `properties.base_height`,
                * and `properties.color`.
                * In `addLayer` you will use expressions to set the new
                * layer's paint properties based on these values.
                */
                'data': 'https://docs.mapbox.com/mapbox-gl-js/assets/indoor-3d-map.geojson'
            });
            map.addLayer({
                'id': 'room-extrusion',
                'type': 'fill-extrusion',
                'source': 'floorplan',
                'paint': {
                    // Get the `fill-extrusion-color` from the source `color` property.
                    'fill-extrusion-color': ['get', 'color'],

                    // Get `fill-extrusion-height` from the source `height` property.
                    'fill-extrusion-height': ['get', 'height'],

                    // Get `fill-extrusion-base` from the source `base_height` property.
                    'fill-extrusion-base': ['get', 'base_height'],

                    // Make extrusions slightly opaque to see through indoor walls.
                    'fill-extrusion-opacity': 0.5
                }
            });
        });
    </script>

</body>

</html>

效果同上

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用 Vite + Vue 3 的示例代码,演示了如何在项目使用 Vue-iClient-MapboxGL 的 sm-time-line 组件: 首先,确保已经安装了相关依赖包。在项目根目录下执行以下命令: ```bash npm install @supermap/vue-iclient-mapboxgl ``` 然后,可以按照下面的示例代码来编写你的 `main.js` 文件和组件文件。 main.js: ```javascript import { createApp } from 'vue'; import App from './App.vue'; import iClientMapboxgl from '@supermap/vue-iclient-mapboxgl'; const app = createApp(App); // 注册Vue-iClient-MapboxGL组件 app.use(iClientMapboxgl); app.mount('#app'); ``` App.vue: ```vue <template> <div> <i-client-mapboxgl ref="map" :accessToken="accessToken" :styleUrl="styleUrl" :center="center" :zoom="zoom"> <sm-time-line :data="timelineData" @change="changeTime"></sm-time-line> </i-client-mapboxgl> </div> </template> <script> export default { name: 'App', data() { return { accessToken: 'your_access_token', styleUrl: 'http://localhost:8080/styles/basic.json', center: [0, 0], zoom: 2, timelineData: [ { time: 0, data: 'data1' }, { time: 25, data: 'data2' }, { time: 50, data: 'data3' }, { time: 75, data: 'data4' }, { time: 100, data: 'data5' }, ], }; }, methods: { changeTime(time) { // 根据时间点执行相应操作 console.log('Selected time:', time); // 示例代码:根据选定的时间加载数据图层或更新图层的显示内容 // ... }, }, }; </script> <style> #map { width: 100%; height: 400px; } </style> ``` 在上述代码,我们首先在 `main.js` 文件注册了 `Vue-iClient-MapboxGL` 组件,然后在 `App.vue` 组件使用了 `i-client-mapboxgl` 组件作为容器来展示地图,并在其嵌套了 `sm-time-line` 组件作为时间轴。 在 `App.vue` 的 `data` ,我们定义了一些地图相关的配置参数和时间轴的数据数组 `timelineData`。在 `changeTime` 方法,可以根据选定的时间点执行相应的操作。 请注意替换 `accessToken` 和 `styleUrl` 的值为你自己的 Access Token 和样式地址。 这是一个简单的示例,你可以根据自己的需求进行相应的调整和扩展。希望对你有所帮助!如果还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值