|  |  |  | 
|---|
|  |  |  | (function () { | 
|---|
|  |  |  | // 图片路径 | 
|---|
|  |  |  | const locationIMGPath = 'img/location.png'; | 
|---|
|  |  |  | const markerBalckPath = 'img/marker_black.svg'; | 
|---|
|  |  |  | const markerRedPath = 'img/marker_red.svg'; | 
|---|
|  |  |  | const markerBluePath = 'img/marker_blue.svg'; | 
|---|
|  |  |  | const centerPin = 'img/push_pin.svg'; | 
|---|
|  |  |  | // 建议将这些常量移到一个配置对象中统一管理 | 
|---|
|  |  |  | const CONFIG = { | 
|---|
|  |  |  | IMAGES: { | 
|---|
|  |  |  | LOCATION: 'img/location.png', | 
|---|
|  |  |  | MARKER_BLACK: 'img/marker_black.svg', | 
|---|
|  |  |  | MARKER_RED: 'img/marker_red.svg', | 
|---|
|  |  |  | MARKER_BLUE: 'img/marker_blue.svg', | 
|---|
|  |  |  | CENTER_PIN: 'img/push_pin.svg' | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | MAP: { | 
|---|
|  |  |  | DEFAULT_ZOOM: 12, | 
|---|
|  |  |  | TIANDITU_KEY: 'd8beed89b43160a9a185e5aff431f85d' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | let map; | 
|---|
|  |  |  | let lastMarker = null; | 
|---|
|  |  |  | let lastClickedMarker = null; | 
|---|
|  |  |  | 
|---|
|  |  |  | function locationOverLay(lng, lag) { | 
|---|
|  |  |  | console.log("function》》》》》locationOverLay"); | 
|---|
|  |  |  | map.centerAndZoom(new T.LngLat(lng, lag), map.getZoom()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let icon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: locationIMGPath, | 
|---|
|  |  |  | iconSize: new T.Point(27, 27), | 
|---|
|  |  |  | iconAnchor: new T.Point(10, 25) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | let marker = new T.Marker(new T.LngLat(lng, lag), { icon: icon }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let marker = new T.Marker( | 
|---|
|  |  |  | new T.LngLat(lng, lag), | 
|---|
|  |  |  | { icon: createIcon(CONFIG.IMAGES.LOCATION, 27) } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | map.addOverLay(marker); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | function closeWaterIntakeDetail(data) { | 
|---|
|  |  |  | if (!isShowCenterPin) { | 
|---|
|  |  |  | if (lastClickedMarker !== null) { | 
|---|
|  |  |  | // 如果有点击取水口则将取水口恢复成黑色 | 
|---|
|  |  |  | // 上次点击的标注改为黑色 | 
|---|
|  |  |  | var defaulticon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: markerBluePath, | 
|---|
|  |  |  | iconSize: new T.Point(28, 28), | 
|---|
|  |  |  | iconAnchor: new T.Point(14, 28) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | lastClickedMarker.setIcon(defaulticon); | 
|---|
|  |  |  | lastClickedMarker.setIcon(createIcon(CONFIG.IMAGES.MARKER_BLUE)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (isShowWaterIntakeDetail) { | 
|---|
|  |  |  | // 假如显示了取水口详情则隐藏取水口详情 | 
|---|
|  |  |  | 
|---|
|  |  |  | function chageMarkerIcon(data) { | 
|---|
|  |  |  | // 点击的标注改为红色 | 
|---|
|  |  |  | var currentMarker = data.target; | 
|---|
|  |  |  | // 点击后图标 | 
|---|
|  |  |  | var clickedIcon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: markerRedPath, | 
|---|
|  |  |  | iconSize: new T.Point(28, 28), | 
|---|
|  |  |  | iconAnchor: new T.Point(14, 28) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 设置当前点击的 marker 为点击后图标 | 
|---|
|  |  |  | currentMarker.setIcon(clickedIcon); | 
|---|
|  |  |  | // 判断点击的不是同一个坐标 | 
|---|
|  |  |  | currentMarker.setIcon(createIcon(CONFIG.IMAGES.MARKER_RED)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (lastClickedMarker !== null) { | 
|---|
|  |  |  | if (!isEqualsLngLat(data.target.getLngLat(), lastClickedMarker.getLngLat())) { | 
|---|
|  |  |  | var defaulticon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: markerBluePath, | 
|---|
|  |  |  | iconSize: new T.Point(28, 28), | 
|---|
|  |  |  | iconAnchor: new T.Point(14, 28) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | lastClickedMarker.setIcon(defaulticon); | 
|---|
|  |  |  | lastClickedMarker.setIcon(createIcon(CONFIG.IMAGES.MARKER_BLUE)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | lastClickedMarker = data.target; | 
|---|
|  |  |  | 
|---|
|  |  |  | function addMarker(id, lng, lat, name, isRed) { | 
|---|
|  |  |  | console.log("function》》》》》addMarker>>>id:" + id); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var iconUrl; | 
|---|
|  |  |  | if (isRed) { | 
|---|
|  |  |  | iconUrl = markerRedPath; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | iconUrl = markerBluePath; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var icon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: iconUrl, | 
|---|
|  |  |  | iconSize: new T.Point(28, 28), | 
|---|
|  |  |  | iconAnchor: new T.Point(14, 28) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | const iconUrl = isRed ? CONFIG.IMAGES.MARKER_RED : CONFIG.IMAGES.MARKER_BLUE; | 
|---|
|  |  |  | let marker = new T.Marker( | 
|---|
|  |  |  | new T.LngLat(lng, lat) // 创建标注 | 
|---|
|  |  |  | , { icon: icon }); | 
|---|
|  |  |  | new T.LngLat(lng, lat), | 
|---|
|  |  |  | { icon: createIcon(iconUrl) } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | //添加点击事件 | 
|---|
|  |  |  | marker.addEventListener("click", (data) => { | 
|---|
|  |  |  | addMarkerListener(id, data) | 
|---|
|  |  |  | 
|---|
|  |  |  | map.addOverLay(marker); // 将标注添加到地图中 | 
|---|
|  |  |  | return "addMarker加载成功 id:" + id | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //更新定位坐标 | 
|---|
|  |  |  | //更新位坐标 | 
|---|
|  |  |  | function updateLocation(log, lat) { | 
|---|
|  |  |  | let icon = new T.Icon({ | 
|---|
|  |  |  | iconUrl: locationIMGPath, | 
|---|
|  |  |  | iconSize: new T.Point(20, 20), | 
|---|
|  |  |  | iconAnchor: new T.Point(10, 10) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | if (locationMarker) { | 
|---|
|  |  |  | map.removeOverLay(locationMarker); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var newPoint = new T.LngLat(log, lat); | 
|---|
|  |  |  | locationMarker = new T.Marker(newPoint, { icon: icon }); | 
|---|
|  |  |  | locationMarker = new T.Marker( | 
|---|
|  |  |  | newPoint, | 
|---|
|  |  |  | { icon: createIcon(CONFIG.IMAGES.LOCATION, 20) } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | map.addOverLay(locationMarker); | 
|---|
|  |  |  | map.panTo(newPoint); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function mapMoveEnd(e) { | 
|---|
|  |  |  | var center = e.target.getCenter(); | 
|---|
|  |  |  | console.log("lng:" + center.getLng() + "   lat:" + center.getLat()) | 
|---|
|  |  |  | window.Android.refreshCenter(center.getLng(), center.getLat()); | 
|---|
|  |  |  | debounce(() => { | 
|---|
|  |  |  | const center = e.target.getCenter(); | 
|---|
|  |  |  | window.Android.refreshCenter(center.getLng(), center.getLat()); | 
|---|
|  |  |  | }, 300); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 添加防抖函数 | 
|---|
|  |  |  | function debounce(fn, delay) { | 
|---|
|  |  |  | let timer = null; | 
|---|
|  |  |  | return function() { | 
|---|
|  |  |  | if(timer) clearTimeout(timer); | 
|---|
|  |  |  | timer = setTimeout(() => { | 
|---|
|  |  |  | fn.apply(this, arguments); | 
|---|
|  |  |  | }, delay); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建marker图标的方法可以抽取出来复用 | 
|---|
|  |  |  | function createIcon(iconUrl, size = 28) { | 
|---|
|  |  |  | return new T.Icon({ | 
|---|
|  |  |  | iconUrl: iconUrl, | 
|---|
|  |  |  | iconSize: new T.Point(size, size), | 
|---|
|  |  |  | iconAnchor: new T.Point(size/2, size) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | })(); | 
|---|