gis-map-universal 0.2.9 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/gismap.umd.js +188 -41
  2. package/package.json +1 -1
package/gismap.umd.js CHANGED
@@ -457236,7 +457236,7 @@ var LatlonPick_component = normalizeComponent(
457236
457236
  zIndex: 1,
457237
457237
  projection: "EPSG:3857",
457238
457238
  });
457239
- // this.map.addLayer(baselayer);
457239
+ this.map.addLayer(baselayer);
457240
457240
  // 加载4市区划高亮WMS服务
457241
457241
  let wmslayer = new Tile["default"]({
457242
457242
  layerName: "wmslayer",
@@ -457249,9 +457249,9 @@ var LatlonPick_component = normalizeComponent(
457249
457249
  }),
457250
457250
  zIndex: 2,
457251
457251
  projection: "EPSG:3857",
457252
- opacity: 0.2,
457252
+ opacity: 0.7,
457253
457253
  });
457254
- // this.map.addLayer(wmslayer);
457254
+ this.map.addLayer(wmslayer);
457255
457255
  // 加载全省道路线
457256
457256
  let baseRoadlayer = new Tile["default"]({
457257
457257
  layerName: "baseRoadlayer",
@@ -457265,7 +457265,7 @@ var LatlonPick_component = normalizeComponent(
457265
457265
  zIndex: 4,
457266
457266
  projection: "EPSG:3857",
457267
457267
  });
457268
- // this.map.addLayer(baseRoadlayer);
457268
+ this.map.addLayer(baseRoadlayer);
457269
457269
  // 加载G35高亮线
457270
457270
  let G35layer = new Tile["default"]({
457271
457271
  layerName: "G35layer",
@@ -457327,20 +457327,10 @@ var LatlonPick_component = normalizeComponent(
457327
457327
  element: elPopup,
457328
457328
  positioning: "bottom-center",
457329
457329
  stopEvent: true,
457330
- autoPan: false,
457331
- // autoPanAnimation: {
457332
- // duration: 250,
457333
- // },
457330
+ autoPan: false
457334
457331
  });
457335
457332
  this.map.addOverlay(this.overlayPopup);
457336
457333
  this.map.on("click", (e) => {
457337
- e.preventDefault();
457338
- this.map.getView().animate({
457339
- center: this.mapCenter,
457340
- zoom: this.map.getView().getZoom(),
457341
- duration: 10
457342
- });
457343
- console.log('点击事件',this.map.getView().getCenter(),this.map.getView().getZoom());
457344
457334
  if (
457345
457335
  !this.map.getInteractions().getArray().includes(this.measuredraw) &&
457346
457336
  // !this.$refs.measureTool.measuredraw.getActive() &&
@@ -457375,6 +457365,7 @@ var LatlonPick_component = normalizeComponent(
457375
457365
  -this.popupWidth / 2,
457376
457366
  -this.popupHeight,
457377
457367
  ]);
457368
+ this.overlayPopup.set('popupBS','clusterList')
457378
457369
  } else {
457379
457370
  this.map.getView().animate({
457380
457371
  center: feature.getGeometry().getCoordinates(),
@@ -457503,6 +457494,25 @@ var LatlonPick_component = normalizeComponent(
457503
457494
  }
457504
457495
  }
457505
457496
  });
457497
+ this.map.getView().on('change', (event) => {
457498
+ if (this.map.getView().getZoom() < 18) {
457499
+ let popupBS = this.overlayPopup.get('popupBS')
457500
+ if (popupBS === 'clusterList') {
457501
+ this.closePopup()
457502
+ }
457503
+ this.gongganTextLayerList.forEach(e => {
457504
+ e.setVisible(false)
457505
+ });
457506
+ }else{
457507
+ if(this.gongganTextLayerShow){
457508
+ this.gongganTextLayerList.forEach(e => {
457509
+ if(e.get("isvis")){
457510
+ e.setVisible(true)
457511
+ }
457512
+ });
457513
+ }
457514
+ }
457515
+ });
457506
457516
  },
457507
457517
  initRadarLayers(url) {
457508
457518
  let radarLayer = new layer_Image["default"]({
@@ -457871,7 +457881,12 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457871
457881
 
457872
457882
  /* harmony default export */ var utills = ({
457873
457883
  data() {
457874
- return {};
457884
+ return {
457885
+ gongganTextLayerShow: false,
457886
+ gongganTextLayerList: [],
457887
+ sourceWithoutTextList: [],
457888
+ sourceWithTextList: [],
457889
+ };
457875
457890
  },
457876
457891
  methods: {
457877
457892
  openPopupByattr(LayerType, attr) {
@@ -457928,6 +457943,7 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457928
457943
  });
457929
457944
  },
457930
457945
  addPointByArr(pointsObj, id, isCluster) {
457946
+ let that = this;
457931
457947
  this.isCluster = isCluster;
457932
457948
  let arry = this.map.getLayers().getArray();
457933
457949
  let foundLayer = null;
@@ -457938,8 +457954,17 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457938
457954
  break;
457939
457955
  }
457940
457956
  }
457941
- this.sourceWithoutText = new source_Vector["default"]();
457942
- this.sourceWithText = new source_Vector["default"]();
457957
+ let sourceWithoutText = new source_Vector["default"]();
457958
+ let sourceWithText = new source_Vector["default"]();
457959
+ let gongganTextLayer = new layer_Vector["default"]({
457960
+ layerName: id + "_Text",
457961
+ zIndex: 999,
457962
+ visible: false,
457963
+ });
457964
+ gongganTextLayer.set("isvis", false)
457965
+ let gongganTextSource = new source_Vector["default"]();
457966
+ this.gongganTextLayerList.push(gongganTextLayer);
457967
+ this.map.addLayer(gongganTextLayer);
457943
457968
  pointsObj.pointList.forEach((data) => {
457944
457969
  let feature = new ol_Feature["a" /* default */]({
457945
457970
  title: "要素点",
@@ -457952,14 +457977,19 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457952
457977
  feature.set("longitude", data.longitude);
457953
457978
  feature.set("latitude", data.latitude);
457954
457979
  feature.set("isVisible", false);
457980
+ feature.set("layerId", id);
457955
457981
  let styleWithoutText = new Style["default"]({
457956
457982
  image: new Icon["default"]({
457957
457983
  src: data.iconUrl,
457958
457984
  scale: data.scale,
457985
+ offset: data.offset,
457986
+ offsetOrigin: "bottom-right",
457987
+ size: data.size,
457959
457988
  }),
457960
457989
  });
457961
457990
  feature.setStyle(styleWithoutText);
457962
- this.sourceWithoutText.addFeature(feature);
457991
+ sourceWithoutText.addFeature(feature);
457992
+ this.sourceWithoutTextList.push(sourceWithoutText);
457963
457993
  });
457964
457994
  pointsObj.pointList.forEach((data) => {
457965
457995
  let feature = new ol_Feature["a" /* default */]({
@@ -457973,10 +458003,14 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457973
458003
  feature.set("longitude", data.longitude);
457974
458004
  feature.set("latitude", data.latitude);
457975
458005
  feature.set("isVisible", false);
458006
+ feature.set("layerId", id);
457976
458007
  let styleWithText = new Style["default"]({
457977
458008
  image: new Icon["default"]({
457978
458009
  src: data.iconUrl,
457979
458010
  scale: data.scale,
458011
+ offset: data.offset,
458012
+ offsetOrigin: "bottom-right",
458013
+ size: data.size,
457980
458014
  }),
457981
458015
  text: new style_Text["default"]({
457982
458016
  text: data.otherInfo.stake,
@@ -457995,7 +458029,8 @@ var Cluster_Cluster = /** @class */ (function (_super) {
457995
458029
  }),
457996
458030
  });
457997
458031
  feature.setStyle(styleWithText);
457998
- this.sourceWithText.addFeature(feature);
458032
+ sourceWithText.addFeature(feature);
458033
+ this.sourceWithTextList.push(sourceWithText);
457999
458034
  });
458000
458035
  if (isCluster) {
458001
458036
  this.customLayer = new layer_Vector["default"]({
@@ -458005,12 +458040,15 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458005
458040
  const size = feature.get("features").length;
458006
458041
  let style;
458007
458042
  if (size > 1) {
458008
- style = new Style["default"]({
458043
+ let circleStyle = new Style["default"]({
458009
458044
  image: new style_Circle["default"]({
458010
- // 圆形
458011
- radius: 18,
458045
+ radius: 20,
458012
458046
  fill: new Fill["default"]({
458013
- color: [255, 160, 0, 0.7],
458047
+ color: [255, 255, 255, 0.4],
458048
+ }),
458049
+ stroke: new Stroke["default"]({
458050
+ color: [255, 255, 255, 0.7],
458051
+ width: 1,
458014
458052
  }),
458015
458053
  }),
458016
458054
  text: new style_Text["default"]({
@@ -458018,14 +458056,81 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458018
458056
  color: "#ffffff",
458019
458057
  }),
458020
458058
  offsetY: 2,
458021
- font: "bold 14px sans-serif",
458022
- text:
458023
- size > 1
458024
- ? size.toString()
458025
- : feature.get("features")[0].values_.name,
458059
+ font: "14px sans-serif",
458060
+ text: size.toString(),
458026
458061
  }),
458027
458062
  });
458028
- return style;
458063
+ let imageStyle1 = new Style["default"]({
458064
+ image: new Icon["default"]({
458065
+ src: "",
458066
+ }),
458067
+ text: new style_Text["default"]({
458068
+ fill: new Fill["default"]({
458069
+ color: "#ffffff",
458070
+ }),
458071
+ offsetY: -2,
458072
+ font: "14px sans-serif",
458073
+ text: size.toString(),
458074
+ }),
458075
+ });
458076
+ let imageStyle2 = new Style["default"]({
458077
+ image: new Icon["default"]({
458078
+ src: "",
458079
+ }),
458080
+ text: new style_Text["default"]({
458081
+ fill: new Fill["default"]({
458082
+ color: "#ffffff",
458083
+ }),
458084
+ offsetY: -2,
458085
+ font: "14px sans-serif",
458086
+ text: size.toString(),
458087
+ }),
458088
+ });
458089
+ if (that.map.getView().getZoom() < 18) {
458090
+ return circleStyle;
458091
+ } else {
458092
+ let point = feature.get("features")[0].getProperties();
458093
+ let stakeFeature = new ol_Feature["a" /* default */]({
458094
+ title: "共杆桩号",
458095
+ geometry: new geom_Point["default"](
458096
+ Object(ol_proj["fromLonLat"])([point.longitude, point.latitude])
458097
+ ),
458098
+ });
458099
+ let featrueWithText = new Style["default"]({
458100
+ text: new style_Text["default"]({
458101
+ text: point.otherInfo.stake,
458102
+ offsetY: 30,
458103
+ fill: new Fill["default"]({ color: "#f8f6e6" }),
458104
+ font: "13px Calibri,sans-serif",
458105
+ backgroundFill: new Fill["default"]({ color: "rgba(50, 35, 5, 0.7)" }),
458106
+ backgroundStroke: new Stroke["default"]({
458107
+ color: "#c7b838",
458108
+ width: 1,
458109
+ lineDash: [4, 4],
458110
+ }),
458111
+ textAlign: "center",
458112
+ textBaseline: "middle",
458113
+ padding: [2, 1, 1, 2],
458114
+ }),
458115
+ });
458116
+ stakeFeature.setStyle(featrueWithText);
458117
+ gongganTextSource.addFeature(stakeFeature);
458118
+ gongganTextLayer.setSource(gongganTextSource);
458119
+ let bz = 1;
458120
+ feature.get("features").forEach((e) => {
458121
+ let state = e.getProperties().otherInfo.state;
458122
+ if (state === 1) {
458123
+ bz = 1;
458124
+ } else {
458125
+ bz = 0;
458126
+ }
458127
+ });
458128
+ if (bz === 1) {
458129
+ return imageStyle1;
458130
+ } else {
458131
+ return imageStyle2;
458132
+ }
458133
+ }
458029
458134
  } else {
458030
458135
  style = feature.get("features")[0].getStyle();
458031
458136
  return style;
@@ -458035,7 +458140,7 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458035
458140
  const clusterSource = new source_Cluster({
458036
458141
  distance: 50,
458037
458142
  minDistance: 200,
458038
- source: this.sourceWithoutText,
458143
+ source: sourceWithoutText,
458039
458144
  });
458040
458145
  if (foundLayer) {
458041
458146
  foundLayer.setSource(clusterSource);
@@ -458048,9 +458153,9 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458048
458153
  zIndex: 999,
458049
458154
  });
458050
458155
  if (foundLayer) {
458051
- foundLayer.setSource(this.sourceWithoutText);
458156
+ foundLayer.setSource(sourceWithoutText);
458052
458157
  } else {
458053
- this.customLayer.setSource(this.sourceWithoutText);
458158
+ this.customLayer.setSource(sourceWithoutText);
458054
458159
  }
458055
458160
  }
458056
458161
  if (!foundLayer) {
@@ -458095,6 +458200,12 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458095
458200
  }
458096
458201
  }
458097
458202
  this.map.removeLayer(foundLayer);
458203
+ this.findLayerByName(layerName + "_Text").setVisible(false);
458204
+ this.gongganTextLayerList.forEach(e => {
458205
+ if (e.getProperties().layerName === layerName+"_Text") {
458206
+ e.set("isvis", false)
458207
+ }
458208
+ });
458098
458209
  this.closePopup();
458099
458210
  },
458100
458211
  findLayerByName(layerName) {
@@ -458109,34 +458220,70 @@ var Cluster_Cluster = /** @class */ (function (_super) {
458109
458220
  }
458110
458221
  return foundLayer;
458111
458222
  },
458223
+ isLayerInMap(layer) {
458224
+ var layersArray = this.map.getLayers().getArray();
458225
+ return layersArray.some(function (mapLayer) {
458226
+ return mapLayer === layer;
458227
+ });
458228
+ },
458112
458229
  pileIsShow(layerName, isShow) {
458113
- if(this.findLayerByName(layerName)){
458230
+ if (this.findLayerByName(layerName)) {
458231
+ let newSourceWithout = null;
458232
+ let newSourceWith = null;
458233
+ this.sourceWithoutTextList.forEach((e) => {
458234
+ let lid = e.getFeatures()[0].getProperties().layerId;
458235
+ if (lid === layerName) {
458236
+ newSourceWithout = e;
458237
+ }
458238
+ });
458239
+ this.sourceWithTextList.forEach((e) => {
458240
+ let lid = e.getFeatures()[0].getProperties().layerId;
458241
+ if (lid === layerName) {
458242
+ newSourceWith = e;
458243
+ }
458244
+ });
458114
458245
  if (this.isCluster) {
458115
458246
  if (!isShow) {
458116
458247
  const newclusterSource = new source_Cluster({
458117
458248
  distance: 50,
458118
458249
  minDistance: 200,
458119
- source: this.sourceWithoutText,
458250
+ source: newSourceWithout,
458120
458251
  });
458121
458252
  this.findLayerByName(layerName).setSource(newclusterSource);
458253
+ this.findLayerByName(layerName + "_Text").setVisible(false);
458254
+ this.gongganTextLayerList.forEach(e => {
458255
+ if (e.getProperties().layerName === layerName+"_Text") {
458256
+ e.set("isvis", false)
458257
+ }
458258
+ });
458259
+ this.gongganTextLayerShow = false;
458122
458260
  } else {
458123
458261
  const newclusterSource = new source_Cluster({
458124
458262
  distance: 50,
458125
458263
  minDistance: 200,
458126
- source: this.sourceWithText,
458264
+ source: newSourceWith,
458127
458265
  });
458128
458266
  this.findLayerByName(layerName).setSource(newclusterSource);
458267
+ if (this.map.getView().getZoom() >= 18) {
458268
+ this.findLayerByName(layerName + "_Text").setVisible(true);
458269
+ this.gongganTextLayerList.forEach(e => {
458270
+ if (e.getProperties().layerName === layerName+"_Text") {
458271
+ e.set("isvis", true)
458272
+ }
458273
+ });
458274
+ }
458275
+ this.gongganTextLayerShow = true;
458129
458276
  }
458130
458277
  } else {
458131
458278
  if (!isShow) {
458132
- this.findLayerByName(layerName).setSource(this.sourceWithoutText);
458279
+ this.findLayerByName(layerName).setSource(newSourceWithout);
458133
458280
  } else {
458134
- this.findLayerByName(layerName).setSource(this.sourceWithText);
458281
+ this.findLayerByName(layerName).setSource(newSourceWith);
458135
458282
  }
458136
458283
  }
458137
- }else{
458138
- console.log('未找到该图层');
458139
- return '未找到该图层'
458284
+ } else {
458285
+ console.log("未找到该图层");
458286
+ return "未找到该图层";
458140
458287
  }
458141
458288
  },
458142
458289
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gis-map-universal",
3
- "version": "0.2.9",
3
+ "version": "0.3.1",
4
4
  "description": "GIS通用组件",
5
5
  "main": "gismap.umd.js",
6
6
  "private": false,