123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316 |
- <!-- 2017-12-6 14:11:44 | 修改 木遥(微信: http://marsgis.cn/weixin.html ) -->
- <!DOCTYPE html>
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <meta name="viewport"
- content="width=device-width,initial-scale=1,user-scalable=0,minimum-scale=1.0,maximum-scale=1.0" />
- <meta name="apple-touch-fullscreen" content="yes" />
- <meta name="apple-mobile-web-app-capable" content="yes" />
- <meta name="apple-mobile-web-app-status-bar-style" content="black" />
- <meta name="format-detection" content="telephone=no" />
- <meta name="x5-fullscreen" content="true" />
- <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1" />
- <!-- 标题及搜索关键字 -->
- <meta name="keywords" content="火星科技,cesium,3D,GIS,marsgis,三维,地球,地图,开发,框架,系统,示例,资料,模型,离线,外包,合肥,安徽,中国" />
- <meta name="description"
- content="火星科技 合肥火星 合肥火星科技 合肥火星科技有限公司 leaflet leaflet框架 leaflet开发 cesium cesium开发 cesium框架 三维 地球 模型 gis marsgis 地图离线 地图开发 地图框架 地图外包 框架 开发 外包 地图离线 二维地图 三维地图 全景漫游 地理信息系统 云GIS 三维GIS GIS平台 WebGIS" />
- <link rel="shortcut icon" type="image/x-icon" href="" />
- <title>高压电线(自动计算线) </title>
- <script type="text/javascript" src="../lib/include-lib.js" libpath="../lib/"
- include="jquery,echarts,font-awesome,bootstrap,layer,haoutil,turf,mars3d"></script>
- <link href="css/style.css" rel="stylesheet" />
- </head>
- <body class="dark">
- <!--加载前进行操作提示,优化用户体验-->
- <div id="mask" class="signmask" onclick="removeMask()"></div>
- <div id="mars3dContainer" class="mars3d-container"></div>
- <div class="infoview">
- <div id="section" style="width: 500px; height: 200px"></div>
- </div>
- <script src="./js/common.js"></script>
- <script type="text/javascript">
- "use script"; //开发环境建议开启严格模式
- var map;
- var graphicLayer;
- function initMap(options) {
- //合并属性参数,可覆盖config.json中的对应配置
- var mapOptions = mars3d.Util.merge(options, {
- scene: {
- center: { lat: 29.526546, lng: 119.823425, alt: 803, heading: 178, pitch: -27 },
- fxaa: true,
- },
- });
- //创建三维地球场景
- map = new mars3d.Map("mars3dContainer", mapOptions);
- //创建Graphic图层
- graphicLayer = new mars3d.layer.GraphicLayer();
- map.addLayer(graphicLayer);
- queryTowerApiData().then(function (res) {
- showData(res.data);
- });
- }
- //访问后端接口,取数据
- function queryTowerApiData() {
- return new Promise(function (resolve, reject) {
- $.ajax({
- url: "//data.mars3d.cn/file/apidemo/tower.json",
- type: "get",
- dataType: "json",
- success: function (result) {
- resolve(result);
- },
- error: function (data) {
- reject(data);
- },
- });
- });
- }
- function showData(arrdata) {
- var polylines1 = [],
- polylines2 = [],
- polylines3 = [],
- polylines4 = [],
- polylines5 = [];
- var polylinesTB = [];
- for (var i = 0; i < arrdata.length; i++) {
- var item = arrdata[i];
- //所在经纬度坐标及海拔高度
- var longitude = Number(item.longitude);
- var latitude = Number(item.latitude);
- var height = Number(item.height);
- var originPoint = {
- longitude: longitude,
- latitude: latitude,
- height: height,
- };
- var position = Cesium.Cartesian3.fromDegrees(originPoint.longitude, originPoint.latitude, originPoint.height);
- //计算电线塔转角角度
- var degree = parseInt(item.degree);
- //5条线路坐标
- let hpr = new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(degree), 0, 0);
- var newPoint1 = mars3d.PointUtil.getPositionByHprAndOffset(position, new Cesium.Cartesian3(0.341789, 16.837972, 50.717621), hpr);
- var newPoint2 = mars3d.PointUtil.getPositionByHprAndOffset(position, new Cesium.Cartesian3(0.34241, -16.838163, 50.717617), hpr);
- var newPoint3 = mars3d.PointUtil.getPositionByHprAndOffset(position, new Cesium.Cartesian3(-0.025005, 0.022878, 39.540545), hpr);
- var newPoint4 = mars3d.PointUtil.getPositionByHprAndOffset(position, new Cesium.Cartesian3(-0.024999, 15.009109, 39.303012), hpr);
- var newPoint5 = mars3d.PointUtil.getPositionByHprAndOffset(position, new Cesium.Cartesian3(-0.025001, -15.009585, 39.301099), hpr);
- polylinesTB.push(newPoint3); //图标显示的点
- if (i === 0) {
- polylines1.push(newPoint1);
- polylines2.push(newPoint2);
- polylines3.push(newPoint3);
- polylines4.push(newPoint4);
- polylines5.push(newPoint5);
- } else {
- var angularityFactor = -5000,
- num = 50;
- var positions = mars3d.PolyUtil.getLinkedPointList(polylines1[polylines1.length - 1], newPoint1, angularityFactor, num); //计算曲线点
- polylines1 = polylines1.concat(positions);
- positions = mars3d.PolyUtil.getLinkedPointList(polylines2[polylines2.length - 1], newPoint2, angularityFactor, num); //计算曲线点
- polylines2 = polylines2.concat(positions);
- positions = mars3d.PolyUtil.getLinkedPointList(polylines3[polylines3.length - 1], newPoint3, angularityFactor, num); //计算曲线点
- polylines3 = polylines3.concat(positions);
- positions = mars3d.PolyUtil.getLinkedPointList(polylines4[polylines4.length - 1], newPoint4, angularityFactor, num); //计算曲线点
- polylines4 = polylines4.concat(positions);
- positions = mars3d.PolyUtil.getLinkedPointList(polylines5[polylines5.length - 1], newPoint5, angularityFactor, num); //计算曲线点
- polylines5 = polylines5.concat(positions);
- }
- var html = mars3d.Util.getTemplateHtml({
- title: "塔杆",
- template: [
- { field: "roadName", name: "所属线路" },
- { field: "towerId", name: "杆塔编号" },
- { field: "杆塔型号", name: "杆塔型号" },
- { field: "杆塔性质", name: "杆塔性质" },
- { field: "杆塔类型", name: "杆塔类型" },
- { field: "投运日期", name: "投运日期" },
- { field: "杆塔全高", name: "杆塔全高" },
- { field: "设计单位", name: "设计单位" },
- { field: "施工单位", name: "施工单位" },
- { field: "height", name: "海拔高度" },
- ],
- attr: item,
- });
- drawWireTowerModel(position, degree, html);
- }
- //绘制路线
- drawGuideLine(polylines1, "#ffffff");
- drawGuideLine(polylines2, "#ffffff");
- drawGuideLine(polylines3);
- drawGuideLine(polylines4, "#ff0000");
- drawGuideLine(polylines5, "#0000ff");
- //绘制断面图echarts图表
- computeSurfacePointsHeight(polylinesTB);
- }
- //绘制电线塔模型
- function drawWireTowerModel(position, degree, inthtml) {
- var modelUrls = ["tower.glb", "V.glb", "vertical01.glb", "vertical02.glb"];
- for (var j = 0; j < modelUrls.length; j++) {
- var primitive = new mars3d.graphic.ModelPrimitive({
- position: position,
- style: {
- url: "//data.mars3d.cn/gltf/mars/tower/" + modelUrls[j],
- heading: degree,
- scale: 1,
- distanceDisplayCondition: new Cesium.DistanceDisplayCondition(0, 4000.0),
- },
- });
- graphicLayer.addGraphic(primitive);
- primitive.bindPopup(inthtml);
- }
- }
- function drawGuideLine(positions, color) {
- var primitive = new mars3d.graphic.PolylinePrimitive({
- positions: positions,
- style: {
- width: 4,
- material: mars3d.MaterialUtil.createMaterial(mars3d.MaterialType.Color, {
- color: color || "#ffff00",
- }),
- },
- });
- graphicLayer.addGraphic(primitive);
- }
- //绘制断面图echarts图表
- function computeSurfacePointsHeight(polylines5) {
- // 绘制断面图
- mars3d.PolyUtil.computeSurfacePoints({
- scene: map.scene,
- positions: polylines5, //需要计算的源路线坐标数组
- callback: function (raisedPositions, noHeight) {
- //raisedPositions为含高程信息的新坐标数组,noHeight为标识是否存在无地形数据。
- var heightArry = [],
- heightTDArray = [],
- distanceArray;
- for (let i = 0; i < polylines5.length; i++) {
- let item = polylines5[i];
- let carto = Cesium.Cartographic.fromCartesian(item);
- let height = mars3d.Util.formatNum(carto.height); //设计高度 当小数点后面的数字一致时,会省略小数点,不显示
- let tdHeight = mars3d.Util.formatNum(Cesium.Cartographic.fromCartesian(raisedPositions[i]).height); //地面高度
- heightArry.push(height);
- heightTDArray.push(tdHeight);
- // 距离数组
- var positionsLineFirst = raisedPositions[0];
- distanceArray = raisedPositions.map(function (data) {
- return Math.round(Cesium.Cartesian3.distance(data, positionsLineFirst)); //计算两点之间的距离,返回距离
- });
- }
- drawHeightToDistanceEcharts(heightArry, heightTDArray, distanceArray);
- },
- });
- }
- function drawHeightToDistanceEcharts(heightArry, heightTDArray, distanceArray) {
- var myChart = echarts.init(document.getElementById("section"), "dark");
- var option = {
- title: {
- text: "断面图",
- left: 25,
- },
- tooltip: {
- trigger: "axis",
- axisPointer: {
- type: "cross",
- },
- },
- toolbox: {
- show: false,
- feature: {
- saveAsImage: {},
- },
- },
- legend: {
- data: ["地形高程", "电线高程"],
- },
- grid: {
- left: 50,
- width: 425,
- top: 50,
- bottom: 30,
- },
- xAxis: {
- type: "category",
- boundaryGap: false,
- data: distanceArray,
- },
- yAxis: {
- type: "value",
- axisLabel: {
- formatter: "{value} 米",
- },
- axisPointer: {
- snap: true,
- },
- },
- dataZoom: {
- start: 80,
- type: "inside",
- },
- series: [
- {
- name: "地形高程",
- type: "line",
- smooth: true,
- itemStyle: {
- normal: {
- color: "rgb(255, 255, 0)",
- },
- },
- data: heightTDArray,
- },
- {
- name: "电线高程",
- type: "line",
- smooth: true,
- itemStyle: {
- normal: {
- color: "rgb(255, 70, 131)",
- },
- },
- data: heightArry,
- markPoint: undefined,
- },
- ],
- };
- myChart.setOption(option, true);
- }
- </script>
- </body>
- </html>
|