From bb39cbe30cf530a7554c5813e21ffaba9307a035 Mon Sep 17 00:00:00 2001
From: TreeWish <1131093754@qq.com>
Date: 星期五, 24 二月 2023 15:39:29 +0800
Subject: [PATCH] 修改部分图表显示效果

---
 src/components/Screen/bottom.vue        |   10 +
 src/assets/img/Screen/fileTypeBar.png   |    0 
 src/components/Screen/top.vue           |    5 
 src/components/chart/FileFormat.vue     |    6 
 src/views/Thematic/index.vue            |    1 
 src/components/chart/DataStorage.vue    |   69 ++++++++-----
 src/components/Screen/left.vue          |   10 +-
 src/components/Screen/right.vue         |  133 +++++++++++++++++++++++--
 src/components/chart/CountDataApply.vue |    9 +
 9 files changed, 188 insertions(+), 55 deletions(-)

diff --git a/src/assets/img/Screen/fileTypeBar.png b/src/assets/img/Screen/fileTypeBar.png
new file mode 100644
index 0000000..2070eb3
--- /dev/null
+++ b/src/assets/img/Screen/fileTypeBar.png
Binary files differ
diff --git a/src/components/Screen/bottom.vue b/src/components/Screen/bottom.vue
index 4c7faa0..71a50c9 100644
--- a/src/components/Screen/bottom.vue
+++ b/src/components/Screen/bottom.vue
@@ -202,6 +202,9 @@
         case "宸ョ▼灞曠ず":
           this.DisplayCurrentProject(child)
           break
+        case "椤圭洰灞曠ず":
+          this.changeProject(child)
+          break
         default:
           break
       }
@@ -285,7 +288,7 @@
             wkt: item.st_astext,
           }
         })
-        console.log(menu.children.length)
+    
       }
     },
     async getCountProjectTour() {
@@ -299,9 +302,12 @@
             wkt: item.wkt,
           }
         })
-        console.log(menu.children.length)
+      
       }
     },
+    changeProject(params) {
+      this.$bus.$emit('changeProject', params.name)
+    }
   },
 }
 </script>
diff --git a/src/components/Screen/left.vue b/src/components/Screen/left.vue
index cf51f3c..97ee516 100644
--- a/src/components/Screen/left.vue
+++ b/src/components/Screen/left.vue
@@ -3,22 +3,22 @@
     <div class="leftarrow">
       <img :src="leftImg" @click="ChangeLeft" />
     </div>
-    <div class="leftContainer" v-show="ChartDisplay">
-      <div class="current1" id="leftCurrent1">
+    <div class="leftContainer" v-if="ChartDisplay">
+      <div class="current1" style="height: 27%;" id="leftCurrent1">
         <div class="aside-title">鏁版嵁鐢宠娆℃暟</div>
         <count-data-apply ></count-data-apply>
       </div>
-      <div class="current1" id="leftCurrent2">
+      <div class="current1" style="height: 27%;"  id="leftCurrent2">
         <div class="aside-title">鏈嶅姟绫诲埆</div>
 
         <service-type></service-type>
       </div>
-      <div class="current1" id="leftCurrent3">
+      <div class="current1" style="height: 36%;" id="leftCurrent3">
         <div class="aside-title">瀛樺偍淇℃伅</div>
         <data-storage></data-storage>
       </div>
     </div>
-    <div class="leftContainer" v-show="ProjectreeDisplay">
+    <div class="leftContainer" v-if="ProjectreeDisplay">
       <project-tree></project-tree>
     </div>
   </div>
diff --git a/src/components/Screen/right.vue b/src/components/Screen/right.vue
index 090c5f5..5e9e2f5 100644
--- a/src/components/Screen/right.vue
+++ b/src/components/Screen/right.vue
@@ -1,23 +1,42 @@
 <template>
   <div class="current">
-    <div class="rightContainer" v-show="ChartDisplay">
+    <div class="rightContainer" v-if="ChartDisplay">
       <div class="current1">
         <div class="aside-title">宸ョ▼绉嶇被</div>
         <project-category></project-category>
       </div>
-      <!-- <div class="current1">
-        <div class="aside-title">鏁版嵁鍙婃湇鍔℃彁浜�</div>
-        <echart12></echart12>
-      </div> -->
-      <div class="" >
+      <div class="" style="height: 60%">
         <div class="aside-title">鏂囦欢鏍煎紡</div>
-        <div class="content" style="height: 542px">
+        <div class="content" style="height: calc(100% - 30px)">
           <div class="header">
             <div>鏍煎紡</div>
             <div>鏁伴噺</div>
           </div>
           <file-format></file-format>
         </div>
+      </div>
+    </div>
+    <div
+      class="rightContainer2"
+      v-if="CourtyDisplay && currentProject =='鍏ㄧ悆椤圭洰'"
+    >
+      <div class="current1">
+        <div class="aside-title">椤圭洰鏁伴噺鏌辩姸鍥�</div>
+        <country-dimension-bar ref="barRef"></country-dimension-bar>
+      </div>
+      <div class="current1">
+        <div class="aside-title">椤圭洰鏁伴噺楗肩姸鍥�</div>
+        <country-dimension-pie ref="pieRef"></country-dimension-pie>
+      </div>
+    </div>
+    <div class="rightContainer2" v-if="CourtyDisplay && currentProject =='鍏ㄥ浗椤圭洰'">
+      <div class="current1">
+        <div class="aside-title">椤圭洰鏁伴噺鏌辩姸鍥�</div>
+        <province-dimension-bar ref="barRef"></province-dimension-bar>
+      </div>
+      <div class="current1">
+        <div class="aside-title">椤圭洰鏁伴噺楗肩姸鍥�</div>
+        <province-dimension-pie ref="pieRef"></province-dimension-pie>
       </div>
     </div>
     <div class="rightarrow">
@@ -31,6 +50,11 @@
 import echart13 from "@/components/echart13.vue"
 import FileFormat from "@/components/chart/FileFormat.vue"
 import ProjectCategory from "../chart/ProjectCategory.vue"
+import CountryDimensionBar from "../chart/CountryDimensionBar.vue"
+import CountryDimensionPie from "../chart/CountryDimensionPie.vue"
+import ProvinceDimensionBar from "../chart/CountryProvinceBar.vue"
+import ProvinceDimensionPie from "../chart/CountryProvincePie.vue"
+import { countCountryDimension, countProvinceDimension } from "@/api/screen.js"
 
 export default {
   components: {
@@ -38,23 +62,87 @@
     echart12,
     echart13,
     FileFormat,
-    ProjectCategory
+    ProjectCategory,
+    CountryDimensionBar,
+    CountryDimensionPie,
+    ProvinceDimensionBar,
+    ProvinceDimensionPie
   },
   data() {
     return {
       ChartDisplay: true,
+      CourtyDisplay: false,
       RightImg: require("../../assets/img/Screen/leftArrow.png"),
+      leftMessage: "init",
+      currentProject: "鍏ㄧ悆椤圭洰",
+      countryData: [],
+      provinceData: [],
     }
   },
+  created() {
+    // this.getCountryData()
+    // this.getProvinceData()
+  },
+  mounted() {
+    // const countryData = this.countryData
+    // const provinceData = this.provinceData
+
+    // this.$refs.barRef.initChart(countryData)
+    // this.$refs.pieRef.initChart(countryData)
+    this.$bus.$on("changeProject", name => {
+      this.currentProject = name
+    })
+  },
   methods: {
-    ChangeRight() {
-      if (this.ChartDisplay) {
-        this.RightImg = require("../../assets/img/Screen/rightArrow.png")
-      } else {
-        this.RightImg = require("../../assets/img/Screen/leftArrow.png")
+    async getCountryData() {
+      const res = await countCountryDimension()
+      if (res.code == 200) {
+        this.countryData = res.result
       }
+    },
+    async getProvinceData() {
+      const res = await countProvinceDimension()
+      if (res.code == 200) {
+        this.provinceData = res.result
+      }
+    },
+    ChangeRight() {
+      if (this.leftMessage == "init") {
+        if (this.ChartDisplay) {
+          this.RightImg = require("../../assets/img/Screen/rightArrow.png")
+        } else {
+          this.RightImg = require("../../assets/img/Screen/leftArrow.png")
+        }
+        this.ChartDisplay = !this.ChartDisplay
+      }
+
+      if (this.leftMessage == "projectree") {
+        if (this.ProjectreeDisplay) {
+          this.RightImg = require("../../assets/img/Screen/leftArrow.png")
+        } else {
+          this.RightImg = require("../../assets/img/Screen/rightArrow.png")
+        }
+        this.ProjectreeDisplay = !this.ProjectreeDisplay
+      }
+
       this.ChartDisplay = !this.ChartDisplay
       this.$parent.ChangeWidth("right")
+    },
+    //鎵撳紑澶у睆宸︿晶鐣岄潰
+    OpenLeftInit() {
+      this.ChartDisplay = true
+      this.CourtyDisplay = false
+      this.leftMessage = "init"
+      // this.OpenLeftInitChart();
+      this.$parent.ChangeWidth("leftTree")
+    },
+
+    //鎵撳紑宸ョ▼鏍�
+    OpenLeftProjectTree() {
+      this.ChartDisplay = false
+      this.CourtyDisplay = true
+      this.leftMessage = "projectree"
+      this.$parent.ChangeWidth("leftTree")
     },
   },
 }
@@ -88,7 +176,24 @@
     align-items: center;
     justify-content: space-around;
     .current1 {
-      height: 30%;
+      height: 32%;
+      width: 100%;
+      background: url(../../assets/img/Screen/chartbg.png);
+      background-size: 100% 100%;
+      background-repeat: no-repeat;
+    }
+  }
+  .rightContainer2 {
+    height: 100%;
+    width: calc(100% - 7px);
+
+    display: flex;
+    flex-direction: column;
+    align-items: center;
+    .current1 {
+      margin-top: 10px;
+      margin-bottom: 30px;
+      height: 32%;
       width: 100%;
       background: url(../../assets/img/Screen/chartbg.png);
       background-size: 100% 100%;
diff --git a/src/components/Screen/top.vue b/src/components/Screen/top.vue
index f79dc91..8257b80 100644
--- a/src/components/Screen/top.vue
+++ b/src/components/Screen/top.vue
@@ -49,15 +49,16 @@
       this.currView = "chart"
       this.screen = true
       this.$parent.$refs.mapleft.OpenLeftInit()
+      this.$parent.$refs.mapright.OpenLeftInit()
     },
 
     //鎵撳紑宸ョ▼鏍�
     OpenProjectree() {
       this.screen = false
-
       this.currView = "tree"
-
       this.$parent.$refs.mapleft.OpenLeftProjectTree()
+      this.$parent.$refs.mapright.OpenLeftProjectTree()
+
     },
   },
 }
diff --git a/src/components/chart/CountDataApply.vue b/src/components/chart/CountDataApply.vue
index ac948f4..0728704 100644
--- a/src/components/chart/CountDataApply.vue
+++ b/src/components/chart/CountDataApply.vue
@@ -27,7 +27,7 @@
         xAxis.push(item.name)
         yAxis.push(item.number)
       })
- 
+
       // let data = [220, 182, 191, 234, 290, 330, 310]
       // const sideData = data.map(item => {
       //   return {
@@ -46,6 +46,13 @@
             type: "shadow", // 榛樿涓虹洿绾匡紝鍙�変负锛�'line' | 'shadow'
           },
         },
+        grid: {
+          top: "10%",
+          bottom: "15%",
+          right: "5%",
+          left: "5%",
+          containLabel: true,
+        },
         xAxis: {
           data: xAxis,
           //鍧愭爣杞�
diff --git a/src/components/chart/DataStorage.vue b/src/components/chart/DataStorage.vue
index ce7a550..5814017 100644
--- a/src/components/chart/DataStorage.vue
+++ b/src/components/chart/DataStorage.vue
@@ -45,7 +45,16 @@
           </el-table-column>
           <el-table-column align="center" prop="name" label="鍚嶇О">
             <template slot-scope="scope">
-              <div>{{ scope.row.name }}</div>
+              <div
+                style="
+                  overflow: hidden;
+                  text-overflow: ellipsis;
+                  white-space: nowrap;
+                "
+                :title="scope.row.name"
+              >
+                {{ scope.row.name }}
+              </div>
             </template>
           </el-table-column>
           <el-table-column prop="num" label="鏂囦欢鏁�" width="70">
@@ -181,36 +190,38 @@
 </style>
 
 <style lang="scss">
-.index-wrap {
-  margin: 0 auto;
-  width: 14px;
-  height: 14px;
-  background: rgba(180, 188, 235, 0.25);
-}
-.scrollbar {
-  width: 100%;
-  overflow-x: hidden;
-  height: 200px;
-  .el-scrollbar__wrap {
-    overflow-x: hidden;
+.data-storage {
+  .index-wrap {
+    margin: 0 auto;
+    width: 14px;
+    height: 14px;
+    background: rgba(180, 188, 235, 0.25);
   }
-  .el-table {
-    height: 100%;
+  .scrollbar {
     width: 100%;
-    background-color: transparent;
-    color: #fff;
-  }
-  .el-table th.el-table__cell.is-leaf,
-  .el-table td.el-table__cell {
-    border: none;
-  }
-  .el-table--group::after,
-  .el-table--border::after,
-  .el-table::before {
-    border: none;
-  }
-  .el-table::before {
-    height: 0;
+    overflow-x: hidden;
+    height: 200px;
+    .el-scrollbar__wrap {
+      overflow-x: hidden;
+    }
+    .el-table {
+      height: 100%;
+      width: 100%;
+      background-color: transparent;
+      color: #fff;
+    }
+    .el-table th.el-table__cell.is-leaf,
+    .el-table td.el-table__cell {
+      border: none;
+    }
+    .el-table--group::after,
+    .el-table--border::after,
+    .el-table::before {
+      border: none;
+    }
+    .el-table::before {
+      height: 0;
+    }
   }
 }
 </style>
diff --git a/src/components/chart/FileFormat.vue b/src/components/chart/FileFormat.vue
index b1ad261..2b5be35 100644
--- a/src/components/chart/FileFormat.vue
+++ b/src/components/chart/FileFormat.vue
@@ -3,6 +3,7 @@
 </template>
 
 <script>
+const fileTypeBar = require("@/assets/img/Screen/fileTypeBar.png")
 import * as echarts from "echarts"
 import { countFileFormat } from "@/api/screen.js"
 export default {
@@ -173,9 +174,10 @@
           {
             name: "XXX",
             type: "pictorialBar",
+
             symbol:
-              "image://",
-            symbolSize: [35, 35],
+              "image://",
+            symbolSize: [25, 25],
             symbolOffset: [20, 0],
             z: 5,
             data: getSymbolData(data),
diff --git a/src/views/Thematic/index.vue b/src/views/Thematic/index.vue
index d3b7ca7..ccb777b 100644
--- a/src/views/Thematic/index.vue
+++ b/src/views/Thematic/index.vue
@@ -42,6 +42,7 @@
       }
       if (parm == "leftView" || parm == "leftTree") {
         this.leftWidth = "20%"
+        this.rightWidth = "20%"
       }
 
       if (parm == "right") {

--
Gitblit v1.9.3