浏览代码

新增曲线偏差率页面

baiyanting 1 年之前
父节点
当前提交
14ec8bf46f

+ 33 - 0
src/api/powerGenerating/index.js

@@ -265,3 +265,36 @@ export function getWindDeviationRatio(data, timeout = 5000) {
     timeout,
   });
 }
+
+export function getWindFittingLine(data, timeout = 5000) {
+  return request({
+    baseURL: process.env.VUE_APP_TEST,
+    url: "/power/fitting/line",
+    method: "get",
+    params: data,
+    headers,
+    timeout,
+  });
+}
+
+export function getWindFittingTime(data, timeout = 5000) {
+  return request({
+    baseURL: process.env.VUE_APP_TEST,
+    url: "/power/fitting/time",
+    method: "get",
+    params: data,
+    headers,
+    timeout,
+  });
+}
+
+export function getWindRatedPower(data, timeout = 5000) {
+  return request({
+    baseURL: process.env.VUE_APP_TEST,
+    url: "/rated/power",
+    method: "get",
+    params: data,
+    headers,
+    timeout,
+  });
+}

+ 397 - 0
src/views/powerGenerating/windAnalyse/lineAnalysis/components/barChart.json

@@ -0,0 +1,397 @@
+
+{
+	"color": [
+			"rgb(50,93,171)",
+			"rgb(222,132,82)",
+			"rgb(105,188,80)",
+			"rgb(197,78,82)",
+			"rgb(129,114,181)",
+			"#005eaa",
+			"#cda819",
+			"#32a487"
+	],
+	"backgroundColor": "rgba(0,0,0,0)",
+	"textStyle": {},
+	"title": {
+			"textStyle": {
+					"color": "#838383B3B3B3"
+			},
+			"subtextStyle": {
+					"color": "#aaaaaa"
+			}
+	},
+	"line": {
+			"itemStyle": {
+					"borderWidth": 1
+			},
+			"lineStyle": {
+					"width": 2
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false
+	},
+	"radar": {
+			"itemStyle": {
+					"borderWidth": 1
+			},
+			"lineStyle": {
+					"width": 2
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false
+	},
+	"bar": {
+			"itemStyle": {
+					"barBorderWidth": 0,
+					"barBorderColor": "#ccc"
+			},
+			"barMaxWidth": 50
+	},
+	"pie": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"scatter": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"boxplot": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"parallel": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"sankey": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"funnel": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"gauge": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"candlestick": {
+			"itemStyle": {
+					"color": "#c12e34",
+					"color0": "#2b821d",
+					"borderColor": "#c12e34",
+					"borderColor0": "#2b821d",
+					"borderWidth": 1
+			}
+	},
+	"graph": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			},
+			"lineStyle": {
+					"width": 1,
+					"color": "#aaaaaa"
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false,
+			"color": [
+					"#c12e34",
+					"#e6b600",
+					"#0098d9",
+					"#50ec39",
+					"#005eaa",
+					"#339ca8",
+					"#cda819",
+					"#32a487"
+			],
+			"label": {
+					"color": "#eeeeee"
+			}
+	},
+	"map": {
+			"itemStyle": {
+					"areaColor": "#ddd",
+					"borderColor": "#eee",
+					"borderWidth": 0.5
+			},
+			"label": {
+					"color": "#c12e34"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"areaColor": "#e6b600",
+							"borderColor": "#ddd",
+							"borderWidth": 1
+					},
+					"label": {
+							"color": "#c12e34"
+					}
+			}
+	},
+	"geo": {
+			"itemStyle": {
+					"areaColor": "#ddd",
+					"borderColor": "#eee",
+					"borderWidth": 0.5
+			},
+			"label": {
+					"color": "#c12e34"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"areaColor": "#e6b600",
+							"borderColor": "#ddd",
+							"borderWidth": 1
+					},
+					"label": {
+							"color": "#c12e34"
+					}
+			}
+	},
+	"categoryAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#838383"
+			},
+			"splitLine": {
+					"show": false,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"valueAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#838383"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"logAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#838383"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"timeAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#838383"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"toolbox": {
+			"iconStyle": {
+					"borderColor": "#06467c"
+			},
+			"emphasis": {
+					"iconStyle": {
+							"borderColor": "#4187c2"
+					}
+			}
+	},
+	"legend": {
+			"textStyle": {
+					"color": "#838383B3B3B3"
+			}
+	},
+	"tooltip": {
+			"axisPointer": {
+					"lineStyle": {
+							"color": "#cccccc",
+							"width": 1
+					},
+					"crossStyle": {
+							"color": "#cccccc",
+							"width": 1
+					}
+			}
+	},
+	"timeline": {
+			"lineStyle": {
+					"color": "#005eaa",
+					"width": 1
+			},
+			"itemStyle": {
+					"color": "#005eaa",
+					"borderWidth": 1
+			},
+			"controlStyle": {
+					"color": "#005eaa",
+					"borderColor": "#005eaa",
+					"borderWidth": 0.5
+			},
+			"checkpointStyle": {
+					"color": "#005eaa",
+					"borderColor": "#316bc2"
+			},
+			"label": {
+					"color": "#005eaa"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"color": "#005eaa"
+					},
+					"controlStyle": {
+							"color": "#005eaa",
+							"borderColor": "#005eaa",
+							"borderWidth": 0.5
+					},
+					"label": {
+							"color": "#005eaa"
+					}
+			}
+	},
+	"visualMap": {
+			"color": [
+					"#1790cf",
+					"#a2d4e6"
+			]
+	},
+	"dataZoom": {
+			"backgroundColor": "rgba(47,69,84,0)",
+			"dataBackgroundColor": "rgba(47,69,84,0.3)",
+			"fillerColor": "rgba(167,183,204,0.4)",
+			"handleColor": "#a7b7cc",
+			"handleSize": "100%",
+			"textStyle": {
+					"color": "#838383B3B3B3"
+			}
+	},
+	"markPoint": {
+			"label": {
+					"color": "#eeeeee"
+			},
+			"emphasis": {
+					"label": {
+							"color": "#eeeeee"
+					}
+			}
+	}
+}

+ 214 - 0
src/views/powerGenerating/windAnalyse/lineAnalysis/components/barChart.vue

@@ -0,0 +1,214 @@
+<script setup>
+import util from "@tools/util";
+import chartTheme from "./barChart.json";
+import {
+  ref,
+  toRaw,
+  computed,
+  onMounted,
+  watch,
+  nextTick,
+  defineEmits,
+  defineProps,
+} from "vue";
+import * as echarts from "echarts";
+const chartId = "chart-" + util.newGUID(); //chartId
+const chartIns = ref(null); //chart 实例
+const emits = defineEmits(["getSelected"]);
+const props = defineProps({
+  xAxis: {
+    type: Object,
+    required: true,
+    default: () => ({}),
+  },
+  yAxis: {
+    type: Array,
+    required: false,
+  },
+  colors: {
+    type: Array,
+    default: () => [],
+  },
+  series: {
+    type: Array,
+    required: true,
+  },
+  dataset: {
+    type: Array,
+    required: false,
+    default: () => [],
+  },
+  height: {
+    type: String,
+    required: false,
+    default: "500px",
+  },
+  width: {
+    type: String,
+    required: false,
+    default: "500px",
+  },
+  title: {
+    type: String,
+    required: false,
+  },
+  subtext: {
+    type: String,
+    required: false,
+  },
+  brush: {
+    type: Boolean,
+    required: false,
+    default: false,
+  },
+});
+
+/**定义option */
+const option = computed({
+  get() {
+    return {
+      color: props.colors.length
+        ? props.colors
+        : [
+            "rgb(50,93,171)",
+            "rgb(222,132,82)",
+            "rgb(105,188,80)",
+            "rgb(197,78,82)",
+            "rgb(129,114,181)",
+            "#005eaa",
+            "#cda819",
+            "#32a487",
+          ],
+      title: {
+        text: props.title || "",
+        subtext: props.subtext || "",
+        top: 6,
+        left: "5%",
+      },
+      xAxis: props.xAxis || {},
+      yAxis: props.yAxis || {},
+      brush: {
+        seriesIndex: [1],
+        yAxisIndex: 0,
+        transformable: true,
+        throttleType: "debounce",
+        throttleDelay: 1000,
+        removeOnClick: true,
+        brushType: props.brush ? "polygon" : false,
+        brushMode: "multiple",
+        brushStyle: {
+          borderWidth: 1,
+          borderColor: "#ff2424",
+        },
+      },
+      toolbox: {
+        show: props.brush,
+      },
+      tooltip: {
+        confine: true,
+        trigger: "axis",
+      },
+      dataset: props.dataset || [],
+      series: props.series || [],
+      legend: {
+        right: "120",
+        top: "5",
+        itemWidth: 6,
+      },
+      grid: {
+        top: 80,
+        left: 40,
+        right: 40,
+        bottom: 40,
+      },
+      dataZoom: [
+        {
+          type: "inside", //图表下方的伸缩条
+          show: false, //是否显示
+          realtime: true, //拖动时,是否实时更新系列的视图
+          start: 0, //伸缩条开始位置(1-100),可以随时更改
+          end: 100, //伸缩条结束位置(1-100),可以随时更改
+        },
+        {
+          type: "slider", //图表下方的伸缩条
+          show: false, //是否显示
+          realtime: true, //拖动时,是否实时更新系列的视图
+          start: 0, //伸缩条开始位置(1-100),可以随时更改
+          end: 100, //伸缩条结束位置(1-100),可以随时更改
+        },
+      ],
+    };
+  },
+  set(val) {},
+});
+watch(
+  () => option,
+  (newVal, oldVal) => {
+    if (chartIns.value) {
+      const echartIns = toRaw(chartIns.value);
+      echartIns.setOption(toRaw(newVal.value));
+    }
+  },
+  { deep: true }
+);
+
+watch([() => props.width, () => props.height], (newVal, oldVal) => {
+  if (chartIns.value) {
+    const echartIns = toRaw(chartIns.value);
+    nextTick(() => echartIns.resize());
+  }
+});
+const funBrushChange = (flag) => {
+  const echartIns = toRaw(chartIns.value);
+  echartIns.dispatchAction({
+    type: "takeGlobalCursor",
+    // 如果想变为“可刷选状态”,必须设置。不设置则会关闭“可刷选状态”。
+    key: "brush",
+    brushOption: {
+      seriesIndex: [1],
+      yAxisIndex: 0,
+      transformable: true,
+      throttleType: "debounce",
+      throttleDelay: 1000,
+      removeOnClick: true,
+      brushType: flag ? "polygon" : false,
+      brushMode: "multiple",
+      brushStyle: {
+        borderWidth: 1,
+        color: "rgba(255,36,36,0.2)",
+        borderColor: "#ff2424",
+      },
+    },
+  });
+  echartIns.off("brushSelected");
+  echartIns.on("brushSelected", (params) => {
+    emits("getSelected", params.batch || []);
+  });
+};
+watch(
+  () => props.brush,
+  (newVal, oldVal) => funBrushChange(newVal)
+);
+
+onMounted(() => {
+  nextTick(() => {
+    echarts.registerTheme("chartTheme", chartTheme);
+    const echartIns = echarts.init(
+      document.getElementById(chartId),
+      "chartTheme"
+    );
+    chartIns.value = echartIns;
+    echartIns.setOption(option.value);
+    funBrushChange(props.brush);
+    window.addEventListener("resize", () => {
+      echartIns.resize();
+    });
+  });
+});
+</script>
+<template>
+  <div
+    :id="chartId"
+    :style="{ height: props.height, width: props.width }"
+  ></div>
+</template>

+ 398 - 0
src/views/powerGenerating/windAnalyse/lineAnalysis/components/current-scatter-chart.json

@@ -0,0 +1,398 @@
+
+{
+	"color": [
+			"#1C99FF",
+			"#FF8700",
+			"#e6b600d9",
+			"#0098d9",
+			"#3D54BE",
+			"#005eaa",
+			"#cda819",
+			"#32a487"
+	],
+	"textStyle": {},
+	"title": {
+			"textStyle": {
+					"color": "#333333"
+			},
+			"subtextStyle": {
+					"color": "#aaaaaa"
+			}
+	},
+	"line": {
+			"itemStyle": {
+					"borderWidth": 1
+			},
+			"lineStyle": {
+					"width": 2
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false
+	},
+	"radar": {
+			"itemStyle": {
+					"borderWidth": 1
+			},
+			"lineStyle": {
+					"width": 2
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false
+	},
+	"bar": {
+			"itemStyle": {
+					"barBorderWidth": 0,
+					"barBorderColor": "#ccc"
+			}
+	},
+	"pie": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"scatter": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"boxplot": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"parallel": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"sankey": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"funnel": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"gauge": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			}
+	},
+	"candlestick": {
+			"itemStyle": {
+					"color": "#c12e34",
+					"color0": "#2b821d",
+					"borderColor": "#c12e34",
+					"borderColor0": "#2b821d",
+					"borderWidth": 1
+			}
+	},
+	"graph": {
+			"itemStyle": {
+					"borderWidth": 0,
+					"borderColor": "#ccc"
+			},
+			"lineStyle": {
+					"width": 1,
+					"color": "#aaaaaa"
+			},
+			"symbolSize": 4,
+			"symbol": "emptyCircle",
+			"smooth": false,
+			"color": [
+					"#c12e34",
+					"#e6b600",
+					"#0098d9",
+					"#50ec39",
+					"#005eaa",
+					"#339ca8",
+					"#cda819",
+					"#32a487"
+			],
+			"label": {
+					"color": "#eeeeee"
+			}
+	},
+	"map": {
+			"itemStyle": {
+					"areaColor": "#ddd",
+					"borderColor": "#eee",
+					"borderWidth": 0.5
+			},
+			"label": {
+					"color": "#c12e34"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"areaColor": "#e6b600",
+							"borderColor": "#ddd",
+							"borderWidth": 1
+					},
+					"label": {
+							"color": "#c12e34"
+					}
+			}
+	},
+	"geo": {
+			"itemStyle": {
+					"areaColor": "#ddd",
+					"borderColor": "#eee",
+					"borderWidth": 0.5
+			},
+			"label": {
+					"color": "#c12e34"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"areaColor": "#e6b600",
+							"borderColor": "#ddd",
+							"borderWidth": 1
+					},
+					"label": {
+							"color": "#c12e34"
+					}
+			}
+	},
+	"categoryAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#333"
+			},
+			"splitLine": {
+					"show": false,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"valueAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#838383"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#838383"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"logAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#333"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"timeAxis": {
+			"axisLine": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisTick": {
+					"show": true,
+					"lineStyle": {
+							"color": "#333"
+					}
+			},
+			"axisLabel": {
+					"show": true,
+					"color": "#333"
+			},
+			"splitLine": {
+					"show": true,
+					"lineStyle": {
+							"color": [
+									"#ccc"
+							]
+					}
+			},
+			"splitArea": {
+					"show": false,
+					"areaStyle": {
+							"color": [
+									"rgba(250,250,250,0.3)",
+									"rgba(200,200,200,0.3)"
+							]
+					}
+			}
+	},
+	"toolbox": {
+			"iconStyle": {
+					"borderColor": "#06467c"
+			},
+			"emphasis": {
+					"iconStyle": {
+							"borderColor": "#4187c2"
+					}
+			},
+			"textStyle": {
+				"color": "#838383"
+			}
+	},
+	"legend": {
+			"textStyle": {
+					"color": "#838383"
+			}
+	},
+	"tooltip": {
+			"axisPointer": {
+					"lineStyle": {
+							"color": "#cccccc",
+							"width": 1
+					},
+					"crossStyle": {
+							"color": "#cccccc",
+							"width": 1
+					}
+			}
+	},
+	"timeline": {
+			"lineStyle": {
+					"color": "#005eaa",
+					"width": 1
+			},
+			"itemStyle": {
+					"color": "#005eaa",
+					"borderWidth": 1
+			},
+			"controlStyle": {
+					"color": "#005eaa",
+					"borderColor": "#005eaa",
+					"borderWidth": 0.5
+			},
+			"checkpointStyle": {
+					"color": "#005eaa",
+					"borderColor": "#316bc2"
+			},
+			"label": {
+					"color": "#005eaa"
+			},
+			"emphasis": {
+					"itemStyle": {
+							"color": "#005eaa"
+					},
+					"controlStyle": {
+							"color": "#005eaa",
+							"borderColor": "#005eaa",
+							"borderWidth": 0.5
+					},
+					"label": {
+							"color": "#005eaa"
+					}
+			}
+	},
+	"visualMap": {
+			"color": [
+					"#1790cf",
+					"#a2d4e6"
+			]
+	},
+	"dataZoom": {
+			"backgroundColor": "rgba(47,69,84,0)",
+			"dataBackgroundColor": "rgba(47,69,84,0.3)",
+			"fillerColor": "rgba(167,183,204,0.4)",
+			"handleColor": "#a7b7cc",
+			"handleSize": "100%",
+			"textStyle": {
+					"color": "#333333"
+			}
+	},
+	"markPoint": {
+			"label": {
+					"color": "#eeeeee"
+			},
+			"emphasis": {
+					"label": {
+							"color": "#eeeeee"
+					}
+			}
+	}
+}

+ 356 - 0
src/views/powerGenerating/windAnalyse/lineAnalysis/components/current-scatter-chart.vue

@@ -0,0 +1,356 @@
+<template>
+  <div class="chart" :id="id"></div>
+</template>
+
+<script>
+import util from "@tools/util";
+import partten from "@tools/partten";
+import * as echarts from "echarts";
+import chartTheme from './current-scatter-chart.json'
+
+export default {
+  name: 'currentScatterChart',
+  props: {
+    // 图表宽度
+    width: {
+      type: String,
+      default: "100%",
+    },
+    // 图表高度
+    height: {
+      type: String,
+      default: "350px",
+    },
+    // 图表主标题
+    chartTitle: {
+      type: String,
+      default: "自定义图表组件",
+    },
+    // X 轴配置项
+    xAxisData: {
+      type: Array,
+      default: () => {
+        return [];
+      },
+    },
+    // Y 轴配置项
+    yAxisData: {
+      type: Array,
+      default: () => {
+        return [];
+      },
+    },
+    dataSet: {
+      type: String,
+      default: ''
+    },
+    // 图表核心数据
+    seriesData: {
+      type: Array,
+      default: () => {
+        return [];
+      },
+    },
+    // 是否显示图表图例
+    showLegend: {
+      type: Boolean,
+      default: true,
+    },
+    // 是否默认采用笔刷模式
+    brushSelected: {
+      type: Boolean,
+      default: false,
+    },
+  },
+  data() {
+    return {
+      id: "",
+      chart: null,
+      color: [
+        "#05bb4c",
+        "#4b55ae",
+        "#fa8c16",
+        "#f8de5b",
+        "#1a93cf",
+        "#c531c7",
+        "#bd3338",
+      ],
+      theme: 'light'
+    };
+  },
+  computed: {
+    collapse(){
+      return this.$store.state.collapse
+    }
+  },
+  watch: {
+    height(){
+      if(this.chart){
+          this.chart.resize()
+      }
+    },
+    collapse(val){
+      if(this.chart){
+        setTimeout(() => {
+          this.chart.resize()
+        },300)
+      }
+    }
+  },
+  methods: {
+    resize() {},
+    initChart() {
+      const that = this;
+      echarts.registerTheme('chartTheme', chartTheme)
+      let myChart = echarts.init(document.getElementById(this.id), 'chartTheme');
+      that.chart = myChart
+      //指定图表的配置项和数据
+      const option = {
+        //标题
+        title: {
+          text: that.chartTitle,
+          right: 440,
+          top: 4,
+          textStyle: {
+            fontSize: 14,
+            color: that.theme === "dark" ? partten.getColor("grayl") : "#000",
+          },
+        },
+        // backgroundColor:
+        //   that.theme === "dark"
+        //     ? "rgba(0,0,0,0.4)"
+        //     : "rgba(255,255,255,0.5)",
+        //工具箱
+        color: [
+            "rgb(255,0,0)",
+            "#FF8700",
+            "#e6b600d9",
+            "#0098d9",
+            "#3D54BE",
+            "#005eaa",
+            "#cda819",
+            "#32a487"
+        ],
+        toolbox: {
+          show: false,
+          x: "right",
+          position: [10, 10],
+          // backgroundColor:'rgba(0,0,0,0.4)',
+          borderColor: partten.getColor("gray"),
+          textStyle: {
+            fontSize: util.vh(16),
+            color: partten.getColor("gray")
+          },
+          iconStyle: {
+            borderColor:partten.getColor("gray")
+          },
+          emphasis: {
+            iconStyle: {
+              borderColor:partten.getColor("gray")
+            },
+          },
+        },
+        tooltip: {
+          trigger: "axis",
+          axisPointer: {
+            type: "cross",
+          },
+          // backgroundColor: "rgba(0,0,0,0.4)",
+          // borderColor: partten.getColor("gray"),
+          // textStyle: {
+          //   fontSize: util.vh(16),
+          //   color: partten.getColor("gray"),
+          // },
+          // formatter(params) {
+          //   return params.value?.x
+          //     ? `${params.seriesName}<br />风速:${params.value.x}m/s<br />功率:${params.value.y}kW`
+          //     : `${params.name}`;
+          // },
+        },
+        brush: {
+          seriesIndex: [2,3],
+          yAxisIndex: 0,
+          transformable: true,
+          throttleType: "debounce",
+          throttleDelay: 1000,
+          removeOnClick: true,
+          brushType: "polygon",
+          brushMode: "multiple",
+          brushStyle: {
+            borderWidth: 1,
+            borderColor: "#ff2424",
+          },
+        },
+        dataZoom: [
+          {
+            type: "inside", //图表下方的伸缩条
+            show: false, //是否显示
+            realtime: true, //拖动时,是否实时更新系列的视图
+            start: 0, //伸缩条开始位置(1-100),可以随时更改
+            end: 100, //伸缩条结束位置(1-100),可以随时更改
+          },
+          {
+            type: "slider", //图表下方的伸缩条
+            show: false, //是否显示
+            realtime: true, //拖动时,是否实时更新系列的视图
+            start: 0, //伸缩条开始位置(1-100),可以随时更改
+            end: 100, //伸缩条结束位置(1-100),可以随时更改
+          },
+        ],
+        textStyle: {
+          fontSize: util.vh(16),
+          color: that.theme === "dark" ? "#fff" : "#000",
+        },
+        //图例-每一条数据的名字
+        legend: {
+          show: that.showLegend,
+          // data: [ "拟合功率", "保证功率","无用点", "有用点", "Cp值"],
+          right: 260,
+          type: 'scroll',
+          top: "5",
+          // icon: "circle",
+          itemWidth: 6,
+          inactiveColor:
+            that.theme === "dark"
+              ? partten.getColor("gray")
+              : "#000",
+          textStyle: {
+            color:
+              that.theme === "dark"
+                ? partten.getColor("grayl")
+                : "#000",
+            fontSize: 12,
+          },
+          
+        },
+        grid: {
+          top: 58,
+          left: 40,
+          right: 40,
+          bottom: 24,
+        },
+        //x轴
+        xAxis: [
+          {
+            name: 'm/s',
+            nameTextStyle: {
+              color: '#838383'
+            },
+            type: "value",
+            boundaryGap: false,
+            data: that.xAxisData || [],
+            min: 0,
+            max: 25,
+            interval: 1,
+            axisLabel: {
+              formatter: "{value}",
+            },
+            splitLine: {
+              show: false,
+            },
+            smooth: true,
+            textStyle: {
+              color:
+                that.theme === "dark"
+                  ? partten.getColor("gray")
+                  : "#000",
+            },
+          },
+        ],
+        //y轴没有显式设置,根据值自动生成y轴
+        yAxis: [{
+          splitLine: { show: false },
+          position: 'left',
+          min: 0,
+          name: 'kW',
+          nameTextStyle: {
+            color: '#838383'
+          }
+        }],
+        animation: true,
+        dataset: that.dataSet.length? JSON.parse(that.dataSet) : [],
+        //数据-data是最终要显示的数据
+        series: that.seriesData,
+      };
+
+      that.resize = function () {
+        myChart.resize();
+      };
+
+      window.addEventListener("resize", that.resize);
+
+      myChart.setOption(option);
+      // if (that.brushSelected) {
+      //   myChart.dispatchAction({
+      //     type: "takeGlobalCursor",
+      //     // 如果想变为“可刷选状态”,必须设置。不设置则会关闭“可刷选状态”。
+      //     key: "brush",
+      //     brushOption: {
+      //       seriesIndex: [2,3],
+      //       yAxisIndex: 0,
+      //       transformable: true,
+      //       throttleType: "debounce",
+      //       throttleDelay: 1000,
+      //       removeOnClick: true,
+      //       brushType: "polygon",
+      //       brushMode: "multiple",
+      //       brushStyle: {
+      //         borderWidth: 1,
+      //         color: "rgba(255,36,36,0.2)",
+      //         borderColor: "#ff2424",
+      //       },
+      //     },
+      //   });
+      // }
+      myChart.off("brushSelected");
+      myChart.on("brushSelected", (params) => {
+        that.$emit("getSelected", params.batch || []);
+      });
+      myChart.off('click')
+      myChart.on('click', params => {
+          // if(params.componentType === 'markArea'){
+          //   myChart.dispatchAction({
+          //     type: 'brush',
+          //     areas: [
+          //       {
+          //         xAxisIndex: 0,
+          //         brushType: 'lineX',
+          //         coordRange: [params.data.coord[0][0], params.data.coord[1][0]]
+          //       },
+          //     ]
+          //   });
+          // }
+        })
+    },
+  },
+  created() {
+    this.id = "chart-" + util.newGUID();
+  },
+  mounted() {
+    // this.$nextTick(() => {
+      this.$el.style.width = this.width;
+      this.$el.style.height = this.height;
+      this.initChart();
+    // });
+  },
+  updated() {
+    // console.log('update')
+    let myChart = echarts.init(document.getElementById(this.id));
+    myChart.dispose();
+    this.$nextTick(() => {
+      this.initChart();
+    });
+  },
+  unmounted() {
+    window.removeEventListener("resize", this.resize);
+  },
+};
+</script>
+
+<style>
+.chart {
+  width: 100%;
+  height: 100%;
+  display: inline-block;
+}
+</style>

+ 733 - 0
src/views/powerGenerating/windAnalyse/lineAnalysis/index.vue

@@ -0,0 +1,733 @@
+<script setup name="lineAnalysis">
+import excelCop from "@/components/excel.vue";
+import treeCop from "@/components/tree.vue";
+import barChartCop from "./components/barChart.vue";
+import SubmitBtn from "@/components/SubmitBtn.vue";
+import { ref, nextTick, onActivated, onMounted, reactive } from "vue";
+import { ElMessage } from "element-plus";
+import util from "@tools/util";
+import CurrentScatterChart from "./components/current-scatter-chart.vue";
+import {
+  getWindFittingTree,
+  getWindFittingLine,
+  getWindFittingTime,
+  getWindRatedPower,
+} from "@/api/powerGenerating/index.js";
+
+/**excel 开始 */
+const excelCheckboxShow = ref(false);
+const excelCheckIds = ref([]);
+const excelList = ref([]);
+const funExcelChange = async (obj) => {
+  //点击excel项时
+  return false;
+};
+const funExcelCheckChange = ({ checkArr, data }) => {
+  //bug
+  excelCheckIds.value = checkArr;
+  funSubmit();
+};
+/**prepare tree 开始 */
+const treeData = ref([]);
+const treeCopRef = ref(); //treeCop ref
+const actTreeNode = ref(null); //当前激活的treeNode
+const funRepeatMap = (arr, type = "fitting") => {
+  return arr.map((o) => {
+    if (o.children) {
+      const findIndex = o.children.findIndex((p) => !!p.type);
+      if (findIndex !== -1) {
+        o.childs = o.children;
+        o.children = [];
+        if (!actTreeNode.value && type === "fitting") {
+          //判断当且仅有process获取tree时 赋值
+          actTreeNode.value = o;
+        }
+      }
+    }
+    return {
+      ...o,
+      children: o.children ? funRepeatMap(o.children, type) : [],
+    };
+  });
+};
+const funGetTree = async () => {
+  actTreeNode.value = null;
+  const res = await getWindFittingTree();
+  treeData.value = funRepeatMap(res.data);
+  excelList.value = [];
+  if (actTreeNode.value) {
+    funCurrentChange({ current: actTreeNode.value, currentNode: null });
+    if (treeCopRef.value) {
+      treeCopRef.value.setCheckedKeys([actTreeNode.value.id]);
+      excelCheckIds.value = actTreeNode.value.childs.map((o) => o.id);
+      funSubmit();
+    }
+  }
+};
+const funCurrentChange = ({ current, currentNode }) => {
+  excelCheckboxShow.value = true;
+  if (current.childs) {
+    excelList.value = current.childs.map((o) => {
+      return {
+        id: o.id,
+        interval: o.interval,
+        path: o.path,
+        prepareid: o.prepareid,
+        station: o.station,
+        time: o.time,
+        type: o.type,
+        windturbine: o.windturbine,
+        name: o.path.substring(
+          o.path.indexOf(o.station + "_") + (o.station + "_").length
+        ),
+      };
+    });
+  } else {
+    excelList.value = [];
+  }
+};
+const funTreeCheckChange = ({
+  current,
+  checkedNodes,
+  checkedKeys,
+  halfCheckedNodes,
+  halfCheckedKeys,
+}) => {
+  //tree change  -> excel change
+  funCurrentChange({ current, currentNode: "" });
+  const checkIds = [];
+  if (checkedNodes.length) {
+    for (const node of checkedNodes) {
+      if (node.childs && node.childs.length) {
+        for (const child of node.childs) {
+          checkIds.push(child.id);
+        }
+      }
+    }
+  }
+  excelCheckIds.value = checkIds;
+  funSubmit();
+};
+
+/**search 开始 */
+const funSubmit = async () => {
+  if (!excelCheckIds.value.length) {
+    ElMessage.error("请勾选要执行的项");
+    return false;
+  }
+  wtData.value = [];
+  const params = {
+    ids: excelCheckIds.value.join(","),
+  };
+  const res = await getWindFittingLine(params);
+  if (res.code === 200) {
+    seriesData.value = [];
+    if (res.data.bzgl) {
+      seriesData.value.push({
+        name: "保证功率",
+        type: "line",
+        symbol: "line", //设定为实心点
+        symbolSize: 0, //设定实心点的大小
+        smooth: true, //这个是把线变成曲线
+        data: res.data.bzgl || [],
+        xAxisIndex: 0,
+      });
+    }
+    if (res.data.sjgl?.length) {
+      for (const wtObj of res.data.sjgl) {
+        seriesData.value.push({
+          name: wtObj.obj.windturbineId + "\n实际功率",
+          type: "line",
+          symbol: "line", //设定为实心点
+          symbolSize: 0, //设定实心点的大小
+          smooth: true, //这个是把线变成曲线
+          data: wtObj.sjgl || [],
+          xAxisIndex: 0,
+        });
+        wtData.value.push(wtObj.obj);
+      }
+    }
+  }
+};
+/**chart Data */
+const avgObj = reactive({
+  //平均cpz等
+  cpavg: "",
+  frequency: "",
+  pcratio: "",
+});
+const xAxisData = ref([]);
+const chartRef = ref(); //chart 的ref
+const seriesData = ref([]);
+const isChartArea = ref(false); // 用来控制图表是否区域划分
+const dataSet = ref("");
+const funChartSelect = async (batch) => {
+  return false;
+};
+const funChartArea = () => {
+  if (seriesData.value?.length) {
+    // 获取数据后 展示dialog table 数据
+    wtDialog.value = true;
+    if (!isChartArea.value) {
+      // 请求一下
+      seriesData.value[0] = {
+        ...seriesData.value[0],
+        markLine: {
+          symbol: "none",
+          label: {
+            show: false,
+          },
+          lineStyle: {
+            color: "rgba(96,174,255, 1)",
+          },
+          data: [
+            {
+              xAxis: 3,
+              valueIndex: 0,
+            },
+            {
+              xAxis: 5,
+              valueIndex: 0,
+            },
+            {
+              xAxis: 10,
+              valueIndex: 0,
+            },
+            {
+              xAxis: 12,
+              valueIndex: 0,
+            },
+            {
+              xAxis: 25,
+              valueIndex: 0,
+            },
+          ],
+        },
+        markArea: {
+          label: {
+            fontSize: util.vh(12),
+          },
+          itemStyle: {
+            color: "rgba(236,245,255, 0)",
+          },
+          emphasis: {
+            itemStyle: {
+              color: "rgba(96,174,255, 0.5)",
+            },
+          },
+          data: [
+            [
+              {
+                name: `3~5m`,
+                xAxis: 3,
+              },
+              {
+                xAxis: 5,
+              },
+            ],
+            [
+              {
+                name: `5~10m`,
+                xAxis: 5,
+              },
+              {
+                xAxis: 10,
+              },
+            ],
+            [
+              {
+                name: `10~12m`,
+                xAxis: 10,
+              },
+              {
+                xAxis: 12,
+              },
+            ],
+            [
+              {
+                name: `12~25m`,
+                xAxis: 12,
+              },
+              {
+                xAxis: 25,
+              },
+            ],
+          ],
+        },
+      };
+      isChartArea.value = true;
+    } else {
+      seriesData.value[0] = {
+        ...seriesData.value[0],
+        markLine: null,
+        markArea: null,
+      };
+      isChartArea.value = false;
+    }
+  }
+};
+/**tmdialog 数据 */
+const tmDialog = ref(false);
+const barxAxis = reactive({
+  type: "category",
+  data: [],
+  splitLine: {
+    show: false,
+  },
+  axisTick: {
+    show: true,
+  },
+});
+const baryAxis = ref({
+  type: "value",
+  name: "小时",
+  splitLine: {
+    show: false,
+  },
+  axisTick: {
+    show: true,
+  },
+});
+const barSeries = ref([
+  {
+    name: "不运行",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "3~5m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "5~10m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "10~12m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "12~25m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+]);
+const barUnWorkSeries = ref([
+  {
+    name: "3~5m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "5~10m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "10~12m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+  {
+    name: "12~25m风速",
+    type: "bar",
+    stack: "a",
+    data: [],
+  },
+]);
+const funTimeArea = async () => {
+  if (seriesData.value?.length) {
+    activeTab.value = "1";
+    //获取数据
+    const res = await getWindFittingTime({
+      ids: excelCheckIds.value.join(","),
+    });
+    if (res.code === 200) {
+      barxAxis.data = [];
+      barSeries.value = [
+        {
+          name: "不运行",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "3~5m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "5~10m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "10~12m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "12~25m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+      ];
+      barUnWorkSeries.value = [
+        {
+          name: "3~5m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "5~10m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "10~12m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+        {
+          name: "12~25m风速",
+          type: "bar",
+          stack: "a",
+          data: [],
+        },
+      ];
+      for (const wtObj of res.data) {
+        barxAxis.data.push(wtObj.wtId);
+        for (const timeKey in wtObj.time1) {
+          barSeries.value[timeKey].data.push(
+            (wtObj.time1[timeKey] / 60).toFixed(0)
+          );
+        }
+        for (const time2Key in wtObj.time2) {
+          barUnWorkSeries.value[time2Key].data.push(
+            (wtObj.time2[time2Key] / 60).toFixed(0)
+          );
+        }
+      }
+      tmDialog.value = true;
+    }
+  }
+};
+
+/**额定功率 */
+const powerDialog = ref(false);
+const powerxAxis = reactive({
+  type: "category",
+  data: [],
+  splitLine: {
+    show: false,
+  },
+  axisTick: {
+    show: true,
+  },
+});
+const poweryAxis = ref({
+  type: "value",
+  name: "kW",
+  max: null,
+  splitLine: {
+    show: false,
+  },
+  axisTick: {
+    show: true,
+  },
+});
+const countyAxis = ref({
+  type: "value",
+  name: "次数",
+  splitLine: {
+    show: false,
+  },
+  axisTick: {
+    show: true,
+  },
+});
+const powerSeries = ref([
+  {
+    name: "平均全功率",
+    type: "bar",
+    data: [],
+    markLine: {},
+  },
+]);
+const countSeries = ref([
+  {
+    name: "次数",
+    type: "bar",
+    data: [],
+    markLine: {},
+  },
+]);
+const funPower = async () => {
+  if (seriesData.value?.length) {
+    //获取数据
+    const res = await getWindRatedPower({ ids: excelCheckIds.value.join(",") });
+    if (res.code === 200) {
+      powerxAxis.data = [];
+      powerSeries.value = [
+        {
+          name: "平均全功率",
+          type: "bar",
+          data: [],
+          markLine: {
+            symbol: "none",
+            label: {
+              show: true,
+            },
+            lineStyle: {
+              color: "rgba(96,174,255, 1)",
+            },
+            data: [],
+          },
+        },
+      ];
+      countSeries.value = [
+        {
+          name: "次数",
+          type: "bar",
+          data: [],
+          markLine: {},
+        },
+      ];
+      if (res.data.data) {
+        const xAxis = [],
+          seriesArr = [],
+          countArr = [];
+        for (const val of res.data.data) {
+          xAxis.push(val.wt);
+          seriesArr.push(val.avg);
+          countArr.push(val.count);
+        }
+        powerxAxis.data = xAxis;
+        countSeries.value[0].data = countArr.map((o) => {
+          return {
+            value: o,
+            // itemStyle: {
+            // 	color: o < res.data.avg ? 'rgb(197,78,82)' : 'rgb(50,93,171)'
+            // }
+          };
+        });
+        powerSeries.value[0].data = seriesArr.map((o) => {
+          return {
+            value: o,
+            itemStyle: {
+              color: o < res.data.avg ? "rgb(197,78,82)" : "rgb(50,93,171)",
+            },
+          };
+        });
+        let maxValue = Math.max(...seriesArr);
+        if (res.data.power > maxValue) {
+          maxValue = res.data.power;
+        } else {
+          maxValue = null;
+        }
+        poweryAxis.value.max = maxValue;
+        powerSeries.value[0].markLine.data = [
+          {
+            yAxis: res.data.avg,
+            name: `平均额定功率${res.data.avg}`,
+            lineStyle: {
+              color: "green",
+            },
+          },
+          {
+            yAxis: res.data.power,
+            name: `额定功率${res.data.power}`,
+            lineStyle: {
+              color: "red",
+            },
+          },
+        ];
+      }
+      powerDialog.value = true;
+    }
+  }
+};
+/**dialog 数据 */
+const wtDialog = ref(false);
+const wtData = ref([]);
+const activeTab = ref("1");
+/**created */
+funGetTree()
+// funGetProcessTree()
+/**mounted */
+
+/**activated */
+onActivated(() => {
+  funGetTree();
+});
+</script>
+<template>
+  <div class="container-wrapper">
+    <el-dialog draggable width="1000px" v-model="tmDialog">
+      <template #title>
+        <div class="dialog-title">
+          <div class="title">时间占比</div>
+        </div>
+      </template>
+      <el-tabs v-model="activeTab">
+        <el-tab-pane label="运行时间" name="1"> </el-tab-pane>
+        <el-tab-pane label="不运行时间" name="2"></el-tab-pane>
+        <div v-if="activeTab === '1'">
+          <bar-chart-cop
+            height="600px"
+            width="100%"
+            :xAxis="barxAxis"
+            :yAxis="baryAxis"
+            :series="barSeries"
+          ></bar-chart-cop>
+        </div>
+        <div v-if="activeTab === '2'">
+          <bar-chart-cop
+            height="600px"
+            :colors="[
+              'rgb(222,132,82)',
+              'rgb(105,188,80)',
+              'rgb(197,78,82)',
+              'rgb(129,114,181)',
+            ]"
+            width="100%"
+            :xAxis="barxAxis"
+            :yAxis="baryAxis"
+            :series="barUnWorkSeries"
+          ></bar-chart-cop>
+        </div>
+      </el-tabs>
+    </el-dialog>
+    <el-dialog draggable width="1000px" v-model="powerDialog" title="额定功率">
+      <template #title>
+        <div class="dialog-title">
+          <div class="title">额定功率</div>
+        </div>
+      </template>
+      <bar-chart-cop
+        height="350px"
+        :colors="[]"
+        width="100%"
+        :xAxis="powerxAxis"
+        :yAxis="countyAxis"
+        :series="countSeries"
+      ></bar-chart-cop>
+      <bar-chart-cop
+        height="350px"
+        :colors="[]"
+        width="100%"
+        :xAxis="powerxAxis"
+        :yAxis="poweryAxis"
+        :series="powerSeries"
+      ></bar-chart-cop>
+    </el-dialog>
+    <el-dialog draggable v-model="wtDialog" title="曲线偏差率">
+      <template #title>
+        <div class="dialog-title">
+          <div class="title">曲线偏差率</div>
+        </div>
+      </template>
+      <el-table :data="wtData" row-key="id" :max-height="600">
+        <el-table-column property="windturbine" align="center" label="风机" />
+        <el-table-column
+          property="pc5ratio"
+          sortable
+          align="center"
+          label="3~5m"
+        />
+        <el-table-column
+          property="pc10ratio"
+          sortable
+          align="center"
+          label="5~10m"
+        />
+        <el-table-column
+          property="pc12ratio"
+          sortable
+          align="center"
+          label="10~12m"
+        />
+        <el-table-column
+          property="pc25ratio"
+          sortable
+          align="center"
+          label="12~25m"
+        />
+        <el-table-column
+          property="pcratio"
+          sortable
+          align="center"
+          label="3~25m"
+        />
+      </el-table>
+    </el-dialog>
+    <div class="power-data-wrapper card-shadow wrapper">
+      <div class="card-title">数据展示</div>
+      <div class="data-wrapper">
+        <tree-cop
+          ref="treeCopRef"
+          :data="treeData"
+          @checkChange="funTreeCheckChange"
+          :show-checkbox="true"
+          :height="treeHeight"
+          @currentChange="funCurrentChange"
+          @refresh="funGetTree"
+        ></tree-cop>
+        <excel-cop
+          :checkIds="excelCheckIds"
+          :showCheckbox="excelCheckboxShow"
+          :data="excelList"
+          :height="excelHeight"
+          @excelChange="funExcelChange"
+          @checkChange="funExcelCheckChange"
+        ></excel-cop>
+        <div class="data-table-wrapper card-shadow">
+          <div class="submit-btns">
+            <SubmitBtn desc="区域划分" @click="funChartArea"></SubmitBtn>
+            <SubmitBtn desc="时间占比" @click="funTimeArea"></SubmitBtn>
+            <SubmitBtn desc="额定功率" @click="funPower"></SubmitBtn>
+          </div>
+          <div class="p-[10px]">
+            <CurrentScatterChart
+              ref="chartRef"
+              width="100%"
+              :height="`calc( ${tableHeight} - 40px )`"
+              chartTitle=""
+              :xAxisData="xAxisData"
+              :yAxisData="{ splitLine: { show: false } }"
+              :seriesData="seriesData"
+              :showLegend="true"
+              :brushSelected="!isChartArea"
+              :dataSet="dataSet"
+              @getSelected="funChartSelect"
+            />
+          </div>
+        </div>
+      </div>
+    
+    </div>
+  </div>
+</template>
+<style scoped>
+.s-dialog-body /deep/ .el-dialog__body {
+  padding: 0px 20px;
+}
+</style>