欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue利用openlayers加載天地圖和高德地圖

 更新時間:2022年04月20日 14:41:46   作者:~HT貓L~  
這篇文章主要介紹了?vue利用openlayers加載天地圖和高德地圖,下文章主要由兩部分完成openlayers加載天地圖和加載高德地圖,下面來看看詳細內容吧,需要的朋友可以參考一下,希望對大家有所幫助

一、天地圖部分

1、在vue中安裝openlayers

npm i --save ol

這里說的vue是基于腳手架構建的。 新建個頁面,也就是vue文件,配置好路由。接著就是可以直接放入我的代碼運行顯示了。

vue利用openlayers加載天地圖和高德地圖
<template>
  <div class="wrapper">
    <div>天地圖</div>
    <div class="map" id="olMap"></div>
  </div>
</template>
<script>
import "ol/ol.css";
import {
  Tile as TileLayer } from "ol/layer";
import XYZ from "ol/source/XYZ";
import {
  defaults as defaultControls } from "ol/control";
import Map from "ol/Map.js";
import View from "ol/View.js";
export default {
  data() {
   return {
      map: null,
      parser: null,
    };
  },
  mounted() {
    this.initMap();
  },
  methods: {
    initMap() {
     const map = new Map({
       target: "olMap",
        view: new View({
 
          center: [0, 0], //中心點經(jīng)緯度
          zoom: 4, //圖層縮放大小
          projection: "EPSG:4326",
        }),
        controls: defaultControls({
          zoom: true,
          attribution: false,
          rotate: false,
        }),
      });
      this.map = map;
      // 添加地圖
      let url = "http://t{0-7}.tianditu.com/DataServer?x={x}&y={y}&l={z}";
      url = `${
   url}&T=vec_c&tk=替代你的key`;
      const source = new XYZ({
     url: url,
        projection: "EPSG:4326",
      });
      const tdtLayer = new TileLayer({
        source: source,
      });
      this.map.addLayer(tdtLayer);
      // 添加注記
      url = "http://t{0-7}.tianditu.com/DataServer?x={x}&y={y}&l={z}";
      url = `${
   url}&T=cva_c&tk=替代你的key`;
      const sourceCVA = new XYZ({
        url: url,
        projection: "EPSG:4326",
      });
      const tdtcvaLayer = new TileLayer({
        source: sourceCVA,
      });
      this.map.addLayer(tdtcvaLayer);
    },
  },
};
</script>
<style scoped>
.map {
  width: 100%;
  height: 100vh;
}
</style>

天地圖就可以顯示出來了。

效果圖:

二、高德地圖部分

相對于天地圖,高德地圖就容易多了,直接上代碼

<template>
  <div class="wrapper">
    <div>高德地圖</div>
    <div id="map"></div>
  </div>
</template>
<script>
import {
 Map,View,Feature} from 'ol'

import * as olProj from 'ol/proj'
import {
 Point} from 'ol/geom'
import {
  Style, Fill, Stroke, Circle as sCircle } from "ol/style";
// 添加圖層
import Tilelayer from 'ol/layer/Tile'
import {
 Vector as VectorLayer} from 'ol/layer'
import {
 XYZ,Vector as VectorSource} from 'ol/source'
//引入樣式文件
import "ol/ol.css"
export default {
  data() {
  return {
    map:null
    }
  },
  mounted() {
  this.init();
   this.setMarker();
  },
  methods: {
    init(){
       this.map=new Map({
         target:'map',
         layers:[new Tilelayer({
           source: new XYZ({
               url:'https://wprd0{1-4}.is.autonavi.com/appmaptile?lang=zh_cn&size=1&style=7&x={x}&y={y}&z={z}',
           })
         })
         ],
        view:new View({

            // 將西安作為地圖中心 
            // olProj.fromLonLat方法將經(jīng)緯度轉換成對應的坐標
          center:olProj.fromLonLat([108.945951, 34.465262]),
          zoom:2
        }),
       })
    },
    setMarker(){
        let _style = new Style({
            image:new sCircle({
                radius:10,
                stroke:new Stroke({
                    color:"#fff",
                }),
                fill: new Fill({
                    color:'#3399CC',
                }),
            }),
        });
        let _feature = new Feature({
 
            geometry:new Point(olProj.fromLonLat([108.945951, 34.465262])),
        });
        _feature.setStyle(_style);
        let _marker = new VectorLayer({

            source: new VectorSource({
               feature:[_feature],
            }),
        });
        this.map.addLayer(_marker);
    },
  },
}
</script>
<style scoped>
  #map{
      /* 屏幕寬高 */
    width: 100vw;
    height: 100vh;
  }
</style>

到此這篇關于 vue利用openlayers加載天地圖和高德地圖的文章就介紹到這了,更多相關openlayers加載天地圖和高德地圖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解vuex持久化插件解決瀏覽器刷新數(shù)據(jù)消失問題

    詳解vuex持久化插件解決瀏覽器刷新數(shù)據(jù)消失問題

    這篇文章主要介紹了詳解vuex持久化插件解決瀏覽器刷新數(shù)據(jù)消失問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • ant design Vue 純前端實現(xiàn)分頁問題

    ant design Vue 純前端實現(xiàn)分頁問題

    這篇文章主要介紹了ant design Vue 純前端實現(xiàn)分頁問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue實現(xiàn)將一個數(shù)組內的相同數(shù)據(jù)進行合并

    vue實現(xiàn)將一個數(shù)組內的相同數(shù)據(jù)進行合并

    今天小編就為大家分享一篇vue實現(xiàn)將一個數(shù)組內的相同數(shù)據(jù)進行合并,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue寫h5頁面的方法總結

    vue寫h5頁面的方法總結

    在本篇內容里小編給大家整理了關于vue寫h5頁面的方法以及注意點分析,有需要的朋友們跟著學習下吧。
    2019-02-02
  • 基于iview的router常用控制方式

    基于iview的router常用控制方式

    這篇文章主要介紹了基于iview的router常用控制方式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 關于Element-UI中slot的用法及說明

    關于Element-UI中slot的用法及說明

    這篇文章主要介紹了關于Element-UI中slot的用法及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue實現(xiàn)防抖的實例代碼

    vue實現(xiàn)防抖的實例代碼

    這篇文章主要給大家介紹了關于vue實現(xiàn)防抖的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Vue實現(xiàn)調用PC端攝像頭實時拍照

    Vue實現(xiàn)調用PC端攝像頭實時拍照

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)調用PC端攝像頭實時拍照,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • VUE JS 使用組件實現(xiàn)雙向綁定的示例代碼

    VUE JS 使用組件實現(xiàn)雙向綁定的示例代碼

    本篇文章主要介紹了VUE JS 使用組件實現(xiàn)雙向綁定,詳細的介紹了vue的雙向數(shù)據(jù)綁定原理以及核心代碼模塊,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • Vue關于訪問外鏈失敗的問題

    Vue關于訪問外鏈失敗的問題

    這篇文章主要介紹了Vue關于訪問外鏈失敗的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論