/* * @Descripttion: * @version: * @Author: sueRimn * @Date: 2020-09-02 16:21:18 * @LastEditors: sueRimn * @LastEditTime: 2020-11-17 14:13:12 */ import { Component, OnInit, ViewChild } from '@angular/core'; import { Router } from '@angular/router'; import { MatDatepickerInputEvent } from '@angular/material/datepicker'; import { MatSnackBarConfig, MatSnackBar } from '@angular/material/snack-bar'; import { DateAdapter } from '@angular/material/core'; import {EchartsDataService,} from '../../echarts-data.service' declare var echarts: any; @Component({ selector: 'app-delete-two', templateUrl: './delete-two.component.html', styleUrls: ['./delete-two.component.scss'] }) export class DeleteTwoComponent implements OnInit { options:any; datayuex=['一月', '二月', '三月', '四月', '五月', '六月', '七月','八月','九月']; datayuey=[210, 160, 150, 140, 130, 120, 110,120,150]; datanianx=[2019,2020]; dataniany=[201,174] tiaoshiPao:any//气泡 constructor(private router: Router,public snackBar: MatSnackBar,private adapter: DateAdapter,public echartsData:EchartsDataService) { } /* @ViewChild('appEcharts')appEcharts :echartsComponent; //父组件中获得子组件的引用 @ViewChild('pageTwoName')pageTwoName :PageTwoNameComponent; //父组件中获得子组件的引用 */ ngOnInit(): void { this.echartsData.statefulInspectionToggle=true this.dateInit() this.tiaoshiPao=this.echartsData.qipao(this.tiaoshiPao,this.datayuey,this.datayuex) //this.bianli() window.setTimeout(()=>{ this.headZhexian('Line','删除数量总统计',this.datayuex,this.datayuey) /* this.headZhexian('leftOne','高层',this.datayuex,this.datayuey) this.headZhexian('leftTwo','轨道交通',this.datayuex,this.datayuey) this.headZhexian('leftThere','储罐类',this.datayuex,this.datayuey) this.headZhexian('leftFour','古建筑',this.datayuex,this.datayuey) this.headZhexian('rightOne','地下',this.datayuex,this.datayuey) this.headZhexian('rightTwo','化工生产',this.datayuex,this.datayuey) this.headZhexian('rightThree','厂房',this.datayuex,this.datayuey) this.headZhexian('rightFour','商市场',this.datayuex,this.datayuey) */ /* else if(this.selectType=='year'){ this.headZhexian('heads','删除数量总统计',this.datanianx,this.dataniany) this.headZhexian('leftOne','高层',this.datayuex,this.datayuey) this.headZhexian('leftTwo','轨道交通',this.datayuex,this.datayuey) this.headZhexian('leftThere','储罐类',this.datayuex,this.datayuey) this.headZhexian('leftFour','古建筑',this.datayuex,this.datayuey) this.headZhexian('rightOne','地下',this.datayuex,this.datayuey) this.headZhexian('rightTwo','化工生产',this.datayuex,this.datayuey) this.headZhexian('rightThree','厂房',this.datayuex,this.datayuey) this.headZhexian('rightFour','商市场',this.datayuex,this.datayuey) } */ },0) } ngOnDestroy():void{ this.headZx.clear() this.headZx.dispose() } selectType:string = 'month'; //选择当前的 查询类型 按月/年 headZx//echarts实例 zhiNameData = ["浦东支队","黄浦支队","徐汇支队","长宁支队","静安支队","普陀支队","虹口支队","杨浦支队","闵行支队","宝山支队","嘉定支队","松江支队","金山支队","崇明支队"] zhiNumData = [200,190,180,170,160,150,140,130,120,110,100,90,80,70] //查询数据 years:any = [] selectMonth:any = [1,2,3,4,5,6,7,8,9,10,11,12] //日期初始化 dateInit () { let date = (new Date()).getFullYear() for (let i=date; i>=date-10;i--) { this.years.unshift(i) } } selectOneYear:any = (new Date()).getFullYear() //开始年份 selectTwoYear:any = (new Date()).getFullYear() //结束年份 selectStartMonth:any = 1 //开始月份 selectEndMonth:any = (new Date()).getMonth()+1 //结束月份 //点击月 monthClick(){ this.tiaoshiPao=null this.tiaoshiPao=this.echartsData.qipao(this.tiaoshiPao,this.datayuey,this.datayuex) this.headZhexian('Line','删除数量总统计',this.datayuex,this.datayuey) /* this.headZhexian('leftOne','高层',this.datayuex,this.datayuey) this.headZhexian('leftTwo','轨道交通',this.datayuex,this.datayuey) this.headZhexian('leftThere','储罐类',this.datayuex,this.datayuey) this.headZhexian('leftFour','古建筑',this.datayuex,this.datayuey) this.headZhexian('rightOne','地下',this.datayuex,this.datayuey) this.headZhexian('rightTwo','化工生产',this.datayuex,this.datayuey) this.headZhexian('rightThree','厂房',this.datayuex,this.datayuey) this.headZhexian('rightFour','商市场',this.datayuex,this.datayuey) */ } //按月查询 monthSubmit (e) { this.headZhexian('Line','删除数量总统计',this.datayuex,this.datayuey) /* this.headZhexian('leftOne','高层',this.datayuex,this.datayuey) this.headZhexian('leftTwo','轨道交通',this.datayuex,this.datayuey) this.headZhexian('leftThere','储罐类',this.datayuex,this.datayuey) this.headZhexian('leftFour','古建筑',this.datayuex,this.datayuey) this.headZhexian('rightOne','地下',this.datayuex,this.datayuey) this.headZhexian('rightTwo','化工生产',this.datayuex,this.datayuey) this.headZhexian('rightThree','厂房',this.datayuex,this.datayuey) this.headZhexian('rightFour','商市场',this.datayuex,this.datayuey) */ if (e.selectTwoYear > e.selectOneYear) { let startTime = e.selectOneYear + '-' + e.selectStartMonth + '-' + 1 + ' ' + 0 + ':' + 0 +':'+ 0 let endTime = e.selectTwoYear + '-' + e.selectEndMonth + '-' + 31 + ' ' + 23 + ':' + 59 +':'+ 59 // console.log(startTime) // console.log(endTime) } else if (e.selectTwoYear === e.selectOneYear) { if(e.selectEndMonth >= e.selectStartMonth) { let startTime = e.selectOneYear + '-' + e.selectStartMonth + '-' + 1 + ' ' + 0 + ':' + 0 +':'+ 0 let endTime = e.selectTwoYear + '-' + e.selectEndMonth + '-' + 31 + ' ' + 23 + ':' + 59 +':'+ 59 // console.log(startTime) // console.log(endTime) } else { const config = new MatSnackBarConfig(); config.verticalPosition = 'top'; config.duration = 3000 this.snackBar.open('请选择正确时间区段','确定',config); } }else { const config = new MatSnackBarConfig(); config.verticalPosition = 'top'; config.duration = 3000 this.snackBar.open('请选择正确时间区段','确定',config); } } selectStartYear:any = (new Date()).getFullYear() //开始年份 selectEndYear:any = (new Date()).getFullYear() //结束年份 //点击年 yearClick(){ this.tiaoshiPao=null this.tiaoshiPao=this.echartsData.qipao(this.tiaoshiPao,this.dataniany,this.datanianx) this.headZhexian('Line','删除数量总统计',this.datanianx,this.dataniany) /* this.headZhexian('leftOne','高层',this.datanianx,this.dataniany) this.headZhexian('leftTwo','轨道交通',this.datanianx,this.dataniany) this.headZhexian('leftThere','储罐类',this.datanianx,this.dataniany) this.headZhexian('leftFour','古建筑',this.datanianx,this.dataniany) this.headZhexian('rightOne','地下',this.datanianx,this.dataniany) this.headZhexian('rightTwo','化工生产',this.datanianx,this.dataniany) this.headZhexian('rightThree','厂房',this.datanianx,this.dataniany) this.headZhexian('rightFour','商市场',this.datanianx,this.dataniany) */ } //按年查询 yearSubmit (e) { //console.log(this.selectType) this.headZhexian('Line','删除数量总统计',this.datanianx,this.dataniany) /* this.headZhexian('leftOne','高层',this.datanianx,this.dataniany) this.headZhexian('leftTwo','轨道交通',this.datanianx,this.dataniany) this.headZhexian('leftThere','储罐类',this.datanianx,this.dataniany) this.headZhexian('leftFour','古建筑',this.datanianx,this.dataniany) this.headZhexian('rightOne','地下',this.datanianx,this.dataniany) this.headZhexian('rightTwo','化工生产',this.datanianx,this.dataniany) this.headZhexian('rightThree','厂房',this.datanianx,this.dataniany) this.headZhexian('rightFour','商市场',this.datanianx,this.dataniany) */ if (e.selectEndYear >= e.selectStartYear) { let startTime = e.selectStartYear + '-' + 1 + '-' + 1 + ' ' + 0 + ':' + 0 +':'+ 0 let endTime = e.selectEndYear + '-' + 12 + '-' + 31 + ' ' + 23 + ':' + 59 +':'+ 59 } else { const config = new MatSnackBarConfig(); config.verticalPosition = 'top'; config.duration = 3000 this.snackBar.open('请选择正确时间区段','确定',config); } } //支队查询 zhiFind(){ this.echartsData.dezhiorBuinding="zhi" } //建筑类型查询 buildingFind(){ this.echartsData.dezhiorBuinding="building" } //返回 goBack(){ history.go(-1) } /** * @name: 折线图 * @test: test font * @msg: * @param {divid(传入的div),headtext(标题)} * @return {type} */ headZhexian(divid:string,headtext:string,datayuex,datayuey){ var dianji:boolean=headtext=="删除数量总统计" ? false:true; var divsiaze={contentSize: [350, 496], viewSize: [831, 380]} var pagex var pagey var boxsize=[pagex,pagey] /* document.onmouseover=function(e){ console.log("000") pagex=e.pageX pagey=e.pageY } */ var ec = echarts as any; this.headZx = ec.init(document.getElementById(`${divid}`),'skinUpp'); this.options = { grid: { top: 50, left:40, right: 20, bottom: 20, }, // 标题 title: { text: `${headtext}`+':总数(1024)', left:'center', top: -4, //副标题文本样式  subtextStyle:{ color:'#999', fontWeight:'bold', }, textStyle:{ //文字颜色 color:'#000', fontSize:divid=='Line'?30: 22, } }, //提示框 tooltip: { trigger: 'axis', formatter: (params)=>{ return this.echartsData.dezhiorBuinding=="zhi"?this.echartsData.tableTooltip(this.echartsData.tableDataZhi,`${headtext}`):this.echartsData.tableTooltip(this.echartsData.buildingType,`${headtext}`) }, /* backgroundColor:'rgba(255,255,255,1)',//通过设置rgba调节背景颜色与透明度 borderWidth:'1', borderRadius :'0', */ position: this.echartsData.tableTooltipNoShow2 }, xAxis: { type: 'category', boundaryGap:true, data: datayuex, axisLabel: { textStyle:{ fontSize :15, color:'#000000' }, color: "#000", //刻度线标签颜色 }, //设置坐标轴字体颜色和宽度 axisLine: { lineStyle: { color: "#000", }, }, splitLine: {//分割线配置 show:true, lineStyle: { color: '#999', } } }, yAxis: { type: 'value', axisLabel: { textStyle:{ fontSize :15, color:'#000000' }, color: "#000" //刻度线标签颜色 }, //设置坐标轴字体颜色和宽度 axisLine: { lineStyle: { color: "#000", } } }, series: [{ data: datayuey, type: 'line', markPoint: { symbolSize:[65, 65], data: this.tiaoshiPao }, clickable:false, }] }; this.headZx.getZr().on('click', (params) => { // console.log(params.name) /* this.echartsData.statefulInspectionName =params.name+headtext; this.router.navigateByUrl(`/statisticanalysis/delete_one/delete_there`); */ const pointInPixel= [params.offsetX, params.offsetY]; if (this.headZx.containPixel('grid',pointInPixel)) { let xIndex=this.headZx.convertFromPixel({seriesIndex:0},[params.offsetX, params.offsetY])[0]; if(this.options.xAxis.data[xIndex]=='2019'||this.options.xAxis.data[xIndex]=='2020'){ this.router.navigate(['/statisticanalysis/delete_thereLineDetails'],{queryParams:{'level':this.options.xAxis.data[xIndex],'headtext':headtext}}); //this.router.navigate(['/statisticanalysis/delete_two_newadd'],{queryParams:{'level':this.options.xAxis.data[xIndex],'headtext':headtext}}); }else{ /*事件处理代码书写位置*/ //this.router.navigate(['/statisticanalysis/delete_one/delete_there'],{queryParams:{'level':this.options.xAxis.data[xIndex],'headtext':headtext}}); if(this.echartsData.dezhiorBuinding=="zhi"){ this.router.navigate(['/statisticanalysis/delete_one/delete_there'],{queryParams:{'level':this.options.xAxis.data[xIndex],'headtext':headtext}}); }else{ this.router.navigate(['/statisticanalysis/delete_two_newadd'],{queryParams:{'level':this.options.xAxis.data[xIndex],'headtext':headtext}}); } } } }); this.headZx.setOption(this.options); } /** * @name: 表格提示框封装 * @test: test font * @msg: * @param {string(表头)} * @return {type} */ biaogeTishi(biaotou:string){ var shuju='[{"name":"浦东支队","number":"156","zhanbi":"3%"},{"name":"黄浦支队","number":"144","zhanbi":"2.8%"},' shuju+='{"name":"徐汇支队","number":"133","zhanbi":"2.1%"},{"name":"长宁支队","number":"122","zhanbi":"1.6%"},' shuju+='{"name":"静安支队","number":"120","zhanbi":"1.3%"},{"name":"普陀支队","number":"100","zhanbi":"1.1%"},' shuju+='{"name":"虹口支队","number":"95","zhanbi":"1%"},{"name":"杨浦支队","number":"90","zhanbi":"0.9%"},' shuju+='{"name":"闵行支队","number":"88","zhanbi":"0.8%"},{"name":"宝山支队","number":"83","zhanbi":"0.7%"},' shuju+='{"name":"徐汇支队","number":"133","zhanbi":"2.1%"},{"name":"长宁支队","number":"122","zhanbi":"1.6%"},' shuju+='{"name":"嘉定支队","number":"78","zhanbi":"0.6%"},{"name":"松江支队","number":"75","zhanbi":"0.5%"},' shuju+='{"name":"金山支队","number":"65","zhanbi":"0.4%"},{"name":"崇明支队","number":"55","zhanbi":"0.3%"}]' var jsonObj = JSON.parse(shuju); var res = '
'+biaotou+'
' res+='
'; res+=''; res+=''; res+='' res+='' res+='' res+=''; for(var i=0;i' res+='' res+='' } res+='' res+='' res+='
名称数量总占比
'+jsonObj[i].number+''+jsonObj[i].zhanbi+'
总计135619%
' return res } }