@vtx/cs-map 1.0.92 → 1.0.93
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/_util/EventEmitter.js +3 -3
- package/lib/_util/Provider.js +1 -1
- package/lib/_util/Provider.js.map +1 -1
- package/lib/_util/StyleCache.js +3 -3
- package/lib/_util/encryptParams.js +1 -1
- package/lib/_util/encryptParams.js.map +1 -1
- package/lib/_util/filterSpecialCharacters.js +6 -6
- package/lib/_util/filterSpecialCharacters.js.map +1 -1
- package/lib/_util/getBBoxFromGeojson.js +5 -5
- package/lib/_util/getDefaultMapInfo.js +1 -1
- package/lib/_util/getSystemInfo.js +1 -1
- package/lib/_util/getToken.js +3 -3
- package/lib/_util/getToken.js.map +1 -1
- package/lib/_util/getUrlParam.js +1 -1
- package/lib/_util/getUrlParam.js.map +1 -1
- package/lib/_util/http.js +5 -5
- package/lib/_util/http.js.map +1 -1
- package/lib/_util/layer.js +8 -8
- package/lib/_util/layer.js.map +1 -1
- package/lib/_util/useColSize.js +1 -1
- package/lib/_util/useColSize.js.map +1 -1
- package/lib/_util/useSet.js +5 -5
- package/lib/_util/useSet.js.map +1 -1
- package/lib/building-tiles-layer/BuildingTilesLayer.js +11 -11
- package/lib/building-tiles-layer/BuildingTilesLayer.js.map +1 -1
- package/lib/building-tiles-layer/index.js +2 -2
- package/lib/building-tiles-layer/index.js.map +1 -1
- package/lib/cesium-tiles-layer/CesiumTilesLayer.js +11 -11
- package/lib/cesium-tiles-layer/CesiumTilesLayer.js.map +1 -1
- package/lib/cesium-tiles-layer/index.js +2 -2
- package/lib/cesium-tiles-layer/index.js.map +1 -1
- package/lib/circle/Circle.js +11 -11
- package/lib/circle/Circle.js.map +1 -1
- package/lib/circle/index.js +1 -1
- package/lib/circle/index.js.map +1 -1
- package/lib/circle-fly/index.js +5 -5
- package/lib/circle-fly/index.js.map +1 -1
- package/lib/demand-layer/DemandLayer.js +14 -14
- package/lib/demand-layer/DemandLayer.js.map +1 -1
- package/lib/demand-layer/index.js +5 -5
- package/lib/demand-layer/index.js.map +1 -1
- package/lib/dom/Dom.js +7 -7
- package/lib/dom/Dom.js.map +1 -1
- package/lib/dom/index.js +4 -4
- package/lib/dom/index.js.map +1 -1
- package/lib/excavation-analysis/Cut.js +203 -0
- package/lib/excavation-analysis/Cut.js.map +1 -0
- package/lib/excavation-analysis/TilesetCut.js +96 -165
- package/lib/excavation-analysis/TilesetCut.js.map +1 -1
- package/lib/excavation-analysis/hooks/useDrawHandler.js +1 -1
- package/lib/excavation-analysis/hooks/useDrawHandler.js.map +1 -1
- package/lib/excavation-analysis/hooks/useTerrainClipPlan.js +13 -3
- package/lib/excavation-analysis/hooks/useTerrainClipPlan.js.map +1 -1
- package/lib/excavation-analysis/hooks/useTileSetCut.js +5 -3
- package/lib/excavation-analysis/hooks/useTileSetCut.js.map +1 -1
- package/lib/excavation-analysis/index.js +26 -8
- package/lib/excavation-analysis/index.js.map +1 -1
- package/lib/feature-layer/FeatureLayer.js +31 -25
- package/lib/feature-layer/FeatureLayer.js.map +1 -1
- package/lib/feature-layer/createFeatureCollection.js +9 -9
- package/lib/feature-layer/createFeatureCollection.js.map +1 -1
- package/lib/feature-layer/index.js +14 -8
- package/lib/feature-layer/index.js.map +1 -1
- package/lib/fence-layer/FenceLayer.js +19 -19
- package/lib/fence-layer/FenceLayer.js.map +1 -1
- package/lib/fence-layer/index.js +2 -2
- package/lib/fence-layer/index.js.map +1 -1
- package/lib/fly-line-layer/FlyLineLayer.js +18 -18
- package/lib/fly-line-layer/FlyLineLayer.js.map +1 -1
- package/lib/fly-line-layer/LineFlowMaterialProperty.js +3 -3
- package/lib/fly-line-layer/LineFlowMaterialProperty.js.map +1 -1
- package/lib/fly-line-layer/index.js +1 -1
- package/lib/fly-line-layer/index.js.map +1 -1
- package/lib/gif-dom-layer/GifDomLayer.js +8 -8
- package/lib/gif-dom-layer/GifDomLayer.js.map +1 -1
- package/lib/gif-dom-layer/index.js +1 -1
- package/lib/gif-dom-layer/index.js.map +1 -1
- package/lib/gradation-line-layer/GradationLineLayer.js +9 -9
- package/lib/gradation-line-layer/GradationLineLayer.js.map +1 -1
- package/lib/gradation-line-layer/index.js +1 -1
- package/lib/gradation-line-layer/index.js.map +1 -1
- package/lib/group-layer/GroupLayer.js +5 -5
- package/lib/group-layer/GroupLayer.js.map +1 -1
- package/lib/group-layer/index.js +5 -5
- package/lib/group-layer/index.js.map +1 -1
- package/lib/heatmap-layer/CesiumHeatmap.js +15 -15
- package/lib/heatmap-layer/CesiumHeatmap.js.map +1 -1
- package/lib/heatmap-layer/HeatmapLayer.js +17 -17
- package/lib/heatmap-layer/HeatmapLayer.js.map +1 -1
- package/lib/heatmap-layer/index.js +9 -9
- package/lib/heatmap-layer/index.js.map +1 -1
- package/lib/highlight-layer/HighlightLayer.js +7 -7
- package/lib/highlight-layer/HighlightLayer.js.map +1 -1
- package/lib/highlight-layer/index.js +1 -1
- package/lib/highlight-layer/index.js.map +1 -1
- package/lib/image-layer/ImageLayer.js +14 -14
- package/lib/image-layer/ImageLayer.js.map +1 -1
- package/lib/image-layer/index.js +2 -2
- package/lib/image-layer/index.js.map +1 -1
- package/lib/image-wms-layer/ImageWmsLayer.js +6 -6
- package/lib/image-wms-layer/ImageWmsLayer.js.map +1 -1
- package/lib/image-wms-layer/index.js +4 -4
- package/lib/image-wms-layer/index.js.map +1 -1
- package/lib/index.js +8 -1
- package/lib/index.js.map +1 -1
- package/lib/inundate-analysis/index.js +6 -6
- package/lib/inundate-analysis/index.js.map +1 -1
- package/lib/label/Label.js +16 -16
- package/lib/label/Label.js.map +1 -1
- package/lib/label/index.js +1 -1
- package/lib/label/index.js.map +1 -1
- package/lib/legend/index.js +11 -11
- package/lib/legend/index.js.map +1 -1
- package/lib/line-flow-layer/LineFlowLayer.js +8 -8
- package/lib/line-flow-layer/LineFlowLayer.js.map +1 -1
- package/lib/line-flow-layer/index.js +1 -1
- package/lib/line-flow-layer/index.js.map +1 -1
- package/lib/map/InfoTool/index.js +7 -7
- package/lib/map/InfoTool/index.js.map +1 -1
- package/lib/map/InfoWindow.js +5 -5
- package/lib/map/InfoWindow.js.map +1 -1
- package/lib/map/Layers.js +14 -14
- package/lib/map/Layers.js.map +1 -1
- package/lib/map/Popup.js +10 -10
- package/lib/map/Popup.js.map +1 -1
- package/lib/map/base/imagery/amap/AmapImageryProvider.js +9 -9
- package/lib/map/base/imagery/amap/AmapImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/amap/AmapMercatorTilingScheme.js +9 -9
- package/lib/map/base/imagery/amap/AmapMercatorTilingScheme.js.map +1 -1
- package/lib/map/base/imagery/baidu/BaiduImageryProvider.js +4 -4
- package/lib/map/base/imagery/baidu/BaiduImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/baidu/BaiduMercatorProjection.js +3 -3
- package/lib/map/base/imagery/baidu/BaiduMercatorTilingScheme.js +9 -9
- package/lib/map/base/imagery/baidu/BaiduMercatorTilingScheme.js.map +1 -1
- package/lib/map/base/imagery/geoq/GeoQImageryProvider.js +9 -9
- package/lib/map/base/imagery/geoq/GeoQImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/google/GoogleImageryProvider.js +8 -8
- package/lib/map/base/imagery/google/GoogleImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/irs/IRSImageryProvider.js +10 -10
- package/lib/map/base/imagery/irs/IRSImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/tdt/JiangSuTdtImageryProvider.js +8 -8
- package/lib/map/base/imagery/tdt/JiangSuTdtImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/tdt/TdtImageryProvider.js +8 -8
- package/lib/map/base/imagery/tdt/TdtImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/tencent/TencentImageryProvider.js +8 -8
- package/lib/map/base/imagery/tencent/TencentImageryProvider.js.map +1 -1
- package/lib/map/base/imagery/transform/AmapMercatorTilingScheme.js +9 -9
- package/lib/map/base/imagery/transform/AmapMercatorTilingScheme.js.map +1 -1
- package/lib/map/base/imagery/transform/CoordTransform.js +3 -3
- package/lib/map/base/index.js +12 -12
- package/lib/map/base/index.js.map +1 -1
- package/lib/map/hooks/useGetMapFeatureInfoByText.js +3 -3
- package/lib/map/hooks/useGetMapFeatureInfoByText.js.map +1 -1
- package/lib/map/index.js +25 -17
- package/lib/map/index.js.map +1 -1
- package/lib/map/material/AroundPoint.js +3 -3
- package/lib/map/material/AroundPoint.js.map +1 -1
- package/lib/map/material/ODLineLayer.js +3 -3
- package/lib/map/material/ODLineLayer.js.map +1 -1
- package/lib/map/material/PolylineTrailLinkMaterialProperty.js +4 -4
- package/lib/map/material/PolylineTrailLinkMaterialProperty.js.map +1 -1
- package/lib/map/material/PolylineTrailMaterialProperty.js +4 -4
- package/lib/map/material/PolylineTrailMaterialProperty.js.map +1 -1
- package/lib/map/material/TilesBuilding.js +3 -3
- package/lib/map/material/TilesBuilding.js.map +1 -1
- package/lib/map/material/index.js +1 -1
- package/lib/map/material/index.js.map +1 -1
- package/lib/marker/Marker.js +17 -17
- package/lib/marker/Marker.js.map +1 -1
- package/lib/marker/index.js +1 -1
- package/lib/marker/index.js.map +1 -1
- package/lib/model/Model.js +16 -16
- package/lib/model/Model.js.map +1 -1
- package/lib/model/index.js +4 -4
- package/lib/model/index.js.map +1 -1
- package/lib/navigation/index.js +5 -5
- package/lib/navigation/index.js.map +1 -1
- package/lib/pipe-tiles-layer/PipeTilesLayer.js +12 -12
- package/lib/pipe-tiles-layer/PipeTilesLayer.js.map +1 -1
- package/lib/pipe-tiles-layer/index.js +2 -2
- package/lib/pipe-tiles-layer/index.js.map +1 -1
- package/lib/point/Point.js +16 -16
- package/lib/point/Point.js.map +1 -1
- package/lib/point/index.js +1 -1
- package/lib/point/index.js.map +1 -1
- package/lib/polygon/Polygon.js +16 -16
- package/lib/polygon/Polygon.js.map +1 -1
- package/lib/polygon/index.js +1 -1
- package/lib/polygon/index.js.map +1 -1
- package/lib/polyline/Polyline.js +16 -16
- package/lib/polyline/Polyline.js.map +1 -1
- package/lib/polyline/index.js +1 -1
- package/lib/polyline/index.js.map +1 -1
- package/lib/renderer/index.js +4 -4
- package/lib/renderer/index.js.map +1 -1
- package/lib/scene-roam/index.js +2 -2
- package/lib/scene-roam/index.js.map +1 -1
- package/lib/slider-scene/index.js +86 -0
- package/lib/slider-scene/index.js.map +1 -0
- package/lib/slider-scene/style/css.js +4 -0
- package/lib/slider-scene/style/css.js.map +1 -0
- package/lib/slider-scene/style/index.css +12 -0
- package/lib/slider-scene/style/index.js +4 -0
- package/lib/slider-scene/style/index.js.map +1 -0
- package/lib/slider-scene/style/index.less +13 -0
- package/lib/split-screen/index.js +5 -5
- package/lib/split-screen/index.js.map +1 -1
- package/lib/tools/base-map-switch/index.js +6 -6
- package/lib/tools/base-map-switch/index.js.map +1 -1
- package/lib/tools/components/Icon/index.js +1 -1
- package/lib/tools/components/Icon/index.js.map +1 -1
- package/lib/tools/components/Icon/svg.js +1 -1
- package/lib/tools/components/Icon/svg.js.map +1 -1
- package/lib/tools/components/Modal/index.js +1 -1
- package/lib/tools/components/Modal/index.js.map +1 -1
- package/lib/tools/components/item-wrap/index.js +5 -5
- package/lib/tools/components/item-wrap/index.js.map +1 -1
- package/lib/tools/components/tool-Item/index.js +1 -1
- package/lib/tools/components/tool-Item/index.js.map +1 -1
- package/lib/tools/dimension-switch/index.js +5 -5
- package/lib/tools/dimension-switch/index.js.map +1 -1
- package/lib/tools/index.js +2 -2
- package/lib/tools/index.js.map +1 -1
- package/lib/tools/layer-control/index.js +9 -9
- package/lib/tools/layer-control/index.js.map +1 -1
- package/lib/tools/layer-control-popover/LayersCheckService.js +5 -5
- package/lib/tools/layer-control-popover/LayersCheckService.js.map +1 -1
- package/lib/tools/layer-control-popover/index.js +9 -9
- package/lib/tools/layer-control-popover/index.js.map +1 -1
- package/lib/tools/loading/index.js +5 -5
- package/lib/tools/loading/index.js.map +1 -1
- package/lib/tools/map-search/Select/index.js +5 -5
- package/lib/tools/map-search/Select/index.js.map +1 -1
- package/lib/tools/map-search/index.js +8 -8
- package/lib/tools/map-search/index.js.map +1 -1
- package/lib/tools/tip/index.js +1 -1
- package/lib/tools/tip/index.js.map +1 -1
- package/lib/tools/tool-box/Measure/Area/index.js +2 -2
- package/lib/tools/tool-box/Measure/Area/index.js.map +1 -1
- package/lib/tools/tool-box/Measure/Distance/index.js +2 -2
- package/lib/tools/tool-box/Measure/Distance/index.js.map +1 -1
- package/lib/tools/tool-box/Measure/Height/index.js +2 -2
- package/lib/tools/tool-box/Measure/Height/index.js.map +1 -1
- package/lib/tools/tool-box/Measure/Measure.js +3 -3
- package/lib/tools/tool-box/Measure/Measure.js.map +1 -1
- package/lib/tools/tool-box/Measure/index.js +4 -4
- package/lib/tools/tool-box/Measure/index.js.map +1 -1
- package/lib/tools/tool-box/index.js +6 -6
- package/lib/tools/tool-box/index.js.map +1 -1
- package/lib/trail-polyline-layer/TrailPolylineLayer.js +9 -9
- package/lib/trail-polyline-layer/TrailPolylineLayer.js.map +1 -1
- package/lib/trail-polyline-layer/index.js +1 -1
- package/lib/trail-polyline-layer/index.js.map +1 -1
- package/lib/wall/WallGeometry.js +13 -13
- package/lib/wall/WallGeometry.js.map +1 -1
- package/lib/wall/index.js +1 -1
- package/lib/wall/index.js.map +1 -1
- package/lib/water-surface-layer/WaterSurfaceLayer.js +16 -16
- package/lib/water-surface-layer/WaterSurfaceLayer.js.map +1 -1
- package/lib/water-surface-layer/index.js +2 -2
- package/lib/water-surface-layer/index.js.map +1 -1
- package/lib/weather/Weather.js +4 -4
- package/lib/weather/Weather.js.map +1 -1
- package/lib/weather/index.js +1 -1
- package/lib/weather/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Cut.js","names":["_cesium","require","_typeof","o","Symbol","iterator","constructor","prototype","_classCallCheck","a","n","TypeError","_defineProperties","e","r","t","length","enumerable","configurable","writable","Object","defineProperty","_toPropertyKey","key","_createClass","i","_toPrimitive","toPrimitive","call","String","Number","Cut","tileset","opt","console","log","_iscutOutter","iscutOutter","cutRegions","center","boundingSphere","enuMtx4","Transforms","eastNorthUpToFixedFrame","modelMatrix","Matrix4","inverse","canvas","undefined","get","set","val","updateShader","value","addRegion","attr","_ref","positions","id","Date","getTime","Math","random","toFixed","index","findIndex","item","push","removeRegionById","splice","destroy","customShader","_this","fs_textureMapRect","allUniforms","u_inverseModel","type","UniformType","MAT4","clone","u_unionCutRegions","BOOL","fs","forEach","element","uniforms","createUniforms","combine","concat","CustomShader","fragmentShaderText","_this2","ceil","xs","ys","zs","modelPoints","map","p","point","multiplyByPoint","Cartesian3","x","y","z","rect","Cartesian4","min","apply","max","document","createElement","width","height","w","ctx","getContext","fillStyle","fillRect","beginPath","moveTo","lineTo","closePath","fill","VEC4","SAMPLER_2D","TextureUniform","url","toDataURL","minificationFilter","TextureMinificationFilter","LINEAR","magnificationFilter","TextureMagnificationFilter","_default","exports"],"sources":["excavation-analysis/Cut.js"],"sourcesContent":["import {\n Matrix4,\n Transforms,\n Cartesian3,\n UniformType,\n combine,\n CustomShader,\n Cartesian4,\n TextureUniform,\n TextureMinificationFilter,\n TextureMagnificationFilter\n} from 'cesium';\n\n// 三维模型裁剪\nclass Cut {\n constructor(tileset, opt) {\n if (!tileset) {\n console.log(\"缺少模型\");\n return;\n }\n this.tileset = tileset;\n this.opt = opt || {};\n /**\n * @property {Boolean} iscutOutter 是否为外部裁剪,默认为内部裁剪\n */\n this._iscutOutter = this.opt.iscutOutter; // 是否为外部裁剪 默认为内部裁剪\n this.cutRegions = []; // 当前裁剪面数组对象\n /* this.modelMatrix = new Matrix4(); // 世界坐标系--》模型坐标系\n Matrix4.inverseTransformation(this.tileset.root.computedTransform, this.modelMatrix) */\n // 建立模型中心点坐标系\n const center = this.tileset.boundingSphere.center;\n const enuMtx4 = Transforms.eastNorthUpToFixedFrame(center);\n this.modelMatrix = Matrix4.inverse(enuMtx4, new Matrix4());\n this.canvas = undefined;\n }\n\n get iscutOutter() {\n return this._iscutOutter\n }\n\n set iscutOutter(val) {\n this._iscutOutter = val;\n this.updateShader();\n }\n\n /**\n * 添加裁剪面\n * @param {Object} attr 参数\n * @param {Cartesian3[]} attr.positions 压平面坐标\n * @param {Number} attr.id 唯一标识\n */\n addRegion(attr) {\n let { positions, id } = attr || {};\n if (!id) id = (new Date()).getTime() + \"\" + Number(Math.random() * 1000).toFixed(0);\n if (!positions || positions.length < 3) {\n console.log(\"缺少裁剪面坐标\");\n return;\n }\n const index = this.cutRegions.findIndex(item => item.id === id)\n if (index == -1) {\n this.cutRegions.push({\n id: id,\n positions: positions\n })\n } else {\n this.cutRegions[index].positions = positions;\n }\n this.updateShader()\n }\n /**\n * 移除裁剪面\n * @param {String} id\n */\n removeRegionById(id) {\n if (id) { // 表示移除所有的裁剪面\n const index = this.cutRegions.findIndex(item => item.id === id)\n if (index != -1) this.cutRegions.splice(index, 1)\n } else { // 表示移除单个的裁剪面\n this.cutRegions = [];\n }\n this.updateShader();\n }\n\n /**\n * 销毁\n */\n destroy() {\n this.tileset.customShader = undefined;\n }\n\n /**\n * 修改模型着色器\n */\n updateShader() {\n // 定义着色器中裁剪函数\n const fs_textureMapRect = `\n vec4 textureMapRect(vec4 rect, sampler2D map, vec2 xy) {\n // 判断当前图元坐标和多边形关系 如果在多边形内 进行纹素拾取\n if (xy.x >= rect.x && xy.x <= rect.z && xy.y >= rect.y && xy.y <= rect.w) {\n float w = rect.z - rect.x;\n float h = rect.w - rect.y;\n float s = (xy.x - rect.x) / w;\n float t = (xy.y - rect.y) / h;\n vec4 color = texture(map, vec2(s, 1.0 - t));\n return color;\n }\n return vec4(1.0);\n }\n `;\n\n let allUniforms = {\n u_inverseModel: {\n type: UniformType.MAT4,\n value: this.modelMatrix.clone()\n },\n u_unionCutRegions: {\n type: UniformType.BOOL,\n value: this._iscutOutter\n }\n }\n\n // 构建多区域着色器\n let fs = ``;\n this.cutRegions.forEach(element => {\n const uniforms = this.createUniforms(element.positions, element.id)\n allUniforms = combine(allUniforms, uniforms)\n fs += `\n vec4 color_${element.id} = textureMapRect(u_rect_${element.id}, u_map_${element.id}, xy);\n cutColor *= color_${element.id};\n `\n })\n\n fs += `\n if (u_unionCutRegions) {\n material.diffuse *= (vec3(1.0) - cutColor.rgb);\n } else {\n material.diffuse *= cutColor.rgb;\n }\n if (material.diffuse.r <= 0.0001 && material.diffuse.g <= 0.0001 && material.diffuse.b <= 0.0001) {\n discard;\n }\n `;\n\n this.tileset.customShader = new CustomShader({\n uniforms: allUniforms,\n fragmentShaderText: `\n ${fs_textureMapRect}\n void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) {\n vec4 positionMC = u_inverseModel * vec4(fsInput.attributes.positionWC, 1.0);\n vec2 xy = positionMC.xy;\n vec4 cutColor = vec4(1.0);\n ${fs}\n }`\n })\n\n }\n\n /**\n * 根据坐标创建片元着色器\n * @param {Cartesian3[]} positions\n * @param {String} id\n */\n createUniforms(positions, id) {\n if (!positions || positions.length < 3) {\n console.log(\"缺少裁剪面坐标\");\n return;\n }\n id = id || Math.ceil(Math.random() * 100000) + '_' + Math.ceil(Math.random() * 100000)\n // 根据世界坐标范围计算相对模型坐标范围\n const xs = [], ys = [], zs = []\n // 计算模型坐标系下坐标\n const modelPoints = positions.map(p => {\n const point = Matrix4.multiplyByPoint(this.modelMatrix, p, new Cartesian3());\n xs.push(point.x)\n ys.push(point.y)\n zs.push(point.z)\n return point\n })\n // 计算当前裁剪面边界范围(模型坐标系下)\n const rect = new Cartesian4(Math.min.apply(null, xs), Math.min.apply(null, ys), Math.max.apply(null, xs), Math.max.apply(null, ys))\n const canvas = document.createElement('canvas')\n canvas.width = 1024\n canvas.height = 1024\n const width = rect.z - rect.x\n const height = rect.w - rect.y\n const ctx = canvas.getContext('2d')\n ctx.fillStyle = '#fff' // 设置整体背景为白色\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n ctx.beginPath()\n\n ctx.moveTo(canvas.width * (modelPoints[0].x - rect.x) / width, canvas.height * (modelPoints[0].y - rect.y) / height)\n\n for (let i = 1; i < modelPoints.length; i++) {\n ctx.lineTo(canvas.width * (modelPoints[i].x - rect.x) / width, canvas.height * (modelPoints[i].y - rect.y) / height)\n }\n\n ctx.closePath()\n ctx.fillStyle = '#000' // 根据填充的黑色来裁剪模型\n ctx.fill()\n\n this.canvas = canvas;\n\n const uniforms = {}\n uniforms[`u_rect_${id}`] = {\n type: UniformType.VEC4,\n value: rect\n }\n uniforms[`u_map_${id}`] = {\n type: UniformType.SAMPLER_2D,\n value: new TextureUniform({\n url: canvas.toDataURL()\n }),\n minificationFilter: TextureMinificationFilter.LINEAR,\n magnificationFilter: TextureMagnificationFilter.LINEAR\n }\n\n return uniforms\n }\n\n}\n\nexport default Cut;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -6,92 +6,82 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports["default"] = void 0;
|
|
7
7
|
var _cesium = require("cesium");
|
|
8
8
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
9
|
-
function
|
|
10
|
-
function
|
|
11
|
-
function
|
|
9
|
+
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
10
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
12
|
+
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
13
|
+
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
|
|
14
|
+
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
12
15
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
13
16
|
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
17
|
+
/**
|
|
18
|
+
* @class
|
|
19
|
+
* @description 3dtiles 模型按照(经纬度二维)范围裁剪
|
|
20
|
+
*/
|
|
21
|
+
var Clipping = /*#__PURE__*/function () {
|
|
22
|
+
function Clipping(tileset, opt) {
|
|
23
|
+
_classCallCheck(this, Clipping);
|
|
18
24
|
if (!tileset) {
|
|
19
|
-
|
|
20
|
-
|
|
25
|
+
throw new Error("参数错误!");
|
|
26
|
+
}
|
|
27
|
+
console.log("polygons:", opt.polygons);
|
|
28
|
+
if (opt.polygons && opt.polygons instanceof Array && opt.polygons.length > 0) {
|
|
29
|
+
var _iterator = _createForOfIteratorHelper(opt.polygons),
|
|
30
|
+
_step;
|
|
31
|
+
try {
|
|
32
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
33
|
+
var polygon = _step.value;
|
|
34
|
+
if (!(polygon instanceof Array && polygon.length >= 3)) {
|
|
35
|
+
throw new Error("参数错误!");
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
} catch (err) {
|
|
39
|
+
_iterator.e(err);
|
|
40
|
+
} finally {
|
|
41
|
+
_iterator.f();
|
|
42
|
+
}
|
|
43
|
+
} else {
|
|
44
|
+
throw new Error("参数错误!");
|
|
21
45
|
}
|
|
22
46
|
this.tileset = tileset;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
this._iscutOutter = this.opt.iscutOutter; // 是否为外部裁剪 默认为内部裁剪
|
|
28
|
-
this.cutRegions = []; // 当前裁剪面数组对象
|
|
29
|
-
/* this.modelMatrix = new Matrix4(); // 世界坐标系--》模型坐标系
|
|
30
|
-
Matrix4.inverseTransformation(this.tileset.root.computedTransform, this.modelMatrix) */
|
|
31
|
-
// 建立模型中心点坐标系
|
|
32
|
-
var center = this.tileset.boundingSphere.center;
|
|
33
|
-
var enuMtx4 = _cesium.Transforms.eastNorthUpToFixedFrame(center);
|
|
34
|
-
this.modelMatrix = _cesium.Matrix4.inverse(enuMtx4, new _cesium.Matrix4());
|
|
35
|
-
this.canvas = undefined;
|
|
36
|
-
}
|
|
37
|
-
return _createClass(TilesetCut, [{
|
|
38
|
-
key: "iscutOutter",
|
|
39
|
-
get: function get() {
|
|
40
|
-
return this._iscutOutter;
|
|
41
|
-
},
|
|
42
|
-
set: function set(val) {
|
|
43
|
-
this._iscutOutter = val;
|
|
44
|
-
this.updateShader();
|
|
47
|
+
if (typeof opt.excavate === "boolean") {
|
|
48
|
+
this.excavate = opt.excavate;
|
|
49
|
+
} else {
|
|
50
|
+
this.excavate = false;
|
|
45
51
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
value: function addRegion(attr) {
|
|
56
|
-
var _ref = attr || {},
|
|
57
|
-
positions = _ref.positions,
|
|
58
|
-
id = _ref.id;
|
|
59
|
-
if (!id) id = new Date().getTime() + "" + Number(Math.random() * 1000).toFixed(0);
|
|
60
|
-
if (!positions || positions.length < 3) {
|
|
61
|
-
console.log("缺少裁剪面坐标");
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
var index = this.cutRegions.findIndex(function (item) {
|
|
65
|
-
return item.id === id;
|
|
66
|
-
});
|
|
67
|
-
if (index == -1) {
|
|
68
|
-
this.cutRegions.push({
|
|
69
|
-
id: id,
|
|
70
|
-
positions: positions
|
|
71
|
-
});
|
|
72
|
-
} else {
|
|
73
|
-
this.cutRegions[index].positions = positions;
|
|
74
|
-
}
|
|
75
|
-
this.updateShader();
|
|
52
|
+
this.polygons = opt.polygons;
|
|
53
|
+
this.center = tileset.boundingSphere.center.clone();
|
|
54
|
+
this.matrix = _cesium.Transforms.eastNorthUpToFixedFrame(this.center.clone());
|
|
55
|
+
this.localMatrix = _cesium.Matrix4.inverse(this.matrix, new _cesium.Matrix4());
|
|
56
|
+
this.localPositionsArr = [];
|
|
57
|
+
for (var pp = 0; pp < this.polygons.length; pp++) {
|
|
58
|
+
var positions = this.polygons[pp];
|
|
59
|
+
var localCoor = this.cartesiansToLocal(positions);
|
|
60
|
+
this.localPositionsArr.push(localCoor);
|
|
76
61
|
}
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
var
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
62
|
+
this.initialize();
|
|
63
|
+
}
|
|
64
|
+
return _createClass(Clipping, [{
|
|
65
|
+
key: "initialize",
|
|
66
|
+
value: function initialize() {
|
|
67
|
+
var out_v_str = "";
|
|
68
|
+
var in_v_str = "";
|
|
69
|
+
var temp_str = "";
|
|
70
|
+
for (var m = 0; m < this.localPositionsArr.length; m++) {
|
|
71
|
+
var polygon = this.localPositionsArr[m];
|
|
72
|
+
out_v_str += "vec2 points_".concat(m, "[").concat(polygon.length, "];\n bool isPointInPolygon_").concat(m, "(vec2 point){\n int nCross = 0; // \u4EA4\u70B9\u6570\n const int n = ").concat(polygon.length, ";\n for(int i = 0; i < n; i++){\n vec2 p1 = points_").concat(m, "[i];\n vec2 p2 = points_").concat(m, "[int(mod(float(i+1),float(n)))];\n if(p1[1] == p2[1]){\n continue;\n }\n if(point[1] < min(p1[1], p2[1])){\n continue;\n }\n if(point[1] >= max(p1[1], p2[1])){\n continue;\n }\n float x = p1[0] + ((point[1] - p1[1]) * (p2[0] - p1[0])) / (p2[1] - p1[1]);\n if(x > point[0]){\n nCross++;\n }\n }\n return int(mod(float(nCross), float(2))) == 1;\n }\n\n ");
|
|
73
|
+
for (var n = 0; n < polygon.length; n++) {
|
|
74
|
+
in_v_str += "points_".concat(m, "[").concat(n, "] = vec2(").concat(polygon[n][0], ", ").concat(polygon[n][1], ");\n");
|
|
75
|
+
}
|
|
76
|
+
temp_str += "isPointInPolygon_".concat(m, "(position2D)||");
|
|
77
|
+
}
|
|
78
|
+
temp_str = temp_str.slice(0, -2);
|
|
79
|
+
if (this.excavate == false) {
|
|
80
|
+
in_v_str += "\n if(".concat(temp_str, "){\n }else{\n vsOutput.positionMC *= 0.0;\n }\n ");
|
|
81
|
+
} else if (this.excavate == true) {
|
|
82
|
+
in_v_str += "\n if(".concat(temp_str, "){\n vsOutput.positionMC *= 0.0;\n }\n ");
|
|
93
83
|
}
|
|
94
|
-
this.updateShader();
|
|
84
|
+
this.updateShader(out_v_str, in_v_str);
|
|
95
85
|
}
|
|
96
86
|
|
|
97
87
|
/**
|
|
@@ -102,102 +92,43 @@ var TilesetCut = /*#__PURE__*/function () {
|
|
|
102
92
|
value: function destroy() {
|
|
103
93
|
this.tileset.customShader = undefined;
|
|
104
94
|
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* 修改模型着色器
|
|
108
|
-
*/
|
|
109
95
|
}, {
|
|
110
96
|
key: "updateShader",
|
|
111
|
-
value: function updateShader() {
|
|
112
|
-
var
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
97
|
+
value: function updateShader(vtx1, vtx2) {
|
|
98
|
+
var v_text = "\n // \u6240\u6709isPointInPolygon\u51FD\u6570\n ".concat(vtx1, "\n void vertexMain(VertexInput vsInput, inout czm_modelVertexOutput vsOutput){\n vec3 modelMC = vsInput.attributes.positionMC;\n vec4 model_local_position = vec4(modelMC.x, modelMC.y, modelMC.z, 1.0);\n vec4 tileset_local_position = u_tileset_worldToLocalMatrix * czm_model * model_local_position;\n vec2 position2D = vec2(tileset_local_position.x,tileset_local_position.y);\n // \u591A\u4E2A\u591A\u8FB9\u5F62\u533A\u57DF\n ").concat(vtx2, "\n }");
|
|
99
|
+
var flatCustomShader = new _cesium.CustomShader({
|
|
100
|
+
uniforms: {
|
|
101
|
+
u_tileset_localToWorldMatrix: {
|
|
102
|
+
type: _cesium.UniformType.MAT4,
|
|
103
|
+
value: this.matrix
|
|
104
|
+
},
|
|
105
|
+
u_tileset_worldToLocalMatrix: {
|
|
106
|
+
type: _cesium.UniformType.MAT4,
|
|
107
|
+
value: this.localMatrix
|
|
108
|
+
},
|
|
109
|
+
u_flatHeight: {
|
|
110
|
+
type: _cesium.UniformType.FLOAT,
|
|
111
|
+
value: this.flatHeight
|
|
112
|
+
}
|
|
119
113
|
},
|
|
120
|
-
|
|
121
|
-
type: _cesium.UniformType.BOOL,
|
|
122
|
-
value: this._iscutOutter
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
// 构建多区域着色器
|
|
127
|
-
var fs = "";
|
|
128
|
-
this.cutRegions.forEach(function (element) {
|
|
129
|
-
var uniforms = _this.createUniforms(element.positions, element.id);
|
|
130
|
-
allUniforms = (0, _cesium.combine)(allUniforms, uniforms);
|
|
131
|
-
fs += "\n vec4 color_".concat(element.id, " = textureMapRect(u_rect_").concat(element.id, ", u_map_").concat(element.id, ", xy);\n cutColor *= color_").concat(element.id, ";\n ");
|
|
132
|
-
});
|
|
133
|
-
fs += "\n if (u_unionCutRegions) {\n material.diffuse *= (vec3(1.0) - cutColor.rgb);\n } else {\n material.diffuse *= cutColor.rgb;\n }\n if (material.diffuse.r <= 0.0001 && material.diffuse.g <= 0.0001 && material.diffuse.b <= 0.0001) {\n discard;\n }\n ";
|
|
134
|
-
this.tileset.customShader = new _cesium.CustomShader({
|
|
135
|
-
uniforms: allUniforms,
|
|
136
|
-
fragmentShaderText: "\n ".concat(fs_textureMapRect, "\n void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) {\n vec4 positionMC = u_inverseModel * vec4(fsInput.attributes.positionWC, 1.0);\n vec2 xy = positionMC.xy;\n vec4 cutColor = vec4(1.0);\n ").concat(fs, "\n }")
|
|
114
|
+
vertexShaderText: v_text
|
|
137
115
|
});
|
|
116
|
+
this.tileset.customShader = flatCustomShader;
|
|
138
117
|
}
|
|
139
118
|
|
|
140
|
-
|
|
141
|
-
* 根据坐标创建片元着色器
|
|
142
|
-
* @param {Cartesian3[]} positions
|
|
143
|
-
* @param {String} id
|
|
144
|
-
*/
|
|
119
|
+
// 世界坐标转数组局部坐标
|
|
145
120
|
}, {
|
|
146
|
-
key: "
|
|
147
|
-
value: function
|
|
148
|
-
var
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
id = id || Math.ceil(Math.random() * 100000) + '_' + Math.ceil(Math.random() * 100000);
|
|
154
|
-
// 根据世界坐标范围计算相对模型坐标范围
|
|
155
|
-
var xs = [],
|
|
156
|
-
ys = [],
|
|
157
|
-
zs = [];
|
|
158
|
-
// 计算模型坐标系下坐标
|
|
159
|
-
var modelPoints = positions.map(function (p) {
|
|
160
|
-
var point = _cesium.Matrix4.multiplyByPoint(_this2.modelMatrix, p, new _cesium.Cartesian3());
|
|
161
|
-
xs.push(point.x);
|
|
162
|
-
ys.push(point.y);
|
|
163
|
-
zs.push(point.z);
|
|
164
|
-
return point;
|
|
165
|
-
});
|
|
166
|
-
// 计算当前裁剪面边界范围(模型坐标系下)
|
|
167
|
-
var rect = new _cesium.Cartesian4(Math.min.apply(null, xs), Math.min.apply(null, ys), Math.max.apply(null, xs), Math.max.apply(null, ys));
|
|
168
|
-
var canvas = document.createElement('canvas');
|
|
169
|
-
canvas.width = 1024;
|
|
170
|
-
canvas.height = 1024;
|
|
171
|
-
var width = rect.z - rect.x;
|
|
172
|
-
var height = rect.w - rect.y;
|
|
173
|
-
var ctx = canvas.getContext('2d');
|
|
174
|
-
ctx.fillStyle = '#fff'; // 设置整体背景为白色
|
|
175
|
-
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
|
176
|
-
ctx.beginPath();
|
|
177
|
-
ctx.moveTo(canvas.width * (modelPoints[0].x - rect.x) / width, canvas.height * (modelPoints[0].y - rect.y) / height);
|
|
178
|
-
for (var i = 1; i < modelPoints.length; i++) {
|
|
179
|
-
ctx.lineTo(canvas.width * (modelPoints[i].x - rect.x) / width, canvas.height * (modelPoints[i].y - rect.y) / height);
|
|
121
|
+
key: "cartesiansToLocal",
|
|
122
|
+
value: function cartesiansToLocal(positions) {
|
|
123
|
+
var arr = [];
|
|
124
|
+
for (var i = 0; i < positions.length; i++) {
|
|
125
|
+
var position = positions[i];
|
|
126
|
+
var localp = _cesium.Matrix4.multiplyByPoint(this.localMatrix, position.clone(), new _cesium.Cartesian3());
|
|
127
|
+
arr.push([localp.x, localp.y]);
|
|
180
128
|
}
|
|
181
|
-
|
|
182
|
-
ctx.fillStyle = '#000'; // 根据填充的黑色来裁剪模型
|
|
183
|
-
ctx.fill();
|
|
184
|
-
this.canvas = canvas;
|
|
185
|
-
var uniforms = {};
|
|
186
|
-
uniforms["u_rect_".concat(id)] = {
|
|
187
|
-
type: _cesium.UniformType.VEC4,
|
|
188
|
-
value: rect
|
|
189
|
-
};
|
|
190
|
-
uniforms["u_map_".concat(id)] = {
|
|
191
|
-
type: _cesium.UniformType.SAMPLER_2D,
|
|
192
|
-
value: new _cesium.TextureUniform({
|
|
193
|
-
url: canvas.toDataURL()
|
|
194
|
-
}),
|
|
195
|
-
minificationFilter: _cesium.TextureMinificationFilter.LINEAR,
|
|
196
|
-
magnificationFilter: _cesium.TextureMagnificationFilter.LINEAR
|
|
197
|
-
};
|
|
198
|
-
return uniforms;
|
|
129
|
+
return arr;
|
|
199
130
|
}
|
|
200
131
|
}]);
|
|
201
132
|
}();
|
|
202
|
-
var _default = exports["default"] =
|
|
133
|
+
var _default = exports["default"] = Clipping;
|
|
203
134
|
//# sourceMappingURL=TilesetCut.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TilesetCut.js","names":["_cesium","require","_typeof","o","Symbol","iterator","constructor","prototype","_classCallCheck","instance","Constructor","TypeError","_defineProperties","target","props","i","length","descriptor","enumerable","configurable","writable","Object","defineProperty","_toPropertyKey","key","_createClass","protoProps","staticProps","t","_toPrimitive","r","e","toPrimitive","call","String","Number","TilesetCut","tileset","opt","console","log","_iscutOutter","iscutOutter","cutRegions","center","boundingSphere","enuMtx4","Transforms","eastNorthUpToFixedFrame","modelMatrix","Matrix4","inverse","canvas","undefined","get","set","val","updateShader","value","addRegion","attr","_ref","positions","id","Date","getTime","Math","random","toFixed","index","findIndex","item","push","removeRegionById","splice","destroy","customShader","_this","fs_textureMapRect","allUniforms","u_inverseModel","type","UniformType","MAT4","clone","u_unionCutRegions","BOOL","fs","forEach","element","uniforms","createUniforms","combine","concat","CustomShader","fragmentShaderText","_this2","ceil","xs","ys","zs","modelPoints","map","p","point","multiplyByPoint","Cartesian3","x","y","z","rect","Cartesian4","min","apply","max","document","createElement","width","height","w","ctx","getContext","fillStyle","fillRect","beginPath","moveTo","lineTo","closePath","fill","VEC4","SAMPLER_2D","TextureUniform","url","toDataURL","minificationFilter","TextureMinificationFilter","LINEAR","magnificationFilter","TextureMagnificationFilter","_default","exports"],"sources":["excavation-analysis/TilesetCut.js"],"sourcesContent":["import {\n Matrix4,\n Transforms,\n Cartesian3,\n UniformType,\n combine,\n CustomShader,\n Cartesian4,\n TextureUniform,\n TextureMinificationFilter,\n TextureMagnificationFilter\n} from 'cesium';\n// 三维模型裁剪\nclass TilesetCut {\n constructor(tileset, opt) {\n if (!tileset) {\n console.log(\"缺少模型\");\n return;\n }\n this.tileset = tileset;\n this.opt = opt || {};\n /**\n * @property {Boolean} iscutOutter 是否为外部裁剪,默认为内部裁剪\n */\n this._iscutOutter = this.opt.iscutOutter; // 是否为外部裁剪 默认为内部裁剪\n this.cutRegions = []; // 当前裁剪面数组对象\n /* this.modelMatrix = new Matrix4(); // 世界坐标系--》模型坐标系\n Matrix4.inverseTransformation(this.tileset.root.computedTransform, this.modelMatrix) */\n // 建立模型中心点坐标系\n const center = this.tileset.boundingSphere.center;\n const enuMtx4 = Transforms.eastNorthUpToFixedFrame(center);\n this.modelMatrix = Matrix4.inverse(enuMtx4, new Matrix4());\n this.canvas = undefined;\n }\n\n get iscutOutter() {\n return this._iscutOutter\n }\n\n set iscutOutter(val) {\n this._iscutOutter = val;\n this.updateShader();\n }\n\n /**\n * 添加裁剪面\n * @param {Object} attr 参数\n * @param {Cartesian3[]} attr.positions 压平面坐标\n * @param {Number} attr.id 唯一标识\n */\n addRegion(attr) {\n let { positions, id } = attr || {};\n if (!id) id = (new Date()).getTime() + \"\" + Number(Math.random() * 1000).toFixed(0);\n if (!positions || positions.length < 3) {\n console.log(\"缺少裁剪面坐标\");\n return;\n }\n const index = this.cutRegions.findIndex(item => item.id === id)\n if (index == -1) {\n this.cutRegions.push({\n id: id,\n positions: positions\n })\n } else {\n this.cutRegions[index].positions = positions;\n }\n this.updateShader()\n }\n /**\n * 移除裁剪面\n * @param {String} id\n */\n removeRegionById(id) {\n if (id) { // 表示移除所有的裁剪面\n const index = this.cutRegions.findIndex(item => item.id === id)\n if (index != -1) this.cutRegions.splice(index, 1)\n } else { // 表示移除单个的裁剪面\n this.cutRegions = [];\n }\n this.updateShader();\n }\n\n /**\n * 销毁\n */\n destroy() {\n this.tileset.customShader = undefined;\n }\n\n /**\n * 修改模型着色器\n */\n updateShader() {\n // 定义着色器中裁剪函数\n const fs_textureMapRect = `\n vec4 textureMapRect(vec4 rect, sampler2D map, vec2 xy) {\n // 判断当前图元坐标和多边形关系 如果在多边形内 进行纹素拾取\n if (xy.x >= rect.x && xy.x <= rect.z && xy.y >= rect.y && xy.y <= rect.w) {\n float w = rect.z - rect.x;\n float h = rect.w - rect.y;\n float s = (xy.x - rect.x) / w;\n float t = (xy.y - rect.y) / h;\n vec4 color = texture(map, vec2(s, 1.0 - t));\n return color;\n }\n return vec4(1.0);\n }\n `;\n\n let allUniforms = {\n u_inverseModel: {\n type: UniformType.MAT4,\n value: this.modelMatrix.clone()\n },\n u_unionCutRegions: {\n type: UniformType.BOOL,\n value: this._iscutOutter\n }\n }\n\n // 构建多区域着色器\n let fs = ``;\n this.cutRegions.forEach(element => {\n const uniforms = this.createUniforms(element.positions, element.id)\n allUniforms = combine(allUniforms, uniforms)\n fs += `\n vec4 color_${element.id} = textureMapRect(u_rect_${element.id}, u_map_${element.id}, xy);\n cutColor *= color_${element.id};\n `\n })\n\n fs += `\n if (u_unionCutRegions) {\n material.diffuse *= (vec3(1.0) - cutColor.rgb);\n } else {\n material.diffuse *= cutColor.rgb;\n }\n if (material.diffuse.r <= 0.0001 && material.diffuse.g <= 0.0001 && material.diffuse.b <= 0.0001) {\n discard;\n }\n `;\n\n this.tileset.customShader = new CustomShader({\n uniforms: allUniforms,\n fragmentShaderText: `\n ${fs_textureMapRect}\n void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) {\n vec4 positionMC = u_inverseModel * vec4(fsInput.attributes.positionWC, 1.0);\n vec2 xy = positionMC.xy;\n vec4 cutColor = vec4(1.0);\n ${fs}\n }`\n })\n\n }\n\n /**\n * 根据坐标创建片元着色器\n * @param {Cartesian3[]} positions\n * @param {String} id\n */\n createUniforms(positions, id) {\n if (!positions || positions.length < 3) {\n console.log(\"缺少裁剪面坐标\");\n return;\n }\n id = id || Math.ceil(Math.random() * 100000) + '_' + Math.ceil(Math.random() * 100000)\n // 根据世界坐标范围计算相对模型坐标范围\n const xs = [], ys = [], zs = []\n // 计算模型坐标系下坐标\n const modelPoints = positions.map(p => {\n const point = Matrix4.multiplyByPoint(this.modelMatrix, p, new Cartesian3());\n xs.push(point.x)\n ys.push(point.y)\n zs.push(point.z)\n return point\n })\n // 计算当前裁剪面边界范围(模型坐标系下)\n const rect = new Cartesian4(Math.min.apply(null, xs), Math.min.apply(null, ys), Math.max.apply(null, xs), Math.max.apply(null, ys))\n const canvas = document.createElement('canvas')\n canvas.width = 1024\n canvas.height = 1024\n const width = rect.z - rect.x\n const height = rect.w - rect.y\n const ctx = canvas.getContext('2d')\n ctx.fillStyle = '#fff' // 设置整体背景为白色\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n ctx.beginPath()\n\n ctx.moveTo(canvas.width * (modelPoints[0].x - rect.x) / width, canvas.height * (modelPoints[0].y - rect.y) / height)\n\n for (let i = 1; i < modelPoints.length; i++) {\n ctx.lineTo(canvas.width * (modelPoints[i].x - rect.x) / width, canvas.height * (modelPoints[i].y - rect.y) / height)\n }\n\n ctx.closePath()\n ctx.fillStyle = '#000' // 根据填充的黑色来裁剪模型\n ctx.fill()\n\n this.canvas = canvas;\n\n const uniforms = {}\n uniforms[`u_rect_${id}`] = {\n type: UniformType.VEC4,\n value: rect\n }\n uniforms[`u_map_${id}`] = {\n type: UniformType.SAMPLER_2D,\n value: new TextureUniform({\n url: canvas.toDataURL()\n }),\n minificationFilter: TextureMinificationFilter.LINEAR,\n magnificationFilter: TextureMagnificationFilter.LINEAR\n }\n\n return uniforms\n }\n\n}\n\nexport default TilesetCut\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"TilesetCut.js","names":["_cesium","require","_typeof","o","Symbol","iterator","constructor","prototype","_createForOfIteratorHelper","r","e","t","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","a","u","call","next","_arrayLikeToArray","toString","slice","name","from","test","_classCallCheck","_defineProperties","enumerable","configurable","writable","Object","defineProperty","_toPropertyKey","key","_createClass","i","_toPrimitive","toPrimitive","String","Number","Clipping","tileset","opt","Error","console","log","polygons","_iterator","_step","polygon","err","excavate","center","boundingSphere","clone","matrix","Transforms","eastNorthUpToFixedFrame","localMatrix","Matrix4","inverse","localPositionsArr","pp","positions","localCoor","cartesiansToLocal","push","initialize","out_v_str","in_v_str","temp_str","m","concat","updateShader","destroy","customShader","undefined","vtx1","vtx2","v_text","flatCustomShader","CustomShader","uniforms","u_tileset_localToWorldMatrix","type","UniformType","MAT4","u_tileset_worldToLocalMatrix","u_flatHeight","FLOAT","flatHeight","vertexShaderText","arr","position","localp","multiplyByPoint","Cartesian3","x","y","_default","exports"],"sources":["excavation-analysis/TilesetCut.js"],"sourcesContent":["import {\n Transforms,\n Matrix4,\n CustomShader,\n UniformType,\n Cartesian3\n} from \"cesium\";\n/**\n * @class\n * @description 3dtiles 模型按照(经纬度二维)范围裁剪\n */\nclass Clipping {\n constructor(tileset, opt) {\n if (!tileset) {\n throw new Error(\"参数错误!\")\n }\n\n console.log(\"polygons:\", opt.polygons);\n if (opt.polygons && opt.polygons instanceof Array && opt.polygons.length > 0) {\n for (let polygon of opt.polygons) {\n if (!(polygon instanceof Array && polygon.length >= 3)) {\n throw new Error(\"参数错误!\")\n }\n }\n } else {\n throw new Error(\"参数错误!\")\n }\n\n this.tileset = tileset;\n if (typeof opt.excavate === \"boolean\") {\n this.excavate = opt.excavate\n } else {\n this.excavate = false;\n }\n this.polygons = opt.polygons;\n\n this.center = tileset.boundingSphere.center.clone();\n this.matrix = Transforms.eastNorthUpToFixedFrame(this.center.clone());\n this.localMatrix = Matrix4.inverse(this.matrix, new Matrix4());\n\n this.localPositionsArr = [];\n for (let pp = 0; pp < this.polygons.length; pp++) {\n let positions = this.polygons[pp];\n let localCoor = this.cartesiansToLocal(positions);\n this.localPositionsArr.push(localCoor);\n }\n\n this.initialize();\n }\n\n\n initialize() {\n let out_v_str = ``;\n let in_v_str = ``;\n let temp_str = ``;\n for (let m = 0; m < this.localPositionsArr.length; m++) {\n\n let polygon = this.localPositionsArr[m];\n out_v_str +=\n `vec2 points_${m}[${polygon.length}];\n bool isPointInPolygon_${m}(vec2 point){\n int nCross = 0; // 交点数\n const int n = ${polygon.length};\n for(int i = 0; i < n; i++){\n vec2 p1 = points_${m}[i];\n vec2 p2 = points_${m}[int(mod(float(i+1),float(n)))];\n if(p1[1] == p2[1]){\n continue;\n }\n if(point[1] < min(p1[1], p2[1])){\n continue;\n }\n if(point[1] >= max(p1[1], p2[1])){\n continue;\n }\n float x = p1[0] + ((point[1] - p1[1]) * (p2[0] - p1[0])) / (p2[1] - p1[1]);\n if(x > point[0]){\n nCross++;\n }\n }\n return int(mod(float(nCross), float(2))) == 1;\n }\\n\n `\n\n for (let n = 0; n < polygon.length; n++) {\n in_v_str += `points_${m}[${n}] = vec2(${polygon[n][0]}, ${polygon[n][1]});\\n`;\n }\n temp_str += `isPointInPolygon_${m}(position2D)||`\n }\n\n temp_str = temp_str.slice(0, -2);\n\n if (this.excavate == false) {\n in_v_str +=\n `\n if(${temp_str}){\n }else{\n vsOutput.positionMC *= 0.0;\n }\n `\n } else if (this.excavate == true) {\n in_v_str +=\n `\n if(${temp_str}){\n vsOutput.positionMC *= 0.0;\n }\n `\n }\n\n this.updateShader(out_v_str, in_v_str);\n }\n\n /**\n * 销毁\n */\n destroy() {\n this.tileset.customShader = undefined;\n }\n\n updateShader(vtx1, vtx2) {\n let v_text = `\n // 所有isPointInPolygon函数\n ${vtx1}\n void vertexMain(VertexInput vsInput, inout czm_modelVertexOutput vsOutput){\n vec3 modelMC = vsInput.attributes.positionMC;\n vec4 model_local_position = vec4(modelMC.x, modelMC.y, modelMC.z, 1.0);\n vec4 tileset_local_position = u_tileset_worldToLocalMatrix * czm_model * model_local_position;\n vec2 position2D = vec2(tileset_local_position.x,tileset_local_position.y);\n // 多个多边形区域\n ${vtx2}\n }`;\n let flatCustomShader = new CustomShader({\n uniforms: {\n u_tileset_localToWorldMatrix: {\n type: UniformType.MAT4,\n value: this.matrix,\n },\n u_tileset_worldToLocalMatrix: {\n type: UniformType.MAT4,\n value: this.localMatrix,\n },\n u_flatHeight: {\n type: UniformType.FLOAT,\n value: this.flatHeight,\n },\n },\n vertexShaderText: v_text,\n });\n this.tileset.customShader = flatCustomShader;\n }\n\n // 世界坐标转数组局部坐标\n cartesiansToLocal(positions) {\n let arr = [];\n for (let i = 0; i < positions.length; i++) {\n let position = positions[i];\n let localp = Matrix4.multiplyByPoint(\n this.localMatrix,\n position.clone(),\n new Cartesian3()\n )\n arr.push([localp.x, localp.y]);\n }\n return arr;\n }\n}\n\nexport default Clipping;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -8,7 +8,7 @@ var _react = require("react");
|
|
|
8
8
|
var _cesium = require("../../_util/cesium");
|
|
9
9
|
var _cesium2 = require("cesium");
|
|
10
10
|
var _TilesetCut = _interopRequireDefault(require("../TilesetCut"));
|
|
11
|
-
function _interopRequireDefault(
|
|
11
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
12
12
|
var DrawHandler = function DrawHandler(props) {
|
|
13
13
|
var viewer = props.viewer,
|
|
14
14
|
type = props.type,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useDrawHandler.js","names":["_react","require","_cesium","_cesium2","_TilesetCut","_interopRequireDefault","obj","__esModule","DrawHandler","props","viewer","type","sceneId","viewerObj","useRef","drawLayer","listnerEvent","drawStart","drawEnd","cutToolRef","current","initDrawHandler","cesiumWidget","screenSpaceEventHandler","removeInputAction","ScreenSpaceEventType","LEFT_DOUBLE_CLICK","CustomDataSource","dataSources","add","activate","draw","drawPolygon","clampToGround","handler","ScreenSpaceEventHandler","scene","canvas","positions","polygon","PolygonHierarchy","polyObj","setInputAction","ev","cartesian","getCartesian3FromXY","position","x","length","push","clone","_createPolygonEntity","createPolygonEntity","entity","LEFT_CLICK","catesian","endPosition","pop","MOUSE_MOVE","destroy","forEach","fuc","RIGHT_CLICK","_drawLayer$current","polygonEntity","Entity","polyline","CallbackProperty","width","material","Color","hierarchy","WHITE","withAlpha","heightReference","HeightReference","CLAMP_TO_GROUND","entities","on","callBack","clear","removeAll","useEffect","console","warn","_default","exports"],"sources":["excavation-analysis/hooks/useDrawHandler.js"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getCartesian3FromXY } from '../../_util/cesium';\nimport {\n ScreenSpaceEventType,\n CustomDataSource,\n ScreenSpaceEventHandler,\n PolygonHierarchy,\n Entity,\n CallbackProperty,\n Color,\n HeightReference\n} from 'cesium';\nimport TilesetCut from '../TilesetCut';\n\n\nconst DrawHandler = (props) => {\n const { viewer, type, sceneId } = props;\n const viewerObj = useRef()\n const drawLayer = useRef(null)\n const listnerEvent = useRef({\n drawStart: [],\n drawEnd: []\n })\n const cutToolRef = useRef();\n if (viewer) viewerObj.current = viewer\n\n // 初始化绘图控件\n const initDrawHandler = (viewer) => {\n // 取消双击事件-追踪该位置\n viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(ScreenSpaceEventType.LEFT_DOUBLE_CLICK)\n drawLayer.current = new CustomDataSource('measureLayer')\n viewer.dataSources.add(drawLayer.current)\n }\n\n const activate = () => {\n if (type) {\n draw(type)\n }\n }\n\n // 绘制多边形\n const drawPolygon = (clampToGround) => {\n if (!viewer) return\n const handler = new ScreenSpaceEventHandler(viewer.scene.canvas)\n const positions = []\n const polygon = new PolygonHierarchy()\n let polyObj = null\n\n handler.setInputAction((ev) => {\n const cartesian = getCartesian3FromXY(viewer, ev.position)\n if (cartesian && cartesian.x) {\n if (positions.length === 0) {\n polygon.positions.push(cartesian.clone())\n positions.push(cartesian.clone())\n }\n positions.push(cartesian.clone())\n polygon.positions.push(cartesian.clone())\n if(!polyObj) {\n const { entity } = createPolygonEntity(positions, polygon, clampToGround)\n polyObj = entity\n }\n }\n }, ScreenSpaceEventType.LEFT_CLICK)\n\n handler.setInputAction((ev) => {\n const catesian = getCartesian3FromXY(viewer, ev.endPosition)\n if (positions.length >= 2) {\n if (catesian && catesian.x) {\n positions.pop()\n positions.push(catesian)\n polygon.positions.pop()\n polygon.positions.push(catesian)\n }\n }\n }, ScreenSpaceEventType.MOUSE_MOVE)\n\n handler.setInputAction(() => {\n handler.destroy()\n positions.push(positions[0])\n // 执行绘制生命周期函数\n if (listnerEvent.current.drawEnd.length) {\n listnerEvent.current.drawEnd.forEach(fuc => {\n fuc(positions)\n })\n }\n }, ScreenSpaceEventType.RIGHT_CLICK)\n }\n\n // 创建多边形\n const createPolygonEntity = (positions, polygon, clampToGround) => {\n const polygonEntity = new Entity({\n polyline: {\n positions: new CallbackProperty(() => {\n return positions\n }, false),\n width: 3,\n material: new Color(0, 255, 255, 0.5),\n clampToGround: clampToGround\n },\n polygon: {\n hierarchy: new CallbackProperty(() => {\n return polygon\n }, false),\n material: Color.WHITE.withAlpha(0.1),\n heightReference: HeightReference.CLAMP_TO_GROUND\n }\n })\n const entity = drawLayer.current?.entities.add(polygonEntity)\n return {\n polygonEntity,\n entity\n }\n }\n\n const draw = (type) => {\n switch(type) {\n case 'polygon':\n drawPolygon(true)\n break\n }\n }\n\n const on = (type, callBack) => {\n listnerEvent.current[type].push(callBack)\n }\n\n const clear = () => {\n if (drawLayer.current) {\n drawLayer.current.entities.removeAll()\n }\n }\n\n useEffect(() => {\n if (viewer && type) {\n initDrawHandler(viewer, type)\n } else {\n console.warn('请使用 initDrawHandler 函数初始化绘图控件')\n }\n return () => {\n clear()\n }\n }, [])\n\n return { activate, on, clear }\n}\n\nexport default DrawHandler;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"useDrawHandler.js","names":["_react","require","_cesium","_cesium2","_TilesetCut","_interopRequireDefault","e","__esModule","DrawHandler","props","viewer","type","sceneId","viewerObj","useRef","drawLayer","listnerEvent","drawStart","drawEnd","cutToolRef","current","initDrawHandler","cesiumWidget","screenSpaceEventHandler","removeInputAction","ScreenSpaceEventType","LEFT_DOUBLE_CLICK","CustomDataSource","dataSources","add","activate","draw","drawPolygon","clampToGround","handler","ScreenSpaceEventHandler","scene","canvas","positions","polygon","PolygonHierarchy","polyObj","setInputAction","ev","cartesian","getCartesian3FromXY","position","x","length","push","clone","_createPolygonEntity","createPolygonEntity","entity","LEFT_CLICK","catesian","endPosition","pop","MOUSE_MOVE","destroy","forEach","fuc","RIGHT_CLICK","_drawLayer$current","polygonEntity","Entity","polyline","CallbackProperty","width","material","Color","hierarchy","WHITE","withAlpha","heightReference","HeightReference","CLAMP_TO_GROUND","entities","on","callBack","clear","removeAll","useEffect","console","warn","_default","exports"],"sources":["excavation-analysis/hooks/useDrawHandler.js"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getCartesian3FromXY } from '../../_util/cesium';\nimport {\n ScreenSpaceEventType,\n CustomDataSource,\n ScreenSpaceEventHandler,\n PolygonHierarchy,\n Entity,\n CallbackProperty,\n Color,\n HeightReference\n} from 'cesium';\nimport TilesetCut from '../TilesetCut';\n\n\nconst DrawHandler = (props) => {\n const { viewer, type, sceneId } = props;\n const viewerObj = useRef()\n const drawLayer = useRef(null)\n const listnerEvent = useRef({\n drawStart: [],\n drawEnd: []\n })\n const cutToolRef = useRef();\n if (viewer) viewerObj.current = viewer\n\n // 初始化绘图控件\n const initDrawHandler = (viewer) => {\n // 取消双击事件-追踪该位置\n viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(ScreenSpaceEventType.LEFT_DOUBLE_CLICK)\n drawLayer.current = new CustomDataSource('measureLayer')\n viewer.dataSources.add(drawLayer.current)\n }\n\n const activate = () => {\n if (type) {\n draw(type)\n }\n }\n\n // 绘制多边形\n const drawPolygon = (clampToGround) => {\n if (!viewer) return\n const handler = new ScreenSpaceEventHandler(viewer.scene.canvas)\n const positions = []\n const polygon = new PolygonHierarchy()\n let polyObj = null\n\n handler.setInputAction((ev) => {\n const cartesian = getCartesian3FromXY(viewer, ev.position)\n if (cartesian && cartesian.x) {\n if (positions.length === 0) {\n polygon.positions.push(cartesian.clone())\n positions.push(cartesian.clone())\n }\n positions.push(cartesian.clone())\n polygon.positions.push(cartesian.clone())\n if(!polyObj) {\n const { entity } = createPolygonEntity(positions, polygon, clampToGround)\n polyObj = entity\n }\n }\n }, ScreenSpaceEventType.LEFT_CLICK)\n\n handler.setInputAction((ev) => {\n const catesian = getCartesian3FromXY(viewer, ev.endPosition)\n if (positions.length >= 2) {\n if (catesian && catesian.x) {\n positions.pop()\n positions.push(catesian)\n polygon.positions.pop()\n polygon.positions.push(catesian)\n }\n }\n }, ScreenSpaceEventType.MOUSE_MOVE)\n\n handler.setInputAction(() => {\n handler.destroy()\n positions.push(positions[0])\n // 执行绘制生命周期函数\n if (listnerEvent.current.drawEnd.length) {\n listnerEvent.current.drawEnd.forEach(fuc => {\n fuc(positions)\n })\n }\n }, ScreenSpaceEventType.RIGHT_CLICK)\n }\n\n // 创建多边形\n const createPolygonEntity = (positions, polygon, clampToGround) => {\n const polygonEntity = new Entity({\n polyline: {\n positions: new CallbackProperty(() => {\n return positions\n }, false),\n width: 3,\n material: new Color(0, 255, 255, 0.5),\n clampToGround: clampToGround\n },\n polygon: {\n hierarchy: new CallbackProperty(() => {\n return polygon\n }, false),\n material: Color.WHITE.withAlpha(0.1),\n heightReference: HeightReference.CLAMP_TO_GROUND\n }\n })\n const entity = drawLayer.current?.entities.add(polygonEntity)\n return {\n polygonEntity,\n entity\n }\n }\n\n const draw = (type) => {\n switch(type) {\n case 'polygon':\n drawPolygon(true)\n break\n }\n }\n\n const on = (type, callBack) => {\n listnerEvent.current[type].push(callBack)\n }\n\n const clear = () => {\n if (drawLayer.current) {\n drawLayer.current.entities.removeAll()\n }\n }\n\n useEffect(() => {\n if (viewer && type) {\n initDrawHandler(viewer, type)\n } else {\n console.warn('请使用 initDrawHandler 函数初始化绘图控件')\n }\n return () => {\n clear()\n }\n }, [])\n\n return { activate, on, clear }\n}\n\nexport default DrawHandler;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -67,14 +67,20 @@ var useTerrainClipPlan = function useTerrainClipPlan(props) {
|
|
|
67
67
|
var createWell = function createWell(data) {
|
|
68
68
|
if (viewer.terrainProvider._layers) {
|
|
69
69
|
createBottomSurface(data.bottom_pos);
|
|
70
|
-
|
|
70
|
+
var handleData = function handleData(arr) {
|
|
71
71
|
var no_height_top = [];
|
|
72
72
|
for (var i = 0; i < arr.length; i++) {
|
|
73
73
|
var s = _cesium.Cartesian3.fromRadians(arr[i].longitude, arr[i].latitude, arr[i].height);
|
|
74
74
|
no_height_top.push(s);
|
|
75
75
|
}
|
|
76
76
|
createWellWall(data.bottom_pos, no_height_top);
|
|
77
|
-
}
|
|
77
|
+
};
|
|
78
|
+
// 针对低于 1.90.0 版本
|
|
79
|
+
if (_cesium.when) {
|
|
80
|
+
(0, _cesium.when)((0, _cesium.sampleTerrainMostDetailed)(viewer.terrainProvider, data.lerp_pos), handleData);
|
|
81
|
+
} else {
|
|
82
|
+
(0, _cesium.sampleTerrainMostDetailed)(viewer.terrainProvider, data.lerp_pos).then(handleData);
|
|
83
|
+
}
|
|
78
84
|
} else {
|
|
79
85
|
createBottomSurface(data.bottom_pos);
|
|
80
86
|
createWellWall(data.bottom_pos, data.no_height_top);
|
|
@@ -248,6 +254,7 @@ var useTerrainClipPlan = function useTerrainClipPlan(props) {
|
|
|
248
254
|
var len = points.length;
|
|
249
255
|
if (len !== 0) {
|
|
250
256
|
var no_height_top = [];
|
|
257
|
+
var height_top = [];
|
|
251
258
|
var bottom_pos = [];
|
|
252
259
|
var lerp_pos = [];
|
|
253
260
|
var diff = excavateMinHeight.current - heightNum.current;
|
|
@@ -261,6 +268,7 @@ var useTerrainClipPlan = function useTerrainClipPlan(props) {
|
|
|
261
268
|
lerp_pos.push(new _cesium.Cartographic(currLonLat[0], currLonLat[1]));
|
|
262
269
|
bottom_pos.push(_cesium.Cartesian3.fromRadians(currLonLat[0], currLonLat[1], diff));
|
|
263
270
|
no_height_top.push(_cesium.Cartesian3.fromRadians(currLonLat[0], currLonLat[1], 0));
|
|
271
|
+
height_top.push(_cesium.Cartesian3.fromRadians(currLonLat[0], currLonLat[1], nextCartorghic.height));
|
|
264
272
|
}
|
|
265
273
|
if (!splitNumber.current) return;
|
|
266
274
|
for (var p = 1; p <= splitNumber.current; p++) {
|
|
@@ -270,13 +278,15 @@ var useTerrainClipPlan = function useTerrainClipPlan(props) {
|
|
|
270
278
|
lerp_pos.push(new _cesium.Cartographic(firstLerp, lastLerp));
|
|
271
279
|
bottom_pos.push(_cesium.Cartesian3.fromRadians(firstLerp, lastLerp, diff));
|
|
272
280
|
no_height_top.push(_cesium.Cartesian3.fromRadians(firstLerp, lastLerp, 0));
|
|
281
|
+
height_top.push(_cesium.Cartesian3.fromRadians(firstLerp, lastLerp, nextCartorghic.height));
|
|
273
282
|
}
|
|
274
283
|
}
|
|
275
284
|
}
|
|
276
285
|
wellData.current = {
|
|
277
286
|
lerp_pos: lerp_pos,
|
|
278
287
|
bottom_pos: bottom_pos,
|
|
279
|
-
no_height_top: no_height_top
|
|
288
|
+
no_height_top: no_height_top,
|
|
289
|
+
height_top: height_top
|
|
280
290
|
};
|
|
281
291
|
}
|
|
282
292
|
};
|