From df4e3452ecdc510faa09c7310ba4857ed432553d Mon Sep 17 00:00:00 2001
From: chenyao <1219716595@qq.com>
Date: Sat, 12 Apr 2025 17:47:19 +0800
Subject: [PATCH] Merge branch 'master' of http://139.196.74.78:10010/r/drone/command-center-dashboard

---
 src/views/Home/EventOverviewDetail/EventOverviewDetailLeft/EventDataAnalysis.vue |   62 ++++++++++++++++++++++---------
 1 files changed, 44 insertions(+), 18 deletions(-)

diff --git a/src/views/Home/EventOverviewDetail/EventOverviewDetailLeft/EventDataAnalysis.vue b/src/views/Home/EventOverviewDetail/EventOverviewDetailLeft/EventDataAnalysis.vue
index 38477bd..0652a8f 100644
--- a/src/views/Home/EventOverviewDetail/EventOverviewDetailLeft/EventDataAnalysis.vue
+++ b/src/views/Home/EventOverviewDetail/EventOverviewDetailLeft/EventDataAnalysis.vue
@@ -1,12 +1,10 @@
 <template>
-	<!-- <common-title title="行业数据分析" /> -->
 	<div class="event-data-analysis">
 		<div class="little-title">行业数据分析</div>
 		<div class="chart" ref="echartsRef"></div>
 	</div>
 </template>
 <script setup>
-// import CommonTitle from '@/components/CommonTitle.vue'
 import { getEventIndustryData } from '@/api/home/event'
 import * as echarts from 'echarts'
 
@@ -18,6 +16,15 @@
 		trigger: 'axis',
 		axisPointer: {
 			type: 'shadow',
+		},
+		formatter: function (params) {
+			let result = ''
+			params.forEach(item => {
+				const color = item.color.colorStops[1].color
+				const marker = `<span style="display:inline-block;margin-right:5px;border-radius:50%;width:10px;height:10px;background-color:${color};"></span>`
+				result += `${marker}${item.seriesName}: ${item.value}<br/>`
+			})
+			return result
 		},
 	},
 	grid: {
@@ -65,18 +72,36 @@
 	series: [],
 }
 
-const testObj = color => ({
-	type: 'bar',
-	emphasis: {
-		focus: 'series',
-	},
-	itemStyle: { color },
-	data: [],
-})
+const seriesObj = (colorList) =>{
+	const offsets = [0,1,1]
+	return {
+		type: 'bar',
+		barWidth: 6,
+		emphasis: {
+			focus: 'series',
+		},
+		itemStyle: {
+			color: new echarts.graphic.LinearGradient(
+				0,
+				0,
+				0,
+				1, // 渐变方向从上到下
+				colorList.map((color,index) => ({ offset:offsets[index], color}))
+			),
+		},
+		data: [],
+	}
+}
 
-const eventType = [
-	{ name: '事件', ...testObj('#6FCAFF') },
-	{ name: '任务', ...testObj('#8EFFAC') },
+const seriesList = [
+	{
+		name: '事件',
+		...seriesObj(['#FFFFFF','rgba(44,134,240,0.48)','#DDECFD']),
+	},
+	{
+		name: '任务',
+		...seriesObj(['#FFFFFF', 'rgba(33,218,229,0.48)', '#E5FEFF']),
+	},
 ]
 const params = inject('eventOverviewParams')
 
@@ -90,17 +115,17 @@
 	const list = res?.data?.data || []
 	echartsOption.xAxis.data = list.map(item => item.name)
 	//
-	eventType.forEach(item => {
+	seriesList.forEach(item => {
 		item.data = []
 	})
 	list.forEach(item => {
 		item.data.forEach(item1 => {
-			eventType.forEach(item2 => {
+			seriesList.forEach(item2 => {
 				item2.name === item1.name && item2.data.push(item1.value)
 			})
 		})
 	})
-	echartsOption.series = eventType
+	echartsOption.series = seriesList
 	chart.setOption(echartsOption)
 }
 
@@ -112,15 +137,16 @@
 </script>
 <style scoped lang="scss">
 .event-data-analysis {
-	height: 330px;
+	height: 280px;
+
 	.little-title {
 		background: url('@/assets/images/little-title-bg.png') no-repeat center / 100% 100%;
 		width: 372px;
 		height: 28px;
 		line-height: 28px;
 		padding-left: 16px;
-		
 	}
+
 	.chart {
 		margin-top: 10px;
 		width: 356px;

--
Gitblit v1.9.3