From 6f7bbdd390abdcdb2cdaef980bc69816a3ff2202 Mon Sep 17 00:00:00 2001 From: riku <risaku@163.com> Date: 星期四, 08 五月 2025 17:38:43 +0800 Subject: [PATCH] 添加动态污染溯源相关逻辑(待完成) --- src/views/historymode/HistoryMode.vue | 44 ++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 40 insertions(+), 4 deletions(-) diff --git a/src/views/historymode/HistoryMode.vue b/src/views/historymode/HistoryMode.vue index 9f9c573..1772dfd 100644 --- a/src/views/historymode/HistoryMode.vue +++ b/src/views/historymode/HistoryMode.vue @@ -8,6 +8,13 @@ @search="onSearch" ></SearchBar> <TrajectoryState v-show="status != 0" :status="status"></TrajectoryState> + <el-button + type="primary" + class="p-events-auto el-button-custom" + @click="handleClick" + > + 鍒嗘瀽 + </el-button> </el-row> <el-row class="m-t-2"> <FactorRadio @@ -19,6 +26,7 @@ <FactorLegend class="m-t-2" :factor="factorDatas.factor[factorType]" + @change="handleLegendTypeChange" ></FactorLegend> </el-row> <el-row class="historical" justify="center"> @@ -49,6 +57,7 @@ <script> import Layer from '@/utils/map/3dLayer'; +import mapLine from '@/utils/map/line'; import marks from '@/utils/map/marks'; import sector from '@/utils/map/sector'; import mapUtil from '@/utils/map/util'; @@ -62,6 +71,7 @@ import DataSheet from './component/DataSheet.vue'; import { ElMessage } from 'element-plus'; import { fetchHistoryData } from '@/utils/factor/data'; +import dataAnalysisApi from '@/api/dataAnalysisApi'; import { mapStores } from 'pinia'; import { useSceneStore } from '@/stores/scene'; @@ -79,7 +89,7 @@ // 鐩戞祴璁惧缂栧彿 deviceCode: '', // 鐩戞祴鍥犲瓙鐨勭被鍨嬬紪鍙� - factorType: defaultOptions(TYPE0), + factorType: defaultOptions(TYPE0).value, // 鐩戞祴鏁版嵁 factorDatas: new FactorDatas(), // 鍐冲畾缁樺埗3D鍥惧舰鏃舵槸鍚︿笌鍘熷浘鍍忓悎骞� @@ -133,19 +143,31 @@ this.sceneStore.searchScene(lng, lat); } }, + handleLegendTypeChange(value, done) { + if (value) { + this.factorDatas.resetRange(); + } else { + this.factorDatas.standardRange(); + } + done(); + this.draw(); + }, draw() { // 鍒锋柊鍥句緥 const factor = this.factorDatas.factor[this.factorType]; sector.clearSector(); + // this.drawRoadLine(factor); this.drawRoadMap(factor); this.drawMassMarks(factor); }, // 缁樺埗3D璧拌璺嚎鍥� drawRoadMap(e) { this.factorDatas.refreshHeight(this.factorType); - Layer.drawRoadMap(this.factorDatas, e, this.merge, this.setCenter); - // } + }, + drawRoadLine(e) { + this.factorDatas.refreshHeight(this.factorType); + mapLine.drawLine(this.factorDatas, e); }, drawMassMarks(e) { marks.drawMassMarks(this.factorDatas, e, (index) => { @@ -182,9 +204,10 @@ }); }, onSearch(option) { - const { deviceType, deviceCode, timeArray } = option; + const { deviceType, deviceCode, timeArray, mission } = option; this.deviceType = deviceType; this.deviceCode = deviceCode; + this.mission = mission; let startTime, endTime; if (timeArray && timeArray.length == 2) { startTime = moment(timeArray[0]).format('YYYY-MM-DD HH:mm:ss'); @@ -200,6 +223,19 @@ perPage: pageSize }).then((res) => this.onFetchData(deviceType, res.data)); }); + }, + handleClick() { + const { missionCode } = this.mission; + dataAnalysisApi.pollutionTrace(missionCode).then((res) => { + res.data.forEach((e) => { + const fDatas = new FactorDatas(); + fDatas.setData(e.dataVoList, this.drawMode, () => { + fDatas.refreshHeight(this.factorType); + Layer.drawHighLight3DLayer(fDatas, fDatas.factor[this.factorType]); + console.log(e.dataVoList); + }); + }); + }); } }, mounted() { -- Gitblit v1.9.3