本文基于ES6,采用React+Cesium的Webgis前端开发框架,目前threejs和cesium的结合正在研究中。此段代码采用原生javascript,可能过程中用到了es6的扁平化语法,如()=>{},list.map方法。

废话不多说了,直接上代码。

import Cesium from 'cesium/Source/Cesium';
import monitor from '../style/images/monitor.jpeg'; const ECesium = {
version: '0.1',
description: '自定义cesium组件',
copyright: '2018-enbo'
}; ECesium.Tools = function (viewer, callback) {
this.viewer = viewer;
this.init();
}; ECesium.Tools.prototype.init = function (back) {
//初始化事件
const viewer = this.viewer;
const scene = viewer.scene;
this.drawingMode = null;
this.measureMode = null;
this.geodesic = new Cesium.EllipsoidGeodesic();
this.handler = new Cesium.ScreenSpaceEventHandler(scene.canvas); this.dataSource = new Cesium.CustomDataSource('test1');
viewer.dataSources.add(this.dataSource);
console.log(viewer.dataSources.indexOf(this.dataSource));
}; ECesium.Tools.prototype.draw = function (type) {
if (!this.viewer) return console.error('this.viewer 未定义');
this.deactivate();
this.drawingMode = type;
switch (type) {
case this.DRAW_TYPE.Point:
this.DrawPoint();
break;
case this.DRAW_TYPE.PolyLine:
case this.DRAW_TYPE.Polygon:
this.DrawGraphics();
break;
default:
break;
}
}; ECesium.Tools.prototype.DrawPoint = function (callback) {
const viewer = this.viewer;
const this_ = this;
this.drawingMode = "point";
this.handler.setInputAction(function (evt) {
const ray = viewer.camera.getPickRay(evt.position);
const mapPosition = this_.getMapPoint(ray);
if (!mapPosition) return;
this_.dataSource.entities.add({
id: '云台' + Math.random(),
name: '林火监测点',
position: Cesium.Cartesian3.fromDegrees(mapPosition.x, mapPosition.y, mapPosition.z),
point: new Cesium.PointGraphics({
color: Cesium.Color.SKYBLUE,
pixelSize: 10,
outlineColor: Cesium.Color.YELLOW,
outlineWidth: 3,
heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
}),
description: `<img style="height: 200px;" src=${monitor}>`
});
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);
}; ECesium.Tools.prototype.DrawGraphics = function (callback) {
const viewer = this.viewer;
const this_ = this;
let activeShapePoints = [];
let activeShape, floatingPoint;
this.handler.setInputAction(function (event) {
if (!Cesium.Entity.supportsPolylinesOnTerrain(viewer.scene)) {
return console.log('This browser does not support polylines on terrain.');
}
const ray = viewer.camera.getPickRay(event.position);
const earthPosition = viewer.scene.globe.pick(ray, viewer.scene);
if (Cesium.defined(earthPosition)) {
if (activeShapePoints.length === 0) {
floatingPoint = this_.createPoint(earthPosition);
activeShapePoints.push(earthPosition);
const dynamicPositions = new Cesium.CallbackProperty(function () {
return activeShapePoints;
}, false);
activeShape = this_.drawShape(dynamicPositions);
} activeShapePoints.push(earthPosition);
this_.createPoint(earthPosition);
} }, Cesium.ScreenSpaceEventType.LEFT_CLICK); this.handler.setInputAction(function (event) {
if (Cesium.defined(floatingPoint)) {
const ray = viewer.camera.getPickRay(event.endPosition);
const newPosition = viewer.scene.globe.pick(ray, viewer.scene);
if (Cesium.defined(newPosition)) {
floatingPoint.position.setValue(newPosition);
activeShapePoints.pop();
activeShapePoints.push(newPosition);
}
}
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE); this.handler.setInputAction(function () {
terminateShape();
}, Cesium.ScreenSpaceEventType.RIGHT_CLICK); function terminateShape() {
activeShapePoints.pop();
this_.drawShape(activeShapePoints);
this.dataSource.entities.remove(floatingPoint);
this.dataSource.entities.remove(activeShape);
floatingPoint = undefined;
activeShape = undefined;
activeShapePoints = [];
}
}; ECesium.Tools.prototype.getMapPoint = function (ray) {
const viewer = this.viewer;
const cartesian = viewer.scene.globe.pick(ray, viewer.scene);
if (!cartesian) {
return null;
} const cartographic = Cesium.Cartographic.fromCartesian(cartesian);
const lng = Cesium.Math.toDegrees(cartographic.longitude);//经度值
const lat = Cesium.Math.toDegrees(cartographic.latitude);//纬度值
//cartographic.height的值为地形高度。
return {x: lng, y: lat, z: cartographic.height};
}; ECesium.Tools.prototype.createPoint = function (worldPosition) {
return this.dataSource.entities.add({
position: worldPosition,
point: {
color: Cesium.Color.WHITE,
pixelSize: 5,
heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
}
});
}; ECesium.Tools.prototype.drawShape = function (positionData) {
switch (this.drawingMode) {
case this.DRAW_TYPE.PolyLine:
return this.dataSource.entities.add({
polyline: {
positions: positionData,
clampToGround: true,
width: 3
}
});
case this.DRAW_TYPE.Polygon:
return this.dataSource.entities.add({
polygon: {
hierarchy: positionData,
material: new Cesium.ColorMaterialProperty(Cesium.Color.WHITE.withAlpha(0.7))
}
});
default:
return;
}
}; ECesium.Tools.prototype.measure = function (type) {
this.deactivate();
this.measureMode = type;
this.DrawMeasureGraphics();
}; ECesium.Tools.prototype.DrawMeasureGraphics = function () {
const viewer = this.viewer;
const this_ = this;
let activeShapePoints = [];
let activeShape, floatingPoint;
let measureDistance = 0, floatDistance = 0;
this.handler.setInputAction(function (event) {
if (!Cesium.Entity.supportsPolylinesOnTerrain(viewer.scene)) {
return console.log('This browser does not support polylines on terrain.');
}
const ray = viewer.camera.getPickRay(event.position);
const earthPosition = viewer.scene.globe.pick(ray, viewer.scene);
if (Cesium.defined(earthPosition)) {
if (activeShapePoints.length === 0) {
floatingPoint = this_.createMeasurePoint(earthPosition);
if (this_.measureMode === this_.MEASURE_TYPE.MEASURE_DISTANCE) {
floatingPoint.label = {
text: new Cesium.CallbackProperty(function (time) {
let distance = floatDistance = this_.getLatestLength(activeShapePoints);
return ((distance + measureDistance) / 1000).toFixed(2) + ' km';
}, false),
showBackground: true,
backgroundColor: new Cesium.Color(0, 0, 0, 0.5),
backgroundPadding: new Cesium.Cartesian2(7, 5),
font: '16px sans-serif',
}; this_.createLabel(earthPosition, '起点')
}
activeShapePoints.push(earthPosition);
const dynamicPositions = new Cesium.CallbackProperty(function () {
return activeShapePoints;
}, false);
activeShape = this_.drawMeasureShape(dynamicPositions);
} if (activeShapePoints.length > 1 && this_.measureMode === this_.MEASURE_TYPE.MEASURE_DISTANCE) {
measureDistance += floatDistance;
this_.createLabel(earthPosition, (measureDistance / 1000).toFixed(2) + ' km');
} activeShapePoints.push(earthPosition);
this_.createMeasurePoint(earthPosition);
} }, Cesium.ScreenSpaceEventType.LEFT_CLICK); this.handler.setInputAction(function (event) {
if (Cesium.defined(floatingPoint)) {
const ray = viewer.camera.getPickRay(event.endPosition);
const newPosition = viewer.scene.globe.pick(ray, viewer.scene);
if (Cesium.defined(newPosition)) {
floatingPoint.position.setValue(newPosition);
activeShapePoints.pop();
activeShapePoints.push(newPosition);
}
}
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE); this.handler.setInputAction(function () {
terminateShape();
}, Cesium.ScreenSpaceEventType.RIGHT_CLICK); function terminateShape() {
activeShapePoints.pop();
this_.drawMeasureShape(activeShapePoints);
this_.dataSource.entities.remove(floatingPoint);
this_.dataSource.entities.remove(activeShape);
floatingPoint = undefined;
activeShape = undefined;
activeShapePoints = [];
measureDistance = 0;
}
}; ECesium.Tools.prototype.drawMeasureShape = function (positionData, callback) {
console.log("draw shape");
switch (this.measureMode) {
case this.MEASURE_TYPE.MEASURE_DISTANCE:
return this.dataSource.entities.add({
polyline: {
positions: positionData,
clampToGround: true,
width: 3
}
});
case this.MEASURE_TYPE.MEASURE_AREA:
return this.dataSource.entities.add({
polygon: {
hierarchy: positionData,
material: new Cesium.ColorMaterialProperty(Cesium.Color.WHITE.withAlpha(0.7))
}
});
default:
return;
}
}; ECesium.Tools.prototype.getLatestLength = function (activeShapePoints) {
const length = activeShapePoints.length;
const endPoint = activeShapePoints[length - 1];
const startPoint = activeShapePoints[length - 2];
const startCartographic = Cesium.Cartographic.fromCartesian(startPoint);
const endCartographic = Cesium.Cartographic.fromCartesian(endPoint);
this.geodesic.setEndPoints(startCartographic, endCartographic);
return Math.round(this.geodesic.surfaceDistance);
}; ECesium.Tools.prototype.createMeasurePoint = function (worldPosition, callback) {
return this.dataSource.entities.add({
position: worldPosition,
point: {
color: Cesium.Color.WHITE,
pixelSize: 8,
outlineColor: Cesium.Color.RED,
outlineWidth: 3,
heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
scaleByDistance: new Cesium.NearFarScalar(0, 0, 1, 1)
}
});
}; ECesium.Tools.prototype.createLabel = function (worldPosition, text) {
return this.dataSource.entities.add({
position: worldPosition,
label: {
text: text,
showBackground: true,
backgroundColor: new Cesium.Color(1, 1, 1, 0.7),
backgroundPadding: new Cesium.Cartesian2(7, 5),
font: '16px sans-serif',
fillColor: Cesium.Color.BLACK,
outlineColor: Cesium.Color.BLACK,
pixelOffset: new Cesium.Cartesian2(-15, -15)
}
});
}; ECesium.Tools.prototype.deactivate = function () {
if (this.handler) {
this.handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK);
} this.drawingMode = null;
}; ECesium.Tools.prototype.DRAW_TYPE = {
Point: 'Point',
PolyLine: 'PolyLine',
Polygon: 'Polygon'
}; ECesium.Tools.prototype.MEASURE_TYPE = {
MEASURE_DISTANCE: 'MeasureTerrainDistance',
MEASURE_AREA: 'MeasureTerrainArea'
};
export default ECesium;

   使用时直接实例化ECesium

this.tool = new ECesium.Tools(this.viewer);

   绘制图形

this.tool.draw('Point/PolyLine/Polygon');

   测距

this.tool.measure(MeasureTerrainDistance);

Tips*面积测量没有添加计算方法,后期会加上。

Cesium 绘制点、线、面和测距的更多相关文章

  1. 【带着canvas去流浪(5)】绘制K线图

    目录 一. 任务说明 二. 重点提示 三. 示例代码 示例代码托管在:http://www.github.com/dashnowords/blogs 博客园地址:<大史住在大前端>原创博文 ...

  2. CAD交互绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  3. CAD交互绘制样条线(com接口)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  4. CAD参数绘制样条线(com接口)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定位置.详细说明如下: 参数 说明 DOUBL ...

  5. CAD参数绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定位置.详细说明如下: 参数 说明 DOUBL ...

  6. CAD动态绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  7. 带着canvas去流浪系列之五 绘制K线图

    [摘要] 用canvas原生API实现百度Echarts 示例代码托管在:http://www.github.com/dashnowords/blogs 一. 任务说明 使用原生canvasAPI绘制 ...

  8. 用Python爬取股票数据,绘制K线和均线并用机器学习预测股价(来自我出的书)

    最近我出了一本书,<基于股票大数据分析的Python入门实战 视频教学版>,京东链接:https://item.jd.com/69241653952.html,在其中用股票范例讲述Pyth ...

  9. 使用Python的pandas模块、mplfinance模块、matplotlib模块绘制K线图

    目录 pandas模块.mplfinance模块和matplotlib模块介绍 pandas模块 mplfinance模块和matplotlib模块 安装mplfinance模块.pandas模块和m ...

  10. mapboxgl绘制3D线

    最近遇到个需求,使用mapboxgl绘制行政区划图层,要求把行政区划拔高做出立体效果,以便突出显示. 拿到这个需求后,感觉很简单呀,只需要用fill-extrusion方式绘制就可以啦,实现出来是这个 ...

随机推荐

  1. Maven把项目依赖的所有jar包都打到同一个jar中

    目录 1 使用maven-shade-plugin 2 推荐: 使用maven-assembly-plugin 3 扩展: Maven安装本地jar包到本地仓库 4 扩展: 手动生成jar包 5 扩展 ...

  2. python——矩阵的奇异值分解,对图像进行SVD

    矩阵SVD 奇异值分解(Singular Value Decomposition)是一种重要的矩阵分解方法,可以看做是对方阵在任意矩阵上的推广.Singular的意思是突出的,奇特的,非凡的,按照这样 ...

  3. C#机器学习之判断日报是否合格

    简单来说机器学习的核心步骤在于“获取学习数据:选择机器算法:定型模型:评估模型,预测模型结果”,下面本人就以判断日报内容是否合格为例为大家简单的阐述一下C#的机器学习. 第一步:问题分析 根据需求可以 ...

  4. Java 在PPT中绘制图形

    Microsoft PowerPoint可支持在幻灯片中插入各种类型的图形并且可设置图形填充.线条颜色.图形大小.位置等.下面将通过Java编程来演示在PPT中绘制图形的方法. 工具:Free Spi ...

  5. 第一章 渲染调度来龙去脉——插入自己的shader

    总有人会问,这个或者那个功能怎么弄,或者看到别人做了什么酷炫的效果也想仿造.其实,功能的实现无非两种: 1.调用Cesium现有的API组合实现:往往照猫画虎,还存在性能不过关的问题,绕了半天其实终究 ...

  6. openlayers一:显示地图与鼠标地理坐标

    openlayers两个好用的开源JS互动地图库之一,另一个是leaflet. openlayers的特点是是大而全,自身包含绝大多数功能,文档好看. leaflet是小而美,自身小,但支持扩展,好用 ...

  7. Retrofit的初次使用

    rxretrofitlibrary是一个已经写好的网络框架库,先以本地Module导入到自己的项目中. 1.它的初始化操作大多在自定义的application中完成,如: public class A ...

  8. Ubuntu16 Nginx的安装与基本配置

    关于Nginx 它是一个轻量级.高性能.稳定性高.并发性好的HTTP和反向代理服务器,当我们搭建自己的应用时,通常用它作为反向代理服务器,图片服务器和负载均衡. 1.Ubuntu 16安装 Nginx ...

  9. #Java学习之路——基础阶段二(第二篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  10. Android开发:Eclipse+OpenCV环境搭建

    一.OpenCV预备: OpenCV是一个跨平台计算机视觉库,可以运行在Linux.Windows.Android和Mac OS操作系统上.它由一系列 C 函数和少量 C++ 类构成,同时提供了Pyt ...