diff --git a/src/app/pages/criminal-records/criminal-records.component.html b/src/app/pages/criminal-records/criminal-records.component.html
index cf769ea..aa55342 100644
--- a/src/app/pages/criminal-records/criminal-records.component.html
+++ b/src/app/pages/criminal-records/criminal-records.component.html
@@ -57,8 +57,29 @@
-
+
+
+
+
+ 违规事件统计
+
+
+
+
+
+
+
+
+
+ 违规趋势
+
+
+
+
@@ -102,7 +123,7 @@
加油区2号摄像头
- 2021-10-12 09:28:13
+ 2021-10-12 09:28:13
查看
@@ -117,4 +138,4 @@
-
+
\ No newline at end of file
diff --git a/src/app/pages/criminal-records/criminal-records.component.scss b/src/app/pages/criminal-records/criminal-records.component.scss
index 99713ae..ec459a9 100644
--- a/src/app/pages/criminal-records/criminal-records.component.scss
+++ b/src/app/pages/criminal-records/criminal-records.component.scss
@@ -10,7 +10,7 @@
padding: 0 36px;
width: 100%;
height: 32px;
- margin: 20px 0px;
+ margin-top: 14px;
form {
width: 100%;
@@ -47,7 +47,7 @@
overflow: hidden;
.title {
- margin-bottom: 15px;
+ margin: 13px 0;
width: 100%;
height: 64px;
box-sizing: border-box;
@@ -59,10 +59,99 @@
display: flex;
justify-content: center;
- .charts {
- width: 98%;
- height: 300px;
- border: 1px solid white;
+ .chart {
+ width: 97%;
+ height: 360px;
+ border: 0px;
+ box-shadow: 0 0 26px 0px #1a7fd7 inset;
+ box-sizing: border-box;
+ padding: 18px 26px;
+ display: flex;
+
+ div {
+ display: flex;
+ flex-direction: column;
+
+ span {
+ font-family: titlefont;
+ display: flex;
+ align-items: center;
+ height: 28px;
+ color: #bee1ff;
+ font-size: 16px;
+ }
+
+ div {
+ flex: 1;
+ }
+
+ .piechart {}
+
+ .barchart {
+ // border: 1px solid rgba(145, 204, 255, 0.95);
+ }
+ }
+
+ .leftbox {
+ width: 360px;
+ position: relative;
+
+ .centerContent {
+ position: absolute;
+ top: 42%;
+ left: 11%;
+ width: 170px;
+
+ div {
+ text-align: center;
+ }
+
+ .numname {
+ font-family: titlefont;
+ color: #bee1ff;
+ }
+
+ .num {
+ color: #FFFFFF;
+ font-size: 42px;
+ text-shadow: 0px 0px 16px #3A9AFF;
+ font-weight: bold;
+ height: 49px;
+ line-height: 50px;
+ }
+ }
+ }
+
+ .rightbox {
+ flex: 1;
+ position: relative;
+
+ .btnbox {
+ position: absolute;
+ right: 5px;
+ top: 5px;
+ display: flex;
+ flex-direction: row;
+ z-index: 999;
+
+ button {
+ border: 1px solid #91CCFF;
+ color: #91CCFF;
+ border-radius: 0px;
+ box-shadow: 0 0 5px 0 #2399FF inset;
+ background: none;
+ }
+
+ .rankingBtn {
+ margin-right: 16px;
+ }
+
+ .selectedbtn {
+ background: linear-gradient(180deg, #000D21 0%, #001331 27%, #2399FF 100%);
+ color: white;
+ }
+ }
+ }
}
}
diff --git a/src/app/pages/criminal-records/criminal-records.component.ts b/src/app/pages/criminal-records/criminal-records.component.ts
index e396d37..727604e 100644
--- a/src/app/pages/criminal-records/criminal-records.component.ts
+++ b/src/app/pages/criminal-records/criminal-records.component.ts
@@ -1,5 +1,6 @@
import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
+import * as echarts from 'echarts';
@Component({
selector: 'app-criminal-records',
templateUrl: './criminal-records.component.html',
@@ -8,7 +9,120 @@ import { FormBuilder, FormGroup, Validators } from '@angular/forms';
export class CriminalRecordsComponent implements OnInit {
validateForm!: FormGroup;
constructor(private fb: FormBuilder) { }
+ mybarChart: any //柱状图
+ baroption = {
+ xAxis: {
+ type: 'category',
+ data: this.getThirtyDays(),
+ axisLine: {
+ show: false,
+ lineStyle: {
+ color: '#91CCFF'
+ }
+ },
+ axisTick: {//刻度线
+ show: false
+ }
+ },
+ yAxis: {
+ type: 'value',
+ nameTextStyle: {
+ color: '#C4E2FC'
+ },
+ splitLine: {//分割线
+ lineStyle: {
+ color: ['#0f4374'],
+ width: 2
+ }
+ },
+ axisTick: {//刻度线
+ show: false
+ },
+ axisLine: {//轴线
+ show: false,
+ lineStyle: {
+ color: '#C4E2FC'
+ }
+ }
+ },
+ series: [
+ {
+ data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
+ type: 'bar',
+ itemStyle: {
+ color: {
+ type: 'linear',
+ x: 0,
+ y: 0,
+ x2: 0,
+ y2: 1,
+ colorStops: [{
+ offset: 0, color: '#23F0FF' // 0% 处的颜色
+ }, {
+ offset: 1, color: 'rgba(35, 153, 255, 0.1)' // 100% 处的颜色
+ }],
+ global: false // 缺省为 false
+ }
+ },
+ barWidth: '25%'
+ },
+ {
+ data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
+ type: 'line',
+ symbol: 'circle',
+ symbolSize: 8,
+ itemStyle: {
+ color: '#fff',
+ shadowColor: '#fff',
+ shadowBlur: 10
+ },
+ lineStyle: {
+ color: '#FFCC8A',
+ width: 1
+ }
+ }
+ ],
+ grid: {
+ left: '36px',
+ right: '30px',
+ bottom: '50px',
+ top: '45px'
+ }
+ };
+ getThirtyDays() {
+ //获取当前日期
+ let myDate = new Date();
+ var nowY = myDate.getFullYear();
+ var nowM = myDate.getMonth() + 1;
+ var nowD = myDate.getDate();
+ var enddateStr = nowY + "-" + (nowM < 10 ? "0" + nowM : nowM) + "-" + (nowD < 10 ? "0" + nowD : nowD);//当前日期
+ var enddate = new Date(enddateStr);
+
+ //获取三十天前日期
+ var lw = new Date(new Date().getTime() - 1000 * 60 * 60 * 24 * 30);//最后一个数字30可改,30天的意思
+ var lastY = lw.getFullYear();
+ var lastM = lw.getMonth() + 1;
+ var lastD = lw.getDate();
+ var startdateStr = lastY + "-" + (lastM < 10 ? "0" + lastM : lastM) + "-" + (lastD < 10 ? "0" + lastD : lastD);//三十天之前日期
+ var startDate = new Date(startdateStr);
+
+ const dateList = []
+ while (true) {
+ startDate.setDate(startDate.getDate() + 1)
+ if (startDate.getTime() <= enddate.getTime()) {
+ if (startDate.getDate() < 10) {
+ // startDate.getFullYear() 获取年,此处没加上年份
+ dateList.push((startDate.getMonth() + 1) + '.0' + startDate.getDate())
+ } else {
+ dateList.push((startDate.getMonth() + 1) + '.' + startDate.getDate())
+ }
+ } else {
+ break
+ }
+ }
+ return dateList;
+ }
ngOnInit(): void {
this.validateForm = this.fb.group({
level: [null],
@@ -16,6 +130,75 @@ export class CriminalRecordsComponent implements OnInit {
site: [null],
datePicker: [null]
});
+ // 基于准备好的dom,初始化echarts实例
+ let myChart = echarts.init(document.getElementById('piechart'));
+ let option = {
+ color: ['#FF4B65', '#23D9FF', '#608AFF', '#B2FF6D', '#FFFF99', '#C4E2FC', '#FF7F00', '#0090FF', '#FFD634', '#105597', '#FF4B65', '#23D9FF', '#71FFF5', '#B2FF6D'],
+ tooltip: {
+ trigger: 'item'//触发类型
+ },
+ series: [
+ {
+ // name: 'Access From',
+ type: 'pie',
+ radius: [85, 112],//内半径外,外半径
+ left: '-30%',
+ avoidLabelOverlap: false,//防止标签重叠策略
+ label: {//每一个标签外网延伸的引导说明
+ show: false,
+ position: 'outside'
+ },
+ labelLine: {//引导线
+ show: true,
+ showAbove: true
+ },
+ emphasis: {//中间高亮区域
+ label: {
+ show: false,
+ fontSize: '40',
+ fontWeight: 'bold'
+ }
+ },
+ data: [
+ { value: 26, name: '工作人员倚靠加油机或者立柱1' },
+ { value: 86, name: '工作人员倚靠加油机或者立柱2' },
+ { value: 34, name: '工作人员倚靠加油机或者立柱3' },
+ { value: 55, name: '工作人员倚靠加油机或者立柱4' },
+ { value: 60, name: '工作人员倚靠加油机或者立柱5' },
+ { value: 26, name: '工作人员倚靠加油机或者立柱6' },
+ { value: 86, name: '工作人员倚靠加油机或者立柱7' },
+ { value: 34, name: '工作人员倚靠加油机或者立柱8' },
+ { value: 55, name: '工作人员倚靠加油机或者立柱9' },
+ { value: 60, name: '工作人员倚靠加油机或者立柱10' },
+ { value: 26, name: '工作人员倚靠加油机或者立柱11' },
+ { value: 86, name: '工作人员倚靠加油机或者立柱12' },
+ { value: 34, name: '工作人员倚靠加油机或者立柱13' },
+ { value: 55, name: '工作人员倚靠加油机或者立柱14' },
+ { value: 60, name: '工作人员倚靠加油机或者立柱15' },
+ { value: 26, name: '工作人员倚靠加油机或者立柱16' },
+ { value: 86, name: '工作人员倚靠加油机或者立柱17' },
+ { value: 34, name: '工作人员倚靠加油机或者立柱18' },
+ { value: 55, name: '工作人员倚靠加油机或者立柱19' },
+ { value: 60, name: '工作人员倚靠加油机或者立柱20' }
+ ],
+ tooltip: {//鼠标移入提示
+ position: 'right',
+ padding: [14, 19],
+ backgroundColor: 'rgba(28, 129, 218, 0.4)',
+ textStyle: {
+ color: '#fff',
+ fontSize: 12
+ }
+ }
+ }
+ ]
+ };
+ // 绘制图表
+ myChart.setOption(option);
+
+ this.mybarChart = echarts.init(document.getElementById('barchart'));
+
+ this.mybarChart.setOption(this.baroption);
}
submitForm(): void {
for (const i in this.validateForm.controls) {
diff --git a/src/app/pages/home/home.component.html b/src/app/pages/home/home.component.html
index 78973af..49d7d83 100644
--- a/src/app/pages/home/home.component.html
+++ b/src/app/pages/home/home.component.html
@@ -3,21 +3,25 @@