/** * 创建者:王成 * 操作系统:MAC * 创建日期:2022年11月14日 * 描述:工具类 */ /* 引入Cesium */ // import * as Cesium from 'Cesium'; /* 引入草图工具 */ import { SketchViewModel } from './SketchViewModel.js' /** * 测量、图形查询、根据坐标生成图形 */ class CommonTools { /** * 默认初始化 * @param {Object} viewer 三维场景 * @param {JSON} [options] 配置项 * @param {Boolean} [options.isClear] 是否清理前期已绘制内容 * @param {Boolean} [options.isDrawPoint] 是否绘制参考点 * @param {Boolean} [options.isRetainDrawPoint] 绘制完成,是否保留绘制参考点 */ constructor(viewer, options) { this._viewer = viewer; options = options || {}; /* 配置是否绘制参考点 */ if (options.isDrawPoint) { this._isDrawPoint = options.isDrawPoint; } else { this._isDrawPoint = false; } /* 配置绘制完成是否保留绘制参考点 */ if (options.isRetainDrawPoint) { this._isRetainDrawPoint = options.isRetainDrawPoint; } else { this._isRetainDrawPoint = false; } /* 是否清理前期已绘制内容 */ if (options.isClear) { this._isClear = options.isClear; } else { this._isClear = false; } this._sketchViewModel = new SketchViewModel(viewer, { iconType: SketchViewModel.SketchIconType.Blue, isDrawPoint: this._isDrawPoint, isRetainDrawPoint: this._isRetainDrawPoint, }); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } /* 初始化 */ this._init(); } /** * 初始化 * @ignore */ _init() { /* 绘制的实体名称 */ this._measureEntityName = 'MeasureEntity'; this._entities = this._viewer.entities; /* 标绘点图片 */ this._measurePointImage = ''; this._iconBlue = ''; this._iconGreen = ''; this._iconViolet = ''; /* 用于面积测量 存储临时位置 经纬度格式 */ this._measureTempPoints = []; } /** * 刷新场景 刷新一帧 * @ignore */ _updateScene() { this._viewer.scene.requestRender(); } /** * 根据Entity的名称批量删除Entity * @ignore * @param {string} entityName 实体名称 */ _removeEntityByName(entityName) { /* 获取实体集合 */ let entities = this._entities; /* 如果不存在实体集合或集合中没有数据 则返回 */ if (!entities || !entities.values) return; let delEntitys = []; /* 循环获取当前集合中的所有实体 */ for (let i = 0; i < entities.values.length; i++) { if (entities.values[i].name == entityName) { delEntitys.push(entities.values[i]); } } /* 删除符合条件的所有实体 */ for (let i = 0; i < delEntitys.length; i++) { entities.remove(delEntitys[i]); } /* 更新场景 */ this._updateScene(); } /** * 资源清理 * @ignore * @param {Boolean} isAll 是否清除已绘制内容 */ _clear(isAll) { if (isAll != undefined && isAll === true) { /* 删除所有绘制的实体 */ this._removeEntityByName(this._measureEntityName); if (this._sketchViewModel != undefined) { this._sketchViewModel.sketchClear(); } } /* 清理数组 */ this._measureTempPoints = []; /* 清理变量 */ this._altitudeDynamicLabel = undefined; /* 清理提示标签 */ this._tooltipRemove(); //app移除按钮 let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } } /** * 普通颜色值转换为Cesium颜色 * @ignore * @param {int} red 红色[0~255] * @param {int} green 绿色[0~255] * @param {int} blue 蓝色[0~255] * @param {int} alpha 透明度[0~1] * @return {Cesium.Color} Cesium格式的颜色 */ _toColor(red, green, blue, alpha) { return new Cesium.Color(red / 255.0, green / 255.0, blue / 255.0, alpha); } /** * 世界坐标系坐标转为经纬度坐标 * @ignore * @param {JSON} cartesian 世界坐标 * @param {Number} cartesian.x x坐标 * @param {Number} cartesian.y y坐标 * @param {Number} cartesian.z z坐标 * @return {JSON} 经纬度格式坐标{long:lat:hei} */ _cartesianToGeography(cartesian) { let ellipsoid = Cesium.Ellipsoid.WGS84; let cartographic = ellipsoid.cartesianToCartographic(cartesian); let latitude = Cesium.Math.toDegrees(cartographic.latitude); let longitude = Cesium.Math.toDegrees(cartographic.longitude); let altitude = cartographic.height; return { lon: longitude, lat: latitude, hei: altitude, } } /** * 绘制点 * @ignore * @param {Object} coord 坐标 * @param {Number} coord.x 空间坐标x * @param {Number} coord.y 空间坐标y * @param {Number} coord.z 空间坐标z * @param {String} label [点上面显示的文字标注] */ _createPoint(coord, label) { let _self = this; let entity = new Cesium.Entity({ name: _self._measureEntityName, position: coord, billboard: { image: _self._iconBlue, horizontalOrigin: Cesium.HorizontalOrigin.center, verticalOrigin: Cesium.VerticalOrigin.bottom, scale: 0.5, pixelOffset: new Cesium.Cartesian2(0, -11), disableDepthTestDistance: Number.POSITIVE_INFINITY, } }); if (label) { entity.label = { text: label, font: '30px SimHei', scale: 0.5, fillColor: this._toColor(255, 255, 255, 1.0), outlineColor: this._toColor(14, 30, 79, 1.0), style: Cesium.LabelStyle.FILL_AND_OUTLINE, outlineWidth: 2.0, verticalOrigin: Cesium.VerticalOrigin.BOTTOM, showBackground: true, backgroundColor: _self._toColor(0, 0, 0, 0.6), disableDepthTestDistance: Number.POSITIVE_INFINITY, pixelOffset: new Cesium.Cartesian2(0, -28), } } this._entities.add(entity); this._updateScene(); return entity; } /** * 绘制标签 * @ignore * @param {Object} coord 坐标 * @param {Number} coord.x 标签空间坐标x * @param {Number} coord.y 标签空间坐标y * @param {Number} coord.z 标签空间坐标z * @param {String} label 标签文字内容 */ _createLabel(coord, label) { let _self = this; let entity = new Cesium.Entity({ name: _self._measureEntityName, position: coord, label: { text: label, font: '30px SimHei', scale: 0.5, fillColor: this._toColor(255, 255, 255, 1.0), outlineColor: this._toColor(14, 30, 79, 1.0), style: Cesium.LabelStyle.FILL_AND_OUTLINE, outlineWidth: 2.0, verticalOrigin: Cesium.VerticalOrigin.BOTTOM, showBackground: true, backgroundColor: _self._toColor(0, 0, 0, 0.6), disableDepthTestDistance: Number.POSITIVE_INFINITY, pixelOffset: new Cesium.Cartesian2(0, -14), } }); this._entities.add(entity); this._updateScene(); } /** * 创建高度测量的动态Label * @ignore */ _createAltitudeDynamicLabel() { let _self = this; this._altitudeDynamicLabel = new Cesium.Entity({ name: _self._measureEntityName, position: new Cesium.CallbackProperty(function() { return _self._altitudeLabelPosition; }, false), label: { text: new Cesium.CallbackProperty(function() { return _self._altitudeLabelText; }, false), font: '12px sans-serif', fillColor: this._toColor(255, 255, 255, 1.0), outlineColor: this._toColor(0, 154, 94, 1.0), style: Cesium.LabelStyle.FILL_AND_OUTLINE, outlineWidth: 1.0, verticalOrigin: Cesium.VerticalOrigin.BOTTOM, pixelOffset: new Cesium.Cartesian2(0, -28), showBackground: true, backgroundColor: this._toColor(0, 0, 0, 0.6), disableDepthTestDistance: Number.POSITIVE_INFINITY, } }); this._entities.add(this._altitudeDynamicLabel); this._updateScene(); } /** * 计算距离 * @ignore * @param {Array} positions 点集合 * @return {string}:距离字符串(含单位) */ _measureDistance(positions) { let distance = 0; for (let i = 0; i < positions.length - 1; i++) { let point1cartographic = Cesium.Cartographic.fromCartesian(positions[i]); let point2cartographic = Cesium.Cartographic.fromCartesian(positions[i + 1]); /**根据经纬度计算出距**/ let geodesic = new Cesium.EllipsoidGeodesic(); geodesic.setEndPoints(point1cartographic, point2cartographic); let s = geodesic.surfaceDistance; /* 返回两点之间的距离 */ s = Math.sqrt(Math.pow(s, 2) + Math.pow(point2cartographic.height - point1cartographic.height, 2)); distance = distance + s; } if (distance < 1000) return distance.toFixed(2) + "米"; else return (distance / 1000).toFixed(2) + "公里"; } /** * 计算空间距离 * @ignore * @param {Array} positions 点集合 * @return {string}:距离字符串(含单位) */ _measureSpaceDistance(positions) { let distance = 0; for (let i = 0; i < positions.length - 1; i++) { let point1 = positions[i]; let point2 = positions[i + 1]; /* 计算分量差 */ let sx = Math.abs(point1.x - point2.x); let sy = Math.abs(point1.y - point2.y); let sz = Math.abs(point1.z - point2.z); /* 返回两点之间的空间距离 */ let s = Math.sqrt(Math.pow(sx, 2) + Math.pow(sy, 2) + Math.pow(sz, 2)); distance = distance + s; } if (distance < 1000) return distance.toFixed(2) + "米"; else return (distance / 1000).toFixed(2) + "公里"; } /** * 计算方向 * @ignore * @param {Cartesian3} from 起始 * @param {Cartesian3} to 终止 * @return {float} 方向度数 */ _measureAreaBearing(from, to) { let radiansPerDegree = Math.PI / 180.0; //角度转化为弧度(rad) let degreesPerRadian = 180.0 / Math.PI; //弧度转化为角度 let lat1 = from.lat * radiansPerDegree; let lon1 = from.lon * radiansPerDegree; let lat2 = to.lat * radiansPerDegree; let lon2 = to.lon * radiansPerDegree; let angle = -Math.atan2(Math.sin(lon1 - lon2) * Math.cos(lat2), Math.cos(lat1) * Math.sin( lat2) - Math.sin(lat1) * Math.cos(lat2) * Math.cos(lon1 - lon2)); if (angle < 0) { angle += Math.PI * 2.0; } angle = angle * degreesPerRadian; //角度 return angle; } /** * 计算角度 * @ignore * @param {Cartesian3} p1 点1 * @param {Cartesian3} p2 点2 * @param {Cartesian3} p3 点3 * @return {float} 返回角度 */ _calculateAreaAngle(p1, p2, p3) { let bearing21 = this._measureAreaBearing(p2, p1); let bearing23 = this._measureAreaBearing(p2, p3); let angle = bearing21 - bearing23; if (angle < 0) { angle += 360; } return angle; } /** * 计算两点之间的距离 * @ignore * @param {Cartesian3} point1 点1 * @param {Cartesian3} point2 点2 */ _calculateDistance(point1, point2) { let point1cartographic = Cesium.Cartographic.fromCartesian(point1); let point2cartographic = Cesium.Cartographic.fromCartesian(point2); /**根据经纬度计算出距离**/ let geodesic = new Cesium.EllipsoidGeodesic(); geodesic.setEndPoints(point1cartographic, point2cartographic); let s = geodesic.surfaceDistance; //返回两点之间的距离 s = Math.sqrt(Math.pow(s, 2) + Math.pow(point2cartographic.height - point1cartographic .height, 2)); return s; } /** * 计算面积 * @ignore * @param {Array} cartesianPoints 空间坐标系点集合 * @return {float} 返回面积 */ _measureArea(points, cartesianPoints) { let self = this; let res = 0; /* 拆分三角面 */ for (let i = 0; i < points.length - 2; i++) { let j = (i + 1) % points.length; let k = (i + 2) % points.length; let totalAngle = self._calculateAreaAngle(points[i], points[j], points[k]); let dis_temp1 = self._calculateDistance(cartesianPoints[i], cartesianPoints[j]); let dis_temp2 = self._calculateDistance(cartesianPoints[j], cartesianPoints[k]); res += dis_temp1 * dis_temp2 * Math.abs(Math.sin(totalAngle)); } return res; } /** * 计算两个点的高度 * @ignore * @param {Array} points 点集合(集合长度必须大于等于2) */ _calculatePolylineAltitudeHeight(points) { if (points === undefined || points.length < 2) return -1; let cartographic = Cesium.Cartographic.fromCartesian(points[0]); let cartographic1 = Cesium.Cartographic.fromCartesian(points[1]); let height_temp = cartographic1.height - cartographic.height; return Math.abs(height_temp).toFixed(2) + '米'; } /** * 设置鼠标为柿子样式 * @ignore */ _setMousePointerStyle() { document.querySelector('body').style.cursor = 'crosshair'; } /** * 恢复鼠标指针为默认样式 * @ignore */ _initMousePointerStyle() { document.querySelector('body').style.cursor = 'default'; } /** * 检测程序运行环境 * @return {CommonTools.RuntimeEnvironment} */ _checkAppOrWeb() { if (window.navigator.userAgent.match( /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i )) { return CommonTools.RuntimeEnvironment.App; } else { return CommonTools.RuntimeEnvironment.Web; } } /** * 是否是运行于App * @ignore */ _isRuntimeApp() { if (this._checkAppOrWeb() === CommonTools.RuntimeEnvironment.App) { return true; } return false; } /** * 是否是运行于App * @ignore */ _isRuntimeWeb() { if (this._checkAppOrWeb() === CommonTools.RuntimeEnvironment.Web) { return true; } return false; } /** * @ignore * 创建操作的主容器 */ _createOperationMainDom() { //创建画布 let buttonDiv = document.createElement('div'); buttonDiv.id = "drawButtonDiv"; buttonDiv.style.width = '80px'; buttonDiv.style.backgroundColor = 'rgba(5, 45, 155, 0.7)'; buttonDiv.style.borderRadius = '5px'; buttonDiv.style.display = 'flex'; buttonDiv.style.flexDirection = 'column'; buttonDiv.style.padding = '8px'; buttonDiv.style.justifyContent = 'center'; buttonDiv.style.position = 'absolute'; buttonDiv.style.bottom = '150px'; buttonDiv.style.right = '10px'; let btnUndo = document.createElement('button'); btnUndo.id = "btnDrawBackout"; btnUndo.style.height = '30px'; btnUndo.style.marginBottom = '8px'; btnUndo.style.backgroundColor = 'rgba(52, 137, 255, 1.0)'; btnUndo.style.color = 'rgb(255, 255, 255)'; btnUndo.style.border = '0px solid red'; btnUndo.style.borderRadius = '5px'; btnUndo.innerHTML = '回退'; btnUndo.style.fontSize = '13px'; btnUndo.style.cursor = 'pointer'; buttonDiv.appendChild(btnUndo); let btnCompletion = document.createElement('button'); btnCompletion.id = "btnDrawComplete"; btnCompletion.style.height = '30px'; btnCompletion.style.backgroundColor = 'rgba(88, 185, 45, 1.0)'; btnCompletion.style.color = 'rgb(255, 255, 255)'; btnCompletion.style.border = '0px solid red'; btnCompletion.style.borderRadius = '5px'; btnCompletion.innerHTML = '完成'; btnCompletion.style.fontSize = '13px'; btnCompletion.style.cursor = 'pointer'; buttonDiv.appendChild(btnCompletion); /* 加入到页面 */ document.body.appendChild(buttonDiv); } /** * 创建顶部弹出提示消息 1秒后自动消失 * @ignore * @param {String} message 消息内容 */ _showTooltipMessage(message) { let msgMainDom = document.getElementById('messageMainDom'); if (msgMainDom !== null && msgMainDom !== undefined) { document.body.removeChild(msgMainDom); } msgMainDom = document.createElement('div'); msgMainDom.style.width = '30%'; msgMainDom.style.backgroundColor = 'rgba(237, 248, 230, 1.0)'; msgMainDom.style.height = '45px'; msgMainDom.style.border = 'solid 2px rgb(219, 241, 208)'; msgMainDom.style.borderRadius = '8px'; msgMainDom.style.display = 'flex'; msgMainDom.style.alignItems = 'center'; msgMainDom.style.paddingLeft = '10px'; msgMainDom.style.color = 'rgb(91, 188, 48)'; msgMainDom.style.fontSize = '14px'; msgMainDom.style.fontWeight = '600'; msgMainDom.style.position = 'absolute'; msgMainDom.style.left = '35%'; msgMainDom.style.transition = 'transform 1s'; msgMainDom.style.transform = 'translateY(-90px)'; msgMainDom.style.top = '0px'; msgMainDom.style.zIndex = 1000; document.body.appendChild(msgMainDom); let strHtml = ''; strHtml += "
"; strHtml += "
" + message + "
"; msgMainDom.innerHTML = strHtml; msgMainDom.addEventListener('transitionend', function() { setTimeout(function() { document.body.removeChild(msgMainDom); }, 1000); }, false); setTimeout(function() { msgMainDom.style.transform = 'translateY(50px)'; }, 100) } } /** * 鼠标跟随标签 */ Object.assign(CommonTools.prototype, { /** * 提示标签初始化 * @ignore * @param {String} text 显示的文本内容 */ _tooltipInit: function(text) { let _self = this; this._tooltipId = 'tooltipJt'; let tooltipObj = document.getElementById(this._tooltipId); if (tooltipObj === null) { tooltipObj = document.createElement('div'); tooltipObj.id = this._tooltipId; document.body.appendChild(tooltipObj); let divStyle = ''; divStyle += "top: 30px;"; divStyle += "left: 30px;"; divStyle += "position: absolute;"; divStyle += "display: flex;"; divStyle += "align-items: center;"; divStyle += "width: 12x0px;"; divStyle += "height: auto;"; divStyle += "background-color: rgba(0, 0, 0, 0.65);"; divStyle += "border-radius: 5px;"; divStyle += "color: rgb(255, 255, 255);"; divStyle += "font-size: 12px;"; divStyle += "font-family: 'Alimama_ShuHeiTi_Bold';"; divStyle += "padding: 8px;"; divStyle += "border:solid 1px rgb(255,0,0);"; tooltipObj.setAttribute('style', divStyle); } if (text != undefined) tooltipObj.innerHTML = text; /* 挂接鼠标移动事件 */ document.onmousemove = function(event) { tooltipObj.style.left = (event.clientX + 10) + 'px'; tooltipObj.style.top = (event.clientY - tooltipObj.offsetHeight / 2) + 'px'; } }, /** * 移除提示标签 * @ignore */ _tooltipRemove: function() { let tooltipObj = document.getElementById(this._tooltipId); if (tooltipObj != null) { document.body.removeChild(tooltipObj); } }, /** * 设置提示标签文本 * @ignore * @param {String} text 文本 */ _tooltipSetText: function(text) { let tooltipObj = document.getElementById(this._tooltipId); if (tooltipObj != null) { tooltipObj.innerHTML = text; } } }) /** * 通用对外公开函数 */ Object.assign(CommonTools.prototype, /** @lends CommonTools.prototype */ { /** * 清理资源 */ clear: function() { /* 清理资源 */ this._clear(true); /* 初始化鼠标样式 */ this._initMousePointerStyle(); } }) /** * 测量类对外公开函数 */ Object.assign(CommonTools.prototype, /** @lends CommonTools.prototype */ { /** * 测量长度 */ measureLength: function(callError) { let _self = this; /* 临时创建的实体 */ this._tempEntitys = []; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置鼠标跟随 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始测量"); } else { this._tooltipInit('点击开始测量'); } /* 调用草图开始绘制 */ if (this._isRuntimeWeb()) { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { _self._createPoint(cPoints[0], '起点'); } else { let distince = _self._measureDistance(cPoints); /* 追加中间距离 */ let tempPoints = [cPoints[cPoints.length - 2], cPoints[cPoints.length - 1]]; distince += ' +' + _self._measureDistance(tempPoints); _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince)); } }, /** * 撤销回调 * @ignore */ onUndo: function() { _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]); _self._tempEntitys.pop(); }, /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint * @param {JSON} scPoint 屏幕点 */ onMoving: function(cPoint, scPoint) { _self._tooltipSetText('右键单击回退
左键双击结束绘制'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { _self._initMousePointerStyle(); _self._tooltipRemove(); } }); } else { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { // 移除提示标签 _self._tooltipRemove(); _self._createPoint(cPoints[0], '起点'); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv == null) { //创建按钮 _self._createOperationMainDom(); //撤销 document.getElementById("btnDrawBackout").onclick = () => { if (_self._sketchViewModel._sketchTempPoints.length > 2) { /* 移除正式点最有一个元素 */ _self._sketchViewModel._sketchPoints.pop(); /* 移除临时点倒数第二个元素 */ _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1); /* 如果绘制了点 则删除最后一个 */ if (_self._sketchViewModel._isDrawPoint) { let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1]; _self._sketchViewModel._entities.remove(lastPointEntity); /* 移除点实体数据中的最后一条数据 */ _self._sketchViewModel._pointEntitys.pop(); } _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]); _self._tempEntitys.pop(); } } //完成绘制 document.getElementById("btnDrawComplete").onclick = () => { if (_self._sketchViewModel._sketchPoints.length < 2) { if (callError) callError("点数少于两个,禁止结束绘制!"); return; } /* 删除临时线 */ _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline); /* 绘制正式线 */ _self._sketchViewModel._createPolyline(); /* 删除标记点 */ if (!_self._sketchViewModel._isRetainDrawPoint) _self._sketchViewModel._removePointEntitys(); /* 干掉事件句柄 释放资源*/ _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler); _self._initMousePointerStyle(); _self._tooltipRemove(); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } } } } else { let distince = _self._measureDistance(cPoints); /* 追加中间距离 */ let tempPoints = [cPoints[cPoints.length - 2], cPoints[cPoints.length - 1]]; distince += ' +' + _self._measureDistance(tempPoints); _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince)); } }, }); } }, /** * 空间距离测量 */ measureSpatialLength: function(callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始测量"); } else { this._tooltipInit('点击开始测量'); } /* 临时创建的实体 */ this._tempEntitys = []; /* 调用草图开始绘制 */ if (this._isRuntimeWeb()) { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Spatial, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { _self._createPoint(cPoints[0], '起点'); } else { let distince = _self._measureSpaceDistance(cPoints); _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince)); } }, /** * 撤销回调 * @ignore */ onUndo: function() { _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]); _self._tempEntitys.pop(); }, /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint * @param {JSON} scPoint 屏幕点 */ onMoving: function(cPoint, scPoint) { _self._tooltipSetText('右键单击回退
左键双击结束绘制'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { _self._initMousePointerStyle(); _self._tooltipRemove(); } }); } else { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Spatial, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { // 移除提示标签 _self._tooltipRemove(); _self._createPoint(cPoints[0], '起点'); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv == null) { //创建按钮 _self._createOperationMainDom(); //撤销 document.getElementById("btnDrawBackout").onclick = () => { if (_self._sketchViewModel._sketchTempPoints.length > 2) { /* 移除正式点最有一个元素 */ _self._sketchViewModel._sketchPoints.pop(); /* 移除临时点倒数第二个元素 */ _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1); _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]); _self._tempEntitys.pop(); } } //完成绘制 document.getElementById("btnDrawComplete").onclick = () => { if (_self._sketchViewModel._sketchPoints.length < 2) { if (callError) callError("点数少于两个,禁止结束绘制!"); return; } /* 删除临时空间线 */ _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempSpatialPolyline); /* 绘制正式空间线 */ _self._sketchViewModel._createSpatialPolyline(); /* 删除标记点 */ _self._sketchViewModel._removePointEntitys(); /* 干掉事件句柄 释放资源*/ _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler); _self._initMousePointerStyle(); _self._tooltipRemove(); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } } } } else { let distince = _self._measureSpaceDistance(cPoints); _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince)); } }, }); } }, /** * 测量面积 */ measureArea: function(callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示工具 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始测量"); } else { this._tooltipInit('点击开始测量'); } var _areaLabel = ""; //面积提示 /* 调用草图开始绘制 */ if (this._isRuntimeWeb()) { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { _self._measureTempPoints.push(_self._cartesianToGeography(cPoints[cPoints.length - 1])); if (cPoints.length === 1) { _areaLabel = '起点'; var areaLabel = _self._createPoint(cPoints[0], new Cesium.CallbackProperty(function() { var lable = _areaLabel return lable; }, false)); } else if (cPoints.length >= 3) { let area = _self._measureArea(_self._measureTempPoints, cPoints); if (area > 100000) { _areaLabel = (area / 100000).toFixed(2) + "km²"; } else { _areaLabel = area.toFixed(2) + "m²"; } } }, /** * 撤销回调 * @ignore */ onUndo: function() { _self._measureTempPoints.pop(); if (_self._measureTempPoints.length === 1) _self._areaLabel = "起点"; }, /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint * @param {JSON} scPoint 屏幕点 */ onMoving: function(cPoint, scPoint) { _self._tooltipSetText('右键单击回退
左键双击结束绘制'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { _self._initMousePointerStyle(); _self._tooltipRemove(); } }); } else { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { _self._measureTempPoints.push(_self._cartesianToGeography(cPoints[cPoints.length - 1])); if (cPoints.length === 1) { // 移除提示标签 _self._tooltipRemove(); _areaLabel = '起点'; var areaLabel = _self._createPoint(cPoints[0], new Cesium.CallbackProperty(function() { var lable = _areaLabel return lable; }, false)); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv == null) { //创建按钮 _self._createOperationMainDom(); //撤销 document.getElementById("btnDrawBackout").onclick = () => { if (_self._sketchViewModel._sketchTempPoints.length > 2) { /* 移除正式点最有一个元素 */ _self._sketchViewModel._sketchPoints.pop(); /* 移除临时点倒数第二个元素 */ _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1); /* 如果绘制了点 则删除最后一个 */ if (_self._sketchViewModel._isDrawPoint) { let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1]; _self._entities.remove(lastPointEntity); /* 移除点实体数据中的最后一条数据 */ _self._sketchViewModel._pointEntitys.pop(); } _self._measureTempPoints.pop(); if (_self._measureTempPoints.length === 1) _self._areaLabel = "起点"; } } //完成绘制 document.getElementById("btnDrawComplete").onclick = () => { if (_self._sketchViewModel._sketchPoints.length < 3) { if (callError) callError("点数少于3个,禁止结束绘制!"); return; } /* 删除临时线和面 */ _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolygon); _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline); /* 绘制正式面 */ _self._sketchViewModel._createPolygon(); /* 删除标记点 */ if (!_self._sketchViewModel._isRetainDrawPoint) _self._sketchViewModel._removePointEntitys(); /* 干掉事件句柄 释放资源*/ _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler); _self._initMousePointerStyle(); _self._tooltipRemove(); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } } } } else if (cPoints.length >= 3) { let area = _self._measureArea(_self._measureTempPoints, cPoints); if (area > 100000) { _areaLabel = (area / 100000).toFixed(2) + "km²"; } else { _areaLabel = area.toFixed(2) + "m²"; } } }, }); } }, /** * 高度测量 */ measureHeight: function(callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制线"); } else { this._tooltipInit('单击开始绘制线'); } /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Height, { /** * 添加回调 * @ignore * @param {Cesium.Cartesian3} cPoint 点 */ onAdded: function(cPoint) { if (_self._isRuntimeApp()) { _self._showTooltipMessage("再次点击结束测量"); } else { _self._tooltipSetText('再次单击结束测量'); } }, /** * 移动回调 * @ignore * @param {Array} cPoints 高度线集合 * @param {Cesium.Cartesian3} centerPoint 顶端中心点 */ onMoving: function(cPoints, centerPoint) { let height = _self._calculatePolylineAltitudeHeight(cPoints); _self._altitudeLabelPosition = centerPoint; _self._altitudeLabelText = height; if (_self._altitudeDynamicLabel === undefined) { _self._createAltitudeDynamicLabel(); } }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} Points 高度线集合 * @param {Cesium.Cartesian3} centerPoint 顶端中心点 */ onComplete: function(cPoints, centerPoint) { let height = _self._calculatePolylineAltitudeHeight(cPoints); /* 干掉临时创建的 */ _self._entities.remove(_self._altitudeDynamicLabel); /* 创建正式的 */ _self._createLabel(centerPoint, height); /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); } }); }, /** * 三角测量 */ measureTriangle: function(callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制线"); } else { this._tooltipInit('单击开始绘制线'); } /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Triangle, { /** * 添加回调 * @ignore * @param {Cesium.Cartesian3} cPoint 点 */ onAdded: function(cPoint) { if (_self._isRuntimeApp()) { _self._showTooltipMessage("再次点击结束测量"); } else { _self._tooltipSetText('再次单击结束测量'); } }, /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint 当前点 */ onMoving: function(cPoint) { _self._tooltipSetText('再次单击结束测量'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * @ignore * @param {Cesium.Cartesian3} positions 高度顶端中心点坐标 */ onComplete: function(positions) { /* 恢复鼠标初始样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 倾斜距离点集合 */ let sPoints = [positions[0], positions[1]]; let sDistince = _self._measureSpaceDistance(sPoints); /* 平面距离点集合 */ let hPoints = [positions[1], positions[2]]; let hDistince = _self._measureSpaceDistance(hPoints); /* 高度点*/ let hePoints = [positions[2], positions[0]]; let height = _self._calculatePolylineAltitudeHeight(hePoints); /* 创建正式的 */ _self._createLabel(positions[0], '斜距:' + sDistince); _self._createLabel(positions[1], '平距:' + hDistince); _self._createLabel(positions[2], '高度:' + height); } }); } }) /** * 查询工具类对外公开函数 */ Object.assign(CommonTools.prototype, /** @lends CommonTools.prototype */ { /** * 点查询 * @param {String} callComplete 成功回调callComplete(coordinates) */ queryByPoint: function(callComplete) { let _self = this; /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标跟随 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击位置进行查询"); } else { this._tooltipInit('单击位置进行查询'); } /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Point, { /** * 完成回调 * @ignore * @param {Cesium.Cartesian3} cPoint 世界坐标系点 * @param {JSON} gPoint 经纬度坐标系点 */ onComplete: function(cPoint, gPoint) { /* 重置鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); _self._createPoint(cPoint); let coordinates = gPoint.lng + ',' + gPoint.lat; if (callComplete) callComplete(coordinates); }, }); }, /** * 多点查询 * @param {String} callComplete 成功回调callComplete(Array) */ queryByMultiplePoint: function(callComplete) { let _self = this; /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标跟随 */ this._tooltipInit("点击位置绘制
左键双击结束绘制"); /* 临时创建的实体 */ this._tempEntitys = []; /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.MultiplePoint, { /** * 添加回调 * @ignore * @param {Cesium.Cartesian3} cPoint 世界坐标系点 * @param {JSON} gPoint 经纬度坐标系点 */ onAdded: function(cPoint, gPoint) { let res = gPoint.lng.toFixed(6) + "," + gPoint.lat.toFixed(6); _self._tempEntitys.push(_self._createPoint(cPoint, res)); }, /** * 撤销回调 * @ignore */ onUndo: function() { _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]); _self._tempEntitys.pop(); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { /* 重置鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回字符串数组 */ let res = []; for (let i = 0; i < gPoints.length; i++) { res.push(gPoints[i].lng); res.push(gPoints[i].lat); } if (callComplete) callComplete(res); }, }); }, /** * 线查询 * @param {String} callComplete 成功回调callComplete(coordinates) * @param {String} callError 失败回调callError(error) */ queryByLine: function(callComplete, callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制线"); } else { this._tooltipInit('单击开始绘制线'); } /* 调用草图开始绘制 */ if (this._isRuntimeWeb()) { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { }, /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint * @param {JSON} scPoint 屏幕点 */ onMoving: function(cPoint, scPoint) { _self._tooltipSetText('右键单击回退
左键双击结束绘制开始查询'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回坐标串 */ let coordinates = undefined; for (let i = 0; i < gPoints.length; i++) { let point = gPoints[i]; if (coordinates === undefined) coordinates = point.lng + ',' + point.lat; else coordinates += ',' + point.lng + ',' + point.lat; } if (callComplete) callComplete(coordinates); }, }); } else { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { /* 移除提示标签 */ _self._tooltipRemove(); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv == null) { //创建按钮 _self._createOperationMainDom(); //撤销 document.getElementById("btnDrawBackout").onclick = () => { if (_self._sketchViewModel._sketchTempPoints.length > 2) { /* 移除正式点最有一个元素 */ _self._sketchViewModel._sketchPoints.pop(); /* 移除临时点倒数第二个元素 */ _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1); /* 如果绘制了点 则删除最后一个 */ if (_self._sketchViewModel._isDrawPoint) { let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1]; _self._sketchViewModel._entities.remove(lastPointEntity); /* 移除点实体数据中的最后一条数据 */ _self._sketchViewModel._pointEntitys.pop(); } } } //完成绘制 document.getElementById("btnDrawComplete").onclick = () => { if (_self._sketchViewModel._sketchPoints.length < 2) { if (callError) callError("点数少于两个,禁止结束绘制!"); return; } /* 删除临时线 */ _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline); /* 绘制正式线 */ _self._sketchViewModel._createPolyline(); /* 删除标记点 */ if (!_self._sketchViewModel._isRetainDrawPoint) _self._sketchViewModel._removePointEntitys(); /* 干掉事件句柄 释放资源*/ _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler); /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回坐标串 */ let coordinates = undefined; for (let i = 0; i < gPoints.length; i++) { let point = gPoints[i]; if (coordinates === undefined) coordinates = point.lng + ',' + point.lat; else coordinates += ',' + point.lng + ',' + point.lat; } let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } if (callComplete) callComplete(coordinates); } } } }, }); } }, /** * 区域查询 * @param {String} callComplete 成功回调callComplete(coordinates) * @param {String} callError 失败回调callError(error) */ queryByPolygon: function(callComplete, callError) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制区域"); } else { this._tooltipInit('单击开始绘制区域'); } /* 调用草图开始绘制 */ if (this._isRuntimeWeb()) { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, { /** * 移动回调 * @ignore * @param {Cesium.Cartesian3} cPoint * @param {JSON} scPoint 屏幕点 */ onMoving: function(cPoint, scPoint) { _self._tooltipSetText('右键单击回退
左键双击结束绘制开始查询'); }, /** * 错误回调 * @ignore * @param {String} error 错误信息 */ onError: function(error) { if (callError) callError(error); }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { /* 重置鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回坐标串 */ let coordinates = undefined; for (let i = 0; i < gPoints.length; i++) { let point = gPoints[i]; if (coordinates === undefined) coordinates = point.lng + ',' + point.lat; else coordinates += ',' + point.lng + ',' + point.lat; } coordinates += ',' + gPoints[0].lng + ',' + gPoints[0].lat; if (callComplete) callComplete(coordinates); }, }); } else { this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 1) { // 移除提示标签 _self._tooltipRemove(); let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv == null) { //创建按钮 _self._createOperationMainDom(); //撤销 document.getElementById("btnDrawBackout").onclick = () => { if (_self._sketchViewModel._sketchTempPoints.length > 2) { /* 移除正式点最有一个元素 */ _self._sketchViewModel._sketchPoints.pop(); /* 移除临时点倒数第二个元素 */ _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1); /* 如果绘制了点 则删除最后一个 */ if (_self._sketchViewModel._isDrawPoint) { let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1]; _self._entities.remove(lastPointEntity); /* 移除点实体数据中的最后一条数据 */ _self._sketchViewModel._pointEntitys.pop(); } } } //完成绘制 document.getElementById("btnDrawComplete").onclick = () => { if (_self._sketchViewModel._sketchPoints.length < 3) { if (callError) callError("点数少于3个,禁止结束绘制!"); return; } /* 删除临时线和面 */ _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolygon); _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline); /* 绘制正式面 */ _self._sketchViewModel._createPolygon(); /* 删除标记点 */ if (!_self._sketchViewModel._isRetainDrawPoint) _self._sketchViewModel._removePointEntitys(); /* 干掉事件句柄 释放资源*/ _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler); /* 重置鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回坐标串 */ let coordinates = undefined; for (let i = 0; i < gPoints.length; i++) { let point = gPoints[i]; if (coordinates === undefined) coordinates = point.lng + ',' + point.lat; else coordinates += ',' + point.lng + ',' + point.lat; } coordinates += ',' + gPoints[0].lng + ',' + gPoints[0].lat; let buttonDiv = document.getElementById("drawButtonDiv"); if (buttonDiv) { //从页面移除 document.body.removeChild(buttonDiv); } if (callComplete) callComplete(coordinates); } } } }, }); } }, /** * 圆查询 * @param {String} callComplete 成功回调callComplete(center,radius) */ queryByCircle: function(callComplete) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制圆"); } else { this._tooltipInit('单击开始绘制圆'); } /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Circle, { /** * 添加回调 * @ignore * @param {JSON} center 中心点 */ onAdded: function(center) { if (_self._isRuntimeApp()) { _self._showTooltipMessage("再次点击结束绘制"); } else { _self._tooltipInit('再次单击结束绘制'); } }, /** * 完成回调 * @ignore * @param {JSON} center 中心点 * @param {Number} radius 半径 */ onComplete: function(center, radius) { /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回圆心坐标及半径 */ if (callComplete) callComplete(center.lng + "," + center.lat, radius); }, }); }, /** * 矩形查询 * @param {String} callComplete 成功回调callComplete(coordinates) */ queryByRectangle: function(callComplete) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ if (this._isRuntimeApp()) { this._showTooltipMessage("点击开始绘制矩形"); } else { this._tooltipInit('单击开始绘制矩形'); } /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Rectangle, { /** * 添加回调 * @ignore * @param {JSON} center 中心点 */ onAdded: function(center) { if (_self._isRuntimeApp()) { _self._showTooltipMessage("再次点击结束绘制"); } else { _self._tooltipInit('再次单击结束绘制'); } }, /** * 完成回调 * @ignore * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(gPoints) { /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 返回坐标串 */ let coordinates = undefined; for (let i = 0; i < gPoints.length; i++) { let point = gPoints[i]; if (coordinates === undefined) coordinates = point.lng + ',' + point.lat; else coordinates += ',' + point.lng + ',' + point.lat; } if (callComplete) callComplete(coordinates); }, }); }, }) /** * 根据坐标绘制相关图形对外公开函数 */ Object.assign(CommonTools.prototype, /** @lends CommonTools.prototype */ { /** * 绘制面拉伸体 * @param {String} callComplete 成功回调callComplete() */ drawPolygonBody: function(callComplete) { let _self = this; /* 清理资源 */ this._clear(this._isClear); /* 设置鼠标样式 */ this._setMousePointerStyle(); /* 设置提示标签 */ this._tooltipInit('点击开始绘制'); /* 调用草图开始绘制 */ this._sketchViewModel.sketchTools(SketchViewModel.SketchType.PolygonBody, { /** * 添加点回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onAdded: function(cPoints, gPoints) { if (cPoints.length === 0) { _self._tooltipInit('点击开始绘制'); } else if (cPoints.length < 3) { _self._tooltipInit('右键单击回退'); } else { _self._tooltipInit('右键单击回退
左键双击结束绘制'); } }, /** * 撤销回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 */ onUndo: function(cPoints) { if (cPoints.length === 0) { _self._tooltipInit('点击开始绘制'); } else if (cPoints.length < 3) { _self._tooltipInit('右键单击回退'); } else { _self._tooltipInit('右键单击回退
左键双击结束绘制'); } }, /** * 完成回调 * @ignore * @param {Array} cPoints 世界坐标系点集合 * @param {Array} gPoints 球面坐标系点集合 */ onComplete: function(cPoints, gPoints) { /* 恢复鼠标样式 */ _self._initMousePointerStyle(); /* 移除提示标签 */ _self._tooltipRemove(); /* 回调 */ if (callComplete) callComplete(); }, }); }, /** * @param {Array} points 经纬度点集合 * @param {JSON} options 回调配置 * @param {Function} options.onComplete() 完成回调,可选 * @param {Function} options.onError(message) 错误回调 */ drawPointFeacture: function(points, options) { this._sketchViewModel.sketchDrawFeacture(points, SketchViewModel.SketchType.DrawPoint, options); }, /** * @param {Array} points 经纬度点集合 * @param {JSON} options 回调配置 * @param {Function} options.onComplete() 完成回调,可选 * @param {Function} options.onError(message) 错误回调 */ drawMultiplePointFeacture: function(points, options) { this._sketchViewModel.sketchDrawFeacture(points, SketchViewModel.SketchType.DrawMultiplePoint, options); }, /** * @param {Array} points 经纬度点集合 * @param {JSON} options 回调配置 * @param {Function} options.onComplete() 完成回调,可选 * @param {Function} options.onError(message) 错误回调 */ drawPolylineFeacture: function(points, options) { this._sketchViewModel.sketchDrawFeacture(points, SketchViewModel.SketchType.DrawPolyline, options); }, /** * @param {Array} points 经纬度点集合 * @param {JSON} options 回调配置 * @param {Function} options.onComplete() 完成回调,可选 * @param {Function} options.onError(message) 错误回调 */ drawPolygonFeacture: function(points, options) { this._sketchViewModel.sketchDrawFeacture(points, SketchViewModel.SketchType.DrawPolygon, options); } }) /* 鼠标移动标签工具 */ Object.assign(CommonTools.prototype, { /** * 提示标签初始化 * @ignore * @param {String} text 显示的文本内容 */ tooltipInit: function(text) { this._tooltipInit(text); }, /** * 移除提示标签 * @ignore */ tooltipRemove: function() { this._tooltipRemove(); }, /** * 设置提示标签文本 * @ignore * @param {String} text 文本 */ tooltipSetText: function(text) { this._tooltipSetText(text); } }); /* 其他工具 */ Object.assign(CommonTools.prototype, { /** * 拾取通过面对象拉伸绘制的体 * @ignore * @param {Function} callComplete 完成回调callComplete({color:height})拾取失败或者未拾取则返回undefined */ pickPolygonBody: function(callComplete) { let _self = this; this._sketchViewModel.sketchPick(function(options) { if (options === undefined) { if (callComplete) callComplete(undefined); } else { if (callComplete) callComplete({ color: options.color, height: options.height, }); } }) }, /** * 设置拾取的体对象样式及高度 * @ignore * @param {JSON} options 配置项 * @param {Array} options.color 颜色[0~~255,0~255,0~255,0~1] * @param {Number} options.height 高度 * @param {Function} options.onComplete(message) 完成回调,如果message为undefined则代表成功,否则为失败消息 */ setPolygonBody: function(options) { this._sketchViewModel.sketchEditPickPolygonBody({ color: options.color, height: options.height, onComplete: options.onComplete }) }, /** * 移除拾取的体对象 * @ignore * @param {Function} onComplete(message) 完成回调,message为undifined为成功,否则为失败消息 */ removePolygonBody: function(onComplete) { this._sketchViewModel.sketchRemovePickPolygonBody(onComplete); } }) /** * 运行环境类型 */ CommonTools.RuntimeEnvironment = Object.freeze(({ App: 'app', Web: 'web' })) /* 输出 */ export default CommonTools