@@ -38,9 +38,11 @@ import { number } from 'echarts';
},
methods: {
- selectItem(index,num){
+ selectItem(index,num,item){
this.selectIndex = index;
- this.selectLine = num
+ this.selectLine = num;
+ if ( item )
+ this.$emit("selectItem",item);
}
},
mounted() {
@@ -147,7 +149,7 @@ import { number } from 'echarts';
>.item {
position: relative;
- width: 180px;
+ width: 113px;
height:35px;
display: inline-flex;
flex-direction: column;
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/assets/charts.js b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/assets/charts.js
index 7c16f575..2fdc8690 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/assets/charts.js
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/assets/charts.js
@@ -15,6 +15,9 @@ let data = [{
typeName:'护栏碰撞',
percent:0.14
}]
+
+window.mainData = data;
+
let chartData = [],lengData=[], colorList = ['#006EDF', '#00FF00', '#FFC30D', '#FF8400', '#1DA7FF','#2967EA'];
for (let i = 0; i < data.length; i++) {
chartData.push({
@@ -55,6 +58,8 @@ for (let i = 0; i < chartData.length; i++) {
});
pieData1.push(gapData);
}
+console.log(pieData1);
+
var options = {
tooltip: {
confine: true,
@@ -115,10 +120,13 @@ var options = {
formatter: function(name){
let total = 0
let target
+ if ( !mainData ) return "";
for (let i = 0; i < data.length; i++) {
- total += data[i].average
- if (data[i].typeName === name) {
- target = data[i].average
+ if ( window.mainData[i] ) {
+ total += window.mainData[i].value
+ if ( window.mainData[i].name === name) {
+ target = window.mainData[i].value
+ }
}
}
var arr = [
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/index.vue b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/index.vue
index 5f59fb55..b47d769d 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/index.vue
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/eventSource/index.vue
@@ -12,6 +12,8 @@
import WgtTitle from '../../../widgets/title'
import * as echarts from "echarts";
import chartsStatistics from "./assets/charts";
+ import { getWarningSourceGroup } from '../../../../../../../api/event/perceiveEvent';
+
export default {
name: 'EventSource',
components: {
@@ -36,30 +38,74 @@
let currentIndex = -1;
this.$nextTick(() => {
var myChart = echarts.init(document.getElementById('eventSource'));
- myChart.setOption(chartsStatistics);
- this.myChart = myChart;
- myChart.on('mouseover', (params) => {
- // oldIndex = currentIndex;
- currentIndex = params.dataIndex;
- highlightPie(currentIndex,oldIndex);
- })
+ getWarningSourceGroup().then((res)=>{
+ if ( res.code == 200 ) {
+ let data = res.data;
+ let warningTypes = [];
+ let number = [];
+ data.forEach(it=>{
+ if ( it.warningSource == 1) {
+ warningTypes.push('交通拥堵');
+ }
+ if ( it.warningSource == 2) {
+ warningTypes.push('行人');
+ }
+ if ( it.warningSource == 3) {
+ warningTypes.push('非机动车');
+ }
+ if ( it.warningSource == 4) {
+ warningTypes.push('停车');
+ }
+ if ( it.warningSource == 5) {
+ warningTypes.push('倒车/逆行');
+ }
+ if ( it.warningSource == 6) {
+ warningTypes.push('烟火');
+ }
+ if ( it.warningSource == 7) {
+ warningTypes.push('撒落物');
+ }
+ if ( it.warningSource == 8) {
+ warningTypes.push('异常天气');
+ }
+ if ( it.warningSource == 9) {
+ warningTypes.push('护栏碰撞');
+ }
- function highlightPie(currentIndex,oldIndex) {
- myChart.dispatchAction({
- type: 'downplay',
- seriesIndex: 1,
- dataIndex: oldIndex
- })
- myChart.dispatchAction({
- type: 'highlight',
- seriesIndex: 1,
- dataIndex: currentIndex
- })
+ number.push(it.number);
+ })
+ let colorList = ['#006EDF', '#00FF00', '#FFC30D', '#FF8400', '#1DA7FF','#2967EA'];
+ let lengData = [];
+ let mainData = [];
+ let mainCount = 0;
+ for (let j =0;j < number.length;j++){
+ mainCount+= number[j];
+ }
+ for (let i = 0;i < warningTypes.length;i++){
+ let it = warningTypes[i];
+ lengData.push({
+ name:it,
+ color:colorList[i],
+ value:number[i],
+ });
+ mainData.push({
+ name:it,
+ color:colorList[i],
+ value:number[i],
+ percent: number[i]/mainCount
+ })
+ }
+ window.mainData = mainData;
+ console.log("--------------",mainData);
+ chartsStatistics.legend.data = lengData;
+ chartsStatistics.series[0].data = mainData;
}
- setTimeout(()=>{
-
- },50)
+ myChart.setOption(chartsStatistics);
+ })
+
+ this.myChart = myChart;
+
});
});
},
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/monthStatistics/index.vue b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/monthStatistics/index.vue
index 797801a7..11f5fb6b 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/monthStatistics/index.vue
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/monthStatistics/index.vue
@@ -12,6 +12,8 @@
import WgtTitle from '../../../widgets/title'
import * as echarts from "echarts";
import chartsStatistics from "./assets/charts";
+ import { getDailyCumulativeMonth } from '../../../../../../../api/event/perceiveEvent';
+
export default {
name: 'MonthStatistics',
components: {
@@ -33,7 +35,34 @@
setTimeout(() => {
this.$nextTick(() => {
var myChart = echarts.init(document.getElementById('monthStatistics'));
- myChart.setOption(chartsStatistics);
+ getDailyCumulativeMonth().then((res)=>{
+ console.log(res);
+ if ( res.code == 200 ) {
+ let data = res.data;
+ let timeData = [];
+ let datasN = [];
+ for (var i = 0; i < 24;i++){
+ let k = 0;
+ for (var j = 0;j < data.length;j++){
+ let it = data[j];
+ if ( it.time == i ) {
+ timeData.push( i +"点至"+ (i +1)+"点");
+ datasN.push(it.number);
+ k++;
+ }
+ }
+ if ( k == 0 ) {
+ timeData.push( i +"点至"+ (i +1)+"点");
+ datasN.push(0);
+ }
+ }
+ chartsStatistics.xAxis.data = timeData;
+ chartsStatistics.series[0].data = datasN;
+
+ myChart.setOption(chartsStatistics);
+ }
+
+ });
});
});
},
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/assets/charts.js b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/assets/charts.js
index 2ef9faf8..d3b60046 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/assets/charts.js
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/assets/charts.js
@@ -1,9 +1,9 @@
let chartIcon = ``;
let xdata = {
- value: ['平阴停车区', '孔村枢纽', '平阴南收费站', '东平湖枢纽', '沙河停车区', '梁山东收费站', '王官屯枢纽']
+ value: ['平阴停车区']
};
let sdata = {
- value: [32774, 30067, 28774, 30067, 30021, 30067, 32774]
+ value: [32774]
}
let dataZoomMove = {
@@ -49,7 +49,7 @@ var options = {
margin:-5,
formatter: function (value) {
let index = xdata.value.indexOf(value);
- return `{a|Top${index+1}} {b|${value}}`
+ return `{a|Top${index + 2}} {b|${value}}`
},
rich: {
a: {
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/index.vue b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/index.vue
index 1e39f500..ec5339e9 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/index.vue
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railway/index.vue
@@ -16,6 +16,8 @@
import WgtTitle from '../../../widgets/title'
import * as echarts from "echarts";
import chartsStatistics from "./assets/charts";
+ import { getSectionPerceivedList } from '../../../../../../../api/event/perceiveEvent';
+
export default {
name: 'Situation',
components: {
@@ -31,7 +33,27 @@
setTimeout(() => {
this.$nextTick(() => {
var myChart = echarts.init(document.getElementById('situationEchartBox'));
- myChart.setOption(chartsStatistics);
+
+ getSectionPerceivedList({}).then((res)=>{
+ console.log(res);
+ if ( res.code == 200 ) {
+ let data = res.data;
+ let texts = [];
+ let datas = [];
+
+ data.forEach(it => {
+ texts.push(it.sectionName);
+ datas.push(it.number);
+ });
+
+ chartsStatistics.yAxis[0].data = texts;
+ chartsStatistics.series[0].data = datas;
+
+ myChart.setOption(chartsStatistics);
+ }
+ });
+
+
});
});
},
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/assets/charts.js b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/assets/charts.js
index d5ab305c..59186783 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/assets/charts.js
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/assets/charts.js
@@ -68,9 +68,7 @@ var options = {
yAxis: [{
type: 'value',
name: "",
- max: 1000,
- min:0,
- splitNumber:5,
+
nameTextStyle: {
color: '#B6E6FF',
fontSize: 13,
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/index.vue b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/index.vue
index b6e39c92..85b0f9a3 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/index.vue
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/railwayDay/index.vue
@@ -12,6 +12,8 @@
import WgtTitle from '../../../widgets/title'
import * as echarts from "echarts";
import chartsStatistics from "./assets/charts";
+import { getSectionPerceivedNumber } from '../../../../../../../api/event/perceiveEvent';
+
export default {
name: 'RailWayDay',
components: {
@@ -33,7 +35,23 @@ export default {
setTimeout(() => {
this.$nextTick(() => {
var myChart = echarts.init(document.getElementById('railwayDay'));
- myChart.setOption(chartsStatistics);
+ getSectionPerceivedNumber().then((res)=>{
+ if ( res.code == 200 ) {
+ let data = res.data;
+ let texts = [];
+ let datas = [];
+
+ data.forEach(it => {
+ texts.push(it.sectionName);
+ datas.push(it.number);
+ });
+
+ chartsStatistics.xAxis.data = texts;
+ chartsStatistics.series[0].data = datas;
+
+ myChart.setOption(chartsStatistics);
+ }
+ })
});
});
},
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/assets/charts.js b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/assets/charts.js
index 4936251f..b6dfeb33 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/assets/charts.js
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/assets/charts.js
@@ -1,4 +1,4 @@
-const echartsData = [
+window.typeAnalysisData = [
{ value: 100, name: '行人' },
{ value: 90, name: '非机动车' },
{ value: 80, name: '拥堵' },
@@ -6,7 +6,7 @@ const echartsData = [
{ value: 50, name: '抛洒物' },
{ value: 45, name: '烟火' }]
-const colorList = [
+window.colorList = [
"#019AFF",
"#3CC3F0",
"#51D5AD",
@@ -14,14 +14,14 @@ const colorList = [
"#F6A73C",
"#7390FD",]
-const colorList1 = [
+window.colorList1 = [
"#61D8FF",
"#FFB905",
"#6AE0BC",]
- let count = 0;
+window.count = 0;
- echartsData.forEach((it)=>{
+typeAnalysisData.forEach((it)=>{
count += it.value;
})
@@ -30,9 +30,9 @@ var options = {
color: colorList,
legend: {
orient: 'vertical',
- top: "center",
+ top: "10",
icon: "circle",
- right: 30,
+ right: 40,
itemGap: 16,
itemWidth: 8,
itemHeight: 8,
@@ -54,11 +54,11 @@ var options = {
}
},
formatter: (params) => {
- let obj = echartsData.filter(it=>{ return it.name == params})
+ let obj = typeAnalysisData.filter(it=>{ return it.name == params})
console.log(obj);
return `{ast|${obj[0].name}} {bst|${Math.round(obj[0].value/count* 100) }%}`
},
- data: echartsData?.map(x => x.name),
+ data: typeAnalysisData?.map(x => x.name),
},
tooltip: {
trigger: 'item',
@@ -96,7 +96,7 @@ var options = {
length: 10,
length2: 30,
},
- data: echartsData.map((item, index) => {
+ data: typeAnalysisData.map((item, index) => {
return {
...item,
label: {
@@ -139,7 +139,7 @@ var options = {
length: 10,
length2: 30,
},
- data: echartsData.map((item, index) => {
+ data: typeAnalysisData.map((item, index) => {
return {
...item,
label: {
diff --git a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/index.vue b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/index.vue
index b0af834d..6fc6e6f3 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/index.vue
+++ b/ruoyi-ui/src/views/JiHeExpressway/pages/perception/eventDetection/components/typeAnalysis/index.vue
@@ -12,6 +12,7 @@
import WgtTitle from '../../../widgets/title'
import * as echarts from "echarts";
import chartsStatistics from "./assets/charts";
+ import { getWarningTypeDay } from '../../../../../../../api/event/perceiveEvent';
const drawRoundRect = ( ctx, x, y, width, height, radius ,gr) => {
@@ -52,9 +53,95 @@
setTimeout(() => {
this.$nextTick(() => {
var myChart = echarts.init(document.getElementById('typeAnalysis'));
- myChart.setOption(chartsStatistics);
+
+
+ getWarningTypeDay().then(res=>{
+ console.log(res);
+ if ( res.code == 200 ) {
+ let data = res.data;
+ console.log("===================",data);
+ typeAnalysisData = [];
+ for (var i = 0;i < data.length;i++){
+ var it = data[i];
+ if ( it.warningType == 1) {
+ typeAnalysisData.push({
+ name:'交通拥堵',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 2) {
+ typeAnalysisData.push({
+ name:'行人',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 3) {
+ typeAnalysisData.push({
+ name:'非机动车',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 4) {
+ typeAnalysisData.push({
+ name:'停车',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 5) {
+ typeAnalysisData.push({
+ name:'倒车/逆行',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 6) {
+ typeAnalysisData.push({
+ name:'烟火',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 7) {
+ typeAnalysisData.push({
+ name:'撒落物',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 8) {
+ typeAnalysisData.push({
+ name:'异常天气',
+ value:it.number
+ });
+ }
+ if ( it.warningType == 9) {
+ typeAnalysisData.push({
+ name:'护栏碰撞',
+ value:it.number
+ });
+ }
+ drawRoundRect(context, 260, 8 + i * 28, 120, 24, 12,gr)
+ }
+ chartsStatistics.legend.data = typeAnalysisData?.map(x => x.name);
+ chartsStatistics.series[0].data = typeAnalysisData.map((item, index) => {
+ return {
+ ...item,
+ label: {
+ color: colorList[index]
+ }
+ }
+ })
+ chartsStatistics.series[1].data = typeAnalysisData.map((item, index) => {
+ return {
+ ...item,
+ label: {
+ color: colorList[index]
+ }
+ }
+ })
+ }
+
+ myChart.setOption(chartsStatistics);
+ })
const domMap = document.getElementById("typeAnalysis");
let parentDiv = domMap.firstChild;
@@ -75,12 +162,12 @@
context.lineWidth = 1; // 设置线段宽度
// 绘制圆角矩形
- drawRoundRect(context, 260, 8, 120, 24, 12,gr)
- drawRoundRect(context, 260, 36, 120, 24, 12,gr)
- drawRoundRect(context, 260, 64, 120, 24, 12,gr)
- drawRoundRect(context, 260, 92, 120, 24, 12,gr)
- drawRoundRect(context, 260, 120, 120, 24, 12,gr)
- drawRoundRect(context, 260, 148, 120, 24, 12,gr)
+
+ // drawRoundRect(context, 260, 36, 120, 24, 12,gr)
+ // drawRoundRect(context, 260, 64, 120, 24, 12,gr)
+ // drawRoundRect(context, 260, 92, 120, 24, 12,gr)
+ // drawRoundRect(context, 260, 120, 120, 24, 12,gr)
+ // drawRoundRect(context, 260, 148, 120, 24, 12,gr)
});
});
},
diff --git a/ruoyi-ui/src/views/JiHeExpressway/scss/el-reset.scss b/ruoyi-ui/src/views/JiHeExpressway/scss/el-reset.scss
index c2eb91b6..81a27a5f 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/scss/el-reset.scss
+++ b/ruoyi-ui/src/views/JiHeExpressway/scss/el-reset.scss
@@ -1,3 +1,10 @@
+.loading-message {
+ background-color: #265a70;
+ border: 0;
+ > i {
+ margin-right: 9px;
+ }
+}
div.el-popper {
background: linear-gradient(180deg, #005c79 0%, #009bcc 100%);
color: #fff;
@@ -475,3 +482,15 @@ body {
}
}
}
+
+div.el-popper.global-input-search-popover {
+ background: #064258;
+
+ .footer {
+ display: flex;
+ align-items: center;
+ justify-content: flex-end;
+ gap: 9px;
+ margin-top: 15px;
+ }
+}
diff --git a/ruoyi-ui/src/views/JiHeExpressway/utils/enum.js b/ruoyi-ui/src/views/JiHeExpressway/utils/enum.js
index d1bcf687..b5c77361 100644
--- a/ruoyi-ui/src/views/JiHeExpressway/utils/enum.js
+++ b/ruoyi-ui/src/views/JiHeExpressway/utils/enum.js
@@ -71,3 +71,113 @@ export const CameraControlTypeEnum = {
text: "枪机",
},
};
+
+export const EventTopics = {
+ 交通事故: 1,
+ 车辆故障: 2,
+ 交通管制: 3,
+ 交通拥堵: 4,
+ 非法上路: 5,
+ 路障清除: 6,
+ 施工建设: 7,
+ 服务区异常: 8,
+ 设施设备隐患: 9,
+ 异常天气: 10,
+ 其他事件: 11,
+};
+
+// 事件类型 eventType
+export const EventType = {
+ 0: "待确认",
+ 1: "处理中",
+ 2: "已完成",
+};
+
+// 信息来源 warningSource
+export const InfoWarningSource = {
+ 1: {
+ text: "视频AI",
+ },
+ 2: {
+ text: "雷达识别",
+ },
+ 3: {
+ text: "锥桶",
+ },
+ 4: {
+ text: "护栏碰撞",
+ },
+ 5: {
+ text: "扫码报警",
+ },
+ 6: {
+ text: "非机预警",
+ },
+};
+
+// 事件主类 warningType
+export const WarningType = {
+ 1: "交通拥堵",
+ 2: "行人",
+ 3: "非机动车",
+ 4: "停车",
+ 5: "倒车/逆行",
+ 6: "烟火",
+ 7: "撒落物",
+ 8: "异常天气",
+ 9: "护栏碰撞",
+};
+
+// 事件主类的子类(上方) warningSubclass
+export const WarningSubclass = {
+ 1: {
+ "1-1": "拥堵",
+ "1-2": "缓行",
+ },
+ 2: {
+ "2-1": "普通行人",
+ "2-2": "工作人员",
+ },
+ 3: {
+ "3-1": "摩托车",
+ "3-2": "自行车",
+ "3-3": "三轮车",
+ },
+ 4: {
+ "4-1": "非工程车",
+ "4-2": "工程车",
+ "4-3": "主路有车",
+ "4-4": "匝道有车",
+ "4-5": "车辆故障",
+ "4-6": "交通事故",
+ "4-7": "应急车道被占用",
+ "4-8": "车离开应急车道",
+ "4-9": "其他",
+ },
+ 5: {
+ "5-1": "倒车_逆行",
+ },
+ 6: {
+ "6-1": "烟火",
+ },
+ 7: {
+ "7-1": "撒落物",
+ },
+ 8: {
+ "8-1": "雨",
+ "8-2": "冰雹",
+ "8-3": "风",
+ "8-4": "雾",
+ "8-5": "高温",
+ "8-6": "积水",
+ "8-7": "路面湿滑",
+ "8-8": "路面结冰",
+ "8-9": "道路能见度低",
+ "8-10": "道路团雾",
+ },
+ 9: {
+ "9-1": "只碰撞不倾斜",
+ "9-2": "只倾斜无碰撞",
+ "9-3": "碰撞后倾斜",
+ },
+};