前言

一个简单的示例,用于动态向 Openlayers 地图添加标记。

1. 动画演示

在这里插入图片描述

2. 代码

	<template>
	  <div>
	    <img src="@/assets/logo-03.png" />
	    <div id="map" class="map"></div>
	    <button @click="addRandomFeature">add</button>
	    <button @click="removeRandomFeature">remove</button>
	  </div>
	</template>
	
	<script>
	import "ol/ol.css";
	import Feature from "ol/Feature";
	import Map from "ol/Map";
	import Point from "ol/geom/Point";
	import TileJSON from "ol/source/TileJSON";
	import VectorSource from "ol/source/Vector";
	import View from "ol/View";
	import { Icon, Style } from "ol/style";
	import { Tile as TileLayer, Vector as VectorLayer } from "ol/layer";
	import { fromLonLat } from "ol/proj";
	
	var london = new Feature({
	  geometry: new Point(fromLonLat([-0.12755, 51.507222]))
	});
	
	var madrid = new Feature({
	  geometry: new Point(fromLonLat([-3.683333, 40.4]))
	});
	var paris = new Feature({
	  geometry: new Point(fromLonLat([2.353, 48.8566]))
	});
	var berlin = new Feature({
	  geometry: new Point(fromLonLat([13.3884, 52.5169]))
	});
	
	london.setStyle(
	  new Style({
	    image: new Icon({
	      color: "#4271AE",
	      crossOrigin: "anonymous",
	      src: "https://openlayers.org/en/latest/examples/data/bigdot.png",
	      scale: 0.2
	    })
	  })
	);
	
	madrid.setStyle(
	  new Style({
	    image: new Icon({
	      crossOrigin: "anonymous",
	      src: "https://openlayers.org/en/latest/examples/data/bigdot.png",
	      scale: 0.2
	    })
	  })
	);
	
	paris.setStyle(
	  new Style({
	    image: new Icon({
	      color: "#8959A8",
	      crossOrigin: "anonymous",
	      // For Internet Explorer 11
	      imgSize: [20, 20],
	      src: "https://openlayers.org/en/latest/examples/data/bigdot.png"
	    })
	  })
	);
	
	berlin.setStyle(
	  new Style({
	    image: new Icon({
	      crossOrigin: "anonymous",
	      // For Internet Explorer 11
	      imgSize: [20, 20],
	      src: "https://openlayers.org/en/latest/examples/data/bigdot.png"
	    })
	  })
	);
	var vectorSource = new VectorSource({
	  features: [london, madrid, paris, berlin]
	});
	
	var vectorLayer = new VectorLayer({
	  source: vectorSource
	});
	
	var rasterLayer = new TileLayer({
	  source: new TileJSON({
	    url: "https://a.tiles.mapbox.com/v3/aj.1x1-degrees.json?secure=1",
	    crossOrigin: ""
	  })
	});
	
	export default {
	  data() {
	    return {
	      map: {},
	      i: 0
	    };
	  },
	  mounted() {
	    this.map = new Map({
	      layers: [rasterLayer, vectorLayer],
	      target: document.getElementById("map"),
	      view: new View({
	        center: fromLonLat([2.896372, 44.6024]),
	        zoom: 0.1
	      })
	    });
	  },
	  methods: {
	    removeRandomFeature() {
	      if (this.i > 0) {
	        vectorSource.removeFeature(vectorSource.getFeatureById("a" + this.i));
	        this.i = this.i - 1;
	      }
	    },
	    addRandomFeature() {
	      vectorSource.forEachFeature(function(e) {
	        console.log(e.getId());
	      });
	
	      var x = Math.random() * 50;
	      var y = Math.random() * 50;
	      var geom = new Point(fromLonLat([x, y]));
	      var rome = new Feature(geom);
	      
	      this.i = this.i + 1;
	      rome.setId("a" + this.i);
	      
	      rome.setStyle(
	        new Style({
	          image: new Icon({
	            color: "#BADA55",
	            crossOrigin: "anonymous",
	            // For Internet Explorer 11
	            src:
	              ""
	          })
	        })
	      );
	      vectorSource.addFeature(rome);
	    }
	  }
	};
	</script>
	<style>
	.map {
	  width: 100%;
	  height: 600px;
	}
	</style>

3. OpenLayers 标签添加文字

在这里插入图片描述

      var berlin = new Feature({
        geometry: new Point([Math.random() * 1087, Math.random() * 749]),
        name: "abc"
      });

      berlin.setStyle(
        new Style({
          image: new Circle({
            radius: 5,
            fill: new Fill({
              color: "blue"
            })
          }),
          text: new Text({
            font: "15px Microsoft YaHei",
            text: "老子 No.1",
            offsetX: 0,
            offsetY: 15,
            fill: new Fill({
              color: "#ff0000"
            })
          })
        })
      );

      vectorSource.addFeature(berlin);

4. OpenLayers 动态修改样式

在这里插入图片描述

    change() {
      this.feature
        .getStyle()
        .getText()
        .setText("哈哈哈");
        
      this.feature.changed();
    }

为了是更改后的样式生效, 必须调用 this.feature.changed();

总结

  1. OpenLayers 通常使用 VectorLayer 图层来添加标签(ICON)
  2. 添加标签的方法是向 VectorLayer 的数据源 VectorSource 添加 Feature来完成。
  3. Feature 有两个重要的属性:geometry 和 style,分别用来控制图形和样式。

A vector object for geographic features with a geometry and other attribute properties, similar to the features in vector file formats like GeoJSON.
Features can be styled individually with setStyle; otherwise they use the style of their vector layer.
Note that attribute properties are set as module:ol/Object properties on the feature object, so they are observable, and have get/set accessors.

API 文档地址:https://openlayers.org/en/latest/apidoc/module-ol_Feature-Feature.html

Logo

前往低代码交流专区

更多推荐