Prechádzať zdrojové kódy

综合业务左侧图表修改

WQQ 2 týždňov pred
rodič
commit
bf97e6e5a4

BIN
src/assets/images/孔港联圩.png


BIN
src/assets/images/孔港联圩水文站.png


BIN
src/assets/images/孔港联圩泵站.png


BIN
src/assets/images/孔港联圩泵站水文站.png


+ 42 - 9
src/views/map/index.vue

@@ -18,6 +18,15 @@
             <div class="polder-popup-item"><span class="label">开泵流量:</span><span class="value">12.8 m³/s</span></div>
           </div>
         </div>
+        <div class="business-marker-btn zhangdong" @mouseenter="showPolderInfo('zhangdong')" @mouseleave="hidePolderInfo">
+          <div class="polder-popup" v-if="state.hoverPolder === 'zhangdong'">
+            <div class="polder-popup-title">张东联圩</div>
+            <div class="polder-popup-item"><span class="label">圩内水位:</span><span class="value">2.65m</span></div>
+            <div class="polder-popup-item"><span class="label">圩外水位:</span><span class="value">3.05m</span></div>
+            <div class="polder-popup-item"><span class="label">开闸流量:</span><span class="value">0.4 m³/s</span></div>
+            <div class="polder-popup-item"><span class="label">开泵流量:</span><span class="value">10.5 m³/s</span></div>
+          </div>
+        </div>
         <div class="business-marker-btn konggang" @click="selectPolderDetail('konggang')" @mouseenter="showPolderInfo('konggang')" @mouseleave="hidePolderInfo">
           <div class="polder-popup polder-popup-left" v-if="state.hoverPolder === 'konggang'">
             <div class="polder-popup-title">孔港联圩</div>
@@ -30,14 +39,14 @@
       </template>
       <!-- 孔港联圩详情 -->
       <template v-if="state.selectedPolderDetail === 'konggang'">
-        <img src="@/assets/images/孔港联圩.png" alt="孔港联圩" />
+        <img :src="getKonggangImage()" alt="孔港联圩" />
         <div class="polder-back-btn" @click="backToPolderOverview">
           <span>返回</span>
         </div>
         <!-- 侧边开关控制 -->
         <div class="polder-layer-controls">
           <div class="toggle-item">
-            <span class="toggle-text">闸门</span>
+            <span class="toggle-text">泵站</span>
             <div class="toggle-switch" :class="{ active: state.showGate }" @click="state.showGate = !state.showGate">
               <div class="toggle-knob"></div>
             </div>
@@ -261,7 +270,7 @@ const state = reactive({
   selectedPolderDetail: null,
   // 图层开关状态
   showGate: true,
-  showHydrology: true,
+  showHydrology: false,
   // 当前圩区数据
   currentPolder: {
     name: '张西联圩',
@@ -279,6 +288,13 @@ const state = reactive({
       gateFlow: '0.5 m³/s',
       pumpFlow: '12.8 m³/s'
     },
+    zhangdong: {
+      name: '张东联圩',
+      innerWaterLevel: '2.65m',
+      outerWaterLevel: '3.05m',
+      gateFlow: '0.4 m³/s',
+      pumpFlow: '10.5 m³/s'
+    },
     konggang: {
       name: '孔港联圩',
       innerWaterLevel: '2.58m',
@@ -419,6 +435,22 @@ function hidePolderInfo() {
 
 function selectPolderDetail(polderKey) {
   state.selectedPolderDetail = polderKey
+  if (polderKey === 'konggang') {
+    state.showGate = true
+    state.showHydrology = false
+  }
+}
+
+function getKonggangImage() {
+  if (state.showGate && state.showHydrology) {
+    return new URL("@/assets/images/孔港联圩泵站水文站.png", import.meta.url).href
+  } else if (state.showGate) {
+    return new URL("@/assets/images/孔港联圩泵站.png", import.meta.url).href
+  } else if (state.showHydrology) {
+    return new URL("@/assets/images/孔港联圩水文站.png", import.meta.url).href
+  } else {
+    return new URL("@/assets/images/孔港联圩.png", import.meta.url).href
+  }
 }
 
 function backToPolderOverview() {
@@ -497,7 +529,7 @@ function handleMenuSelect(index) {
     } else if (index === "2") {
       gsap.to(".water-resource-content .module-card", { x: 0, opacity: 1, duration: 0.5, stagger: 0.1 })
     } else if (index === "3") {
-      gsap.to(".water-station-content .stats-card", { x: 0, opacity: 1, duration: 0.5, stagger: 0.1 })
+      gsap.to(".water-station-content .water-station-card", { x: 0, opacity: 1, duration: 0.5, stagger: 0.1 })
     } else if (index === "4") {
       gsap.to(".history-content .event-card", { x: 0, opacity: 1, duration: 0.5 })
       gsap.to(".history-content .timeline-container", { y: 0, opacity: 1, duration: 0.5, delay: 0.2 })
@@ -787,20 +819,21 @@ function handleMapPlayComplete() {
     width: 150px;
     height: 150px;
     background: transparent;
-    border: 3px solid #ff0000;
     cursor: pointer;
     transition: all 0.3s ease;
     z-index: 10;
     
-    &:hover {
-      box-shadow: 0 0 15px rgba(255, 0, 0, 0.8);
-    }
-    
     &.zhangxi {
       left: 40%;
       top: 60%;
       transform: translate(-50%, -50%);
     }
+    
+    &.zhangdong {
+      left: 55%;
+      top: 60%;
+      transform: translate(-50%, -50%);
+    }
      
     &.konggang {
       left: 70%;

+ 106 - 78
src/views/waterStation/index.vue

@@ -1,39 +1,43 @@
 <template>
   <div class="water-station-content">
-    <!-- 左侧统计面板 -->
     <div class="left-panel">
       <div class="left-panel-3d">
-        <div class="stats-card">
-          <div class="stats-title">圩区统计</div>
-          <div class="stats-grid">
-            <div class="stat-item">
-              <div class="stat-value">18</div>
-              <div class="stat-label">骨干河道</div>
+        <m-card title="圩区统计" class="water-station-card" :width="398" :height="450">
+          <div class="stats-panel">
+            <div class="core-indicator">
+              <div class="indicator-main">
+                <span class="main-value">94</span>
+                <span class="main-unit">个</span>
+              </div>
+              <div class="indicator-label">圩区总数</div>
             </div>
-            <div class="stat-item">
-              <div class="stat-value">94</div>
-              <div class="stat-label">圩区总数</div>
-            </div>
-            <div class="stat-item">
-              <div class="stat-value">618</div>
-              <div class="stat-label">防洪闸</div>
-            </div>
-            <div class="stat-item">
-              <div class="stat-value">560</div>
-              <div class="stat-label">排涝站</div>
-            </div>
-            <div class="stat-item">
-              <div class="stat-value">2173.69<span class="stat-unit">m³/s</span></div>
-              <div class="stat-label">排涝流量</div>
+            <div class="stats-grid">
+              <div class="stat-item">
+                <div class="stat-value">18</div>
+                <div class="stat-label">骨干河道</div>
+              </div>
+              <div class="stat-item">
+                <div class="stat-value">618</div>
+                <div class="stat-label">防洪闸</div>
+              </div>
+              <div class="stat-item">
+                <div class="stat-value">560</div>
+                <div class="stat-label">排涝站</div>
+              </div>
+              <div class="stat-item">
+                <div class="stat-value">2173.69<span class="stat-unit">m³/s</span></div>
+                <div class="stat-label">排涝流量</div>
+              </div>
             </div>
           </div>
-        </div>
+        </m-card>
       </div>
     </div>
   </div>
 </template>
 
 <script setup>
+import mCard from "@/components/mCard/index.vue"
 </script>
 
 <style lang="scss">
@@ -71,66 +75,90 @@
   z-index: 4;
 }
 
-.stats-card {
-  height: 450px;
-  background: rgba(0, 20, 40, 0.8);
-  border: 1px solid rgba(48, 220, 255, 0.3);
-  border-radius: 10px;
-  box-shadow: 0 0 20px rgba(48, 220, 255, 0.1);
-  padding: 20px;
-  pointer-events: auto;
+.water-station-card {
   transform: translateX(-150%);
   opacity: 0;
+}
+
+.stats-panel {
+  padding: 12px;
+  height: 100%;
+  display: flex;
+  flex-direction: column;
+  gap: 12px;
+  box-sizing: border-box;
+}
+
+.core-indicator {
+  text-align: center;
+  padding: 12px;
+  background: linear-gradient(135deg, rgba(48, 220, 255, 0.1) 0%, rgba(0, 191, 255, 0.05) 100%);
+  border-radius: 8px;
+  border: 1px solid rgba(48, 220, 255, 0.3);
+}
+
+.indicator-main {
+  margin-bottom: 5px;
+}
+
+.main-value {
+  font-size: 40px;
+  font-weight: 700;
+  color: #30DCFF;
+  font-family: "D-DIN";
+  text-shadow: 0 0 20px rgba(48, 220, 255, 0.5);
+}
+
+.main-unit {
+  font-size: 20px;
+  color: rgba(48, 220, 255, 0.8);
+  font-weight: 600;
+}
+
+.indicator-label {
+  color: rgba(255, 255, 255, 0.8);
+  font-size: 12px;
+  letter-spacing: 1px;
+}
+
+.stats-grid {
+  display: grid;
+  grid-template-columns: repeat(2, 1fr);
+  gap: 10px;
+}
+
+.stat-item {
+  background: rgba(0, 180, 255, 0.08);
+  border: 1px solid rgba(0, 180, 255, 0.2);
+  border-radius: 8px;
+  padding: 15px 10px;
+  text-align: center;
+  transition: all 0.3s ease;
   
-  .stats-title {
-    font-size: 20px;
-    font-weight: bold;
-    color: #30dcff;
-    text-align: center;
-    margin-bottom: 20px;
-    padding-bottom: 15px;
-    border-bottom: 1px solid rgba(48, 220, 255, 0.3);
-    letter-spacing: 4px;
-  }
-  
-  .stats-grid {
-    display: flex;
-    flex-direction: column;
-    gap: 15px;
+  &:hover {
+    background: rgba(0, 180, 255, 0.15);
+    border-color: rgba(48, 220, 255, 0.5);
   }
+}
+
+.stat-value {
+  font-size: 24px;
+  font-weight: 700;
+  color: #30DCFF;
+  font-family: "D-DIN";
+  margin-bottom: 5px;
+  text-shadow: 0 0 10px rgba(48, 220, 255, 0.5);
   
-  .stat-item {
-    display: flex;
-    justify-content: space-between;
-    align-items: center;
-    padding: 15px 20px;
-    background: rgba(48, 220, 255, 0.05);
-    border: 1px solid rgba(48, 220, 255, 0.15);
-    border-radius: 8px;
-    transition: all 0.3s ease;
-    
-    &:hover {
-      background: rgba(48, 220, 255, 0.1);
-      border-color: rgba(48, 220, 255, 0.3);
-    }
-    
-    .stat-value {
-      font-size: 28px;
-      font-weight: bold;
-      color: #30dcff;
-      text-shadow: 0 0 10px rgba(48, 220, 255, 0.5);
-      
-      .stat-unit {
-        font-size: 14px;
-        margin-left: 4px;
-        opacity: 0.8;
-      }
-    }
-    
-    .stat-label {
-      font-size: 15px;
-      color: #a3dcde;
-    }
+  .stat-unit {
+    font-size: 12px;
+    margin-left: 2px;
+    opacity: 0.8;
   }
 }
+
+.stat-label {
+  font-size: 12px;
+  color: rgba(255, 255, 255, 0.7);
+  letter-spacing: 1px;
+}
 </style>