123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959 |
- /**
- * 创建者:王成
- * 操作系统: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<JSON>} 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<JSON>} 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<JSON} points 经纬度格式点集合
- * @param {Array<JSON>} 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<JSON>} 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 += "<div style='"
- strHtml += "background-color: rgb(88, 185, 45);";
- strHtml += "color: rgb(255, 255, 255);";
- strHtml += "height: 24px;";
- strHtml += "width: 24px;";
- strHtml += "border-radius: 20px;";
- strHtml += "display: flex;";
- strHtml += "justify-content: center;";
- strHtml += "align-items: center;";
- strHtml += "font-size: 14px;";
- strHtml += "margin-right: 18px;";
- strHtml += "'>✓</div>";
- strHtml += "<div>" + message + "</div>";
- 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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('右键单击回退<br>左键双击结束绘制');
- },
- /**
- * 错误回调
- * @ignore
- * @param {String} error 错误信息
- */
- onError: function(error) {
- if (callError) callError(error);
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, {
- /**
- * 添加点回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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('右键单击回退<br>左键双击结束绘制');
- },
- /**
- * 错误回调
- * @ignore
- * @param {String} error 错误信息
- */
- onError: function(error) {
- if (callError) callError(error);
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Spatial, {
- /**
- * 添加点回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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('右键单击回退<br>左键双击结束绘制');
- },
- /**
- * 错误回调
- * @ignore
- * @param {String} error 错误信息
- */
- onError: function(error) {
- if (callError) callError(error);
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, {
- /**
- * 添加点回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} 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<JSON>} 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<Number>)
- */
- queryByMultiplePoint: function(callComplete) {
- let _self = this;
- /* 设置鼠标样式 */
- this._setMousePointerStyle();
- /* 清理资源 */
- this._clear(this._isClear);
- /* 设置鼠标跟随 */
- this._tooltipInit("点击位置绘制<br>左键双击结束绘制");
- /* 临时创建的实体 */
- 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onAdded: function(cPoints, gPoints) {
- },
- /**
- * 移动回调
- * @ignore
- * @param {Cesium.Cartesian3} cPoint
- * @param {JSON} scPoint 屏幕点
- */
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText('右键单击回退<br>左键双击结束绘制开始查询');
- },
- /**
- * 错误回调
- * @ignore
- * @param {String} error 错误信息
- */
- onError: function(error) {
- if (callError) callError(error);
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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('右键单击回退<br>左键双击结束绘制开始查询');
- },
- /**
- * 错误回调
- * @ignore
- * @param {String} error 错误信息
- */
- onError: function(error) {
- if (callError) callError(error);
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} 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<JSON>} 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<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 0) {
- _self._tooltipInit('点击开始绘制');
- } else if (cPoints.length < 3) {
- _self._tooltipInit('右键单击回退');
- } else {
- _self._tooltipInit('右键单击回退<br>左键双击结束绘制');
- }
- },
- /**
- * 撤销回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- */
- onUndo: function(cPoints) {
- if (cPoints.length === 0) {
- _self._tooltipInit('点击开始绘制');
- } else if (cPoints.length < 3) {
- _self._tooltipInit('右键单击回退');
- } else {
- _self._tooltipInit('右键单击回退<br>左键双击结束绘制');
- }
- },
- /**
- * 完成回调
- * @ignore
- * @param {Array<JSON>} cPoints 世界坐标系点集合
- * @param {Array<JSON>} gPoints 球面坐标系点集合
- */
- onComplete: function(cPoints, gPoints) {
- /* 恢复鼠标样式 */
- _self._initMousePointerStyle();
- /* 移除提示标签 */
- _self._tooltipRemove();
- /* 回调 */
- if (callComplete) callComplete();
- },
- });
- },
- /**
- * @param {Array<Number>} 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<Number>} 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<Number>} 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<Number>} 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<Number>} 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
|