密度任意时间报表
This commit is contained in:
@ -19,3 +19,11 @@ export function getDensityGroup() {
|
|||||||
method: 'get'
|
method: 'get'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export function getDensityDataRange(fDateStart,fDateEnd) {
|
||||||
|
return request({
|
||||||
|
url: '/fx_density/getDensityDataRange/'+fDateStart+'/'+fDateEnd,
|
||||||
|
method: 'get'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
@ -138,11 +138,12 @@
|
|||||||
},
|
},
|
||||||
itemStyle: {
|
itemStyle: {
|
||||||
normal: {
|
normal: {
|
||||||
color: '#fff',
|
color: '#a32323',
|
||||||
borderWidth: 10,
|
borderWidth: 10,
|
||||||
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
||||||
shadowBlur: 100,*/
|
shadowBlur: 100,*/
|
||||||
borderColor: '#A9F387'
|
borderColor: '#A9F387',
|
||||||
|
label : {show: true}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
smooth: false,
|
smooth: false,
|
||||||
|
@ -140,10 +140,11 @@
|
|||||||
},
|
},
|
||||||
itemStyle: {
|
itemStyle: {
|
||||||
normal: {
|
normal: {
|
||||||
color: '#fff',
|
color: '#a32323',
|
||||||
borderWidth: 10,
|
borderWidth: 10,
|
||||||
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
||||||
shadowBlur: 100,*/
|
shadowBlur: 100,*/
|
||||||
|
label : {show: true},
|
||||||
borderColor: '#A9F387'
|
borderColor: '#A9F387'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
261
ruoyi-ui/src/views/fx_density/fx_density_date_range.vue
Normal file
261
ruoyi-ui/src/views/fx_density/fx_density_date_range.vue
Normal file
@ -0,0 +1,261 @@
|
|||||||
|
<template>
|
||||||
|
<div >
|
||||||
|
<div class="ibox-title">
|
||||||
|
<el-row :gutter="24">
|
||||||
|
|
||||||
|
<el-col :xs="24" :sm="24" :lg="24">
|
||||||
|
|
||||||
|
<b>选择时间范围</b>
|
||||||
|
|
||||||
|
<el-date-picker
|
||||||
|
v-model="daterange_time1"
|
||||||
|
align="right"
|
||||||
|
value-format="yyyy-MM-dd"
|
||||||
|
type="date"
|
||||||
|
placeholder="选择日期"
|
||||||
|
:picker-options="pickerOptions">
|
||||||
|
</el-date-picker>
|
||||||
|
|
||||||
|
<b>--</b>
|
||||||
|
<el-date-picker
|
||||||
|
v-model="daterange_time2"
|
||||||
|
align="right"
|
||||||
|
value-format="yyyy-MM-dd"
|
||||||
|
type="date"
|
||||||
|
placeholder="选择日期"
|
||||||
|
:picker-options="pickerOptions">
|
||||||
|
</el-date-picker>
|
||||||
|
|
||||||
|
<el-button @click="getData" type="primary">查询</el-button>
|
||||||
|
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
<el-container >
|
||||||
|
|
||||||
|
|
||||||
|
<div id="chart_density_avg" style="width: 90%;height: 600px;top:20px"></div>
|
||||||
|
</el-container>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import echarts from 'echarts'
|
||||||
|
|
||||||
|
require('echarts/theme/macarons') // echarts theme
|
||||||
|
import resize from '../dashboard/mixins/resize'
|
||||||
|
import { getDensityDataRange } from '@/api/dashboard/density'
|
||||||
|
|
||||||
|
let lineChartData = {
|
||||||
|
xAxisData: [],
|
||||||
|
actualData: []
|
||||||
|
}
|
||||||
|
|
||||||
|
export default {
|
||||||
|
mixins: [resize],
|
||||||
|
name: 'density30day',
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
tableData: [],
|
||||||
|
pickerOptions: {
|
||||||
|
disabledDate(time) {
|
||||||
|
return time.getTime() > Date.now();
|
||||||
|
},
|
||||||
|
shortcuts: [{
|
||||||
|
text: '今天',
|
||||||
|
onClick(picker) {
|
||||||
|
picker.$emit('pick', new Date());
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
text: '昨天',
|
||||||
|
onClick(picker) {
|
||||||
|
const date = new Date();
|
||||||
|
date.setTime(date.getTime() - 3600 * 1000 * 24);
|
||||||
|
picker.$emit('pick', date);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
text: '一周前',
|
||||||
|
onClick(picker) {
|
||||||
|
const date = new Date();
|
||||||
|
date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
|
||||||
|
picker.$emit('pick', date);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
text: '30天前',
|
||||||
|
onClick(picker) {
|
||||||
|
const date = new Date();
|
||||||
|
date.setTime(date.getTime() - 3600 * 1000 * 24 * 30);
|
||||||
|
picker.$emit('pick', date);
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
daterange_time1: '',
|
||||||
|
daterange_time2: '',
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
created() {
|
||||||
|
// this.getData()
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getData() {
|
||||||
|
|
||||||
|
lineChartData = {
|
||||||
|
xAxisData: [],
|
||||||
|
actualData: []
|
||||||
|
}
|
||||||
|
|
||||||
|
getDensityDataRange(this.daterange_time1,this.daterange_time2).then(response => {
|
||||||
|
for (var i = 0; i < response.data.length; i++) {
|
||||||
|
lineChartData.xAxisData.push((response.data[i].time + '').replace(' 00:00:00.0', ''))
|
||||||
|
lineChartData.actualData.push(parseFloat(response.data[i].density).toFixed(4))
|
||||||
|
}
|
||||||
|
|
||||||
|
const chart_energy_avg = echarts.init(document.getElementById('chart_density_avg'))
|
||||||
|
|
||||||
|
option_energy_avg.xAxis[0].data = lineChartData.xAxisData
|
||||||
|
option_energy_avg.series[0].data = lineChartData.actualData
|
||||||
|
option_energy_avg.title.text = '平均密度'
|
||||||
|
option_energy_avg.yAxis[0].min = (Math.min.apply(null, lineChartData.actualData).toFixed(2)*1-0.01)
|
||||||
|
option_energy_avg.yAxis[0].max = (Math.max.apply(null, lineChartData.actualData).toFixed(2)*1+0.01)
|
||||||
|
|
||||||
|
chart_energy_avg.setOption(option_energy_avg, true)
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
const option_energy_avg = {
|
||||||
|
title: {
|
||||||
|
text: '',
|
||||||
|
textStyle: {
|
||||||
|
color: '#000',
|
||||||
|
fontSize: 18
|
||||||
|
},
|
||||||
|
itemGap: 5,
|
||||||
|
|
||||||
|
x: 'center'
|
||||||
|
},
|
||||||
|
tooltip: {
|
||||||
|
trigger: 'axis'
|
||||||
|
},
|
||||||
|
xAxis: [{
|
||||||
|
type: 'category',
|
||||||
|
data: ['1#', '2#', '3#', '30#'],
|
||||||
|
axisLine: {
|
||||||
|
lineStyle: {
|
||||||
|
color: '#999'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
yAxis: [{
|
||||||
|
type: 'value',
|
||||||
|
min: 0.36,
|
||||||
|
max: 0.42,
|
||||||
|
|
||||||
|
// splitNumber: 12,
|
||||||
|
splitLine: {
|
||||||
|
lineStyle: {
|
||||||
|
type: 'dashed',
|
||||||
|
color: '#DDD'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
axisLine: {
|
||||||
|
show: false,
|
||||||
|
lineStyle: {
|
||||||
|
color: '#333'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
nameTextStyle: {
|
||||||
|
color: '#999'
|
||||||
|
},
|
||||||
|
splitArea: {
|
||||||
|
show: false
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
series: [{
|
||||||
|
name: '密度',
|
||||||
|
type: 'line',
|
||||||
|
data: [80, 72],
|
||||||
|
lineStyle: {
|
||||||
|
normal: {
|
||||||
|
width: 8,
|
||||||
|
color: {
|
||||||
|
type: 'linear',
|
||||||
|
|
||||||
|
colorStops: [{
|
||||||
|
offset: 0,
|
||||||
|
color: '#A9F387' // 0% 处的颜色
|
||||||
|
}, {
|
||||||
|
offset: 1,
|
||||||
|
color: '#48D8BF' // 100% 处的颜色
|
||||||
|
}],
|
||||||
|
globalCoord: false // 缺省为 false
|
||||||
|
},
|
||||||
|
shadowColor: 'rgba(72,216,191, 0.3)',
|
||||||
|
shadowBlur: 10,
|
||||||
|
shadowOffsetY: 20
|
||||||
|
}
|
||||||
|
},
|
||||||
|
itemStyle: {
|
||||||
|
normal: {
|
||||||
|
color: '#a32323',
|
||||||
|
borderWidth: 10,
|
||||||
|
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
||||||
|
shadowBlur: 100,*/
|
||||||
|
borderColor: '#A9F387',
|
||||||
|
label : {show: true}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
smooth: false,
|
||||||
|
markLine: {
|
||||||
|
label: {
|
||||||
|
formatter: '{b}: {c}'
|
||||||
|
},
|
||||||
|
precision: 4,
|
||||||
|
lineStyle: {
|
||||||
|
width: 3,
|
||||||
|
color: 'red'
|
||||||
|
},
|
||||||
|
data: [{
|
||||||
|
name: '目标',
|
||||||
|
yAxis: '0.38'
|
||||||
|
}, {
|
||||||
|
type: 'average',
|
||||||
|
name: '平均'
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.dashboard-editor-container {
|
||||||
|
padding: 32px;
|
||||||
|
background-color: rgb(240, 242, 245);
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
.chart-wrapper {
|
||||||
|
background: #fff;
|
||||||
|
padding: 16px 16px 0;
|
||||||
|
margin-bottom: 32px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width:1024px) {
|
||||||
|
.chart-wrapper {
|
||||||
|
padding: 8px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
@ -133,10 +133,11 @@
|
|||||||
},
|
},
|
||||||
itemStyle: {
|
itemStyle: {
|
||||||
normal: {
|
normal: {
|
||||||
color: '#fff',
|
color: '#a32323',
|
||||||
borderWidth: 10,
|
borderWidth: 10,
|
||||||
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
/*shadowColor: 'rgba(72,216,191, 0.3)',
|
||||||
shadowBlur: 100,*/
|
shadowBlur: 100,*/
|
||||||
|
label : {show: true},
|
||||||
borderColor: '#A9F387'
|
borderColor: '#A9F387'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -242,4 +242,43 @@ public class DB_Ajax_DashBoard_Density_48102 {
|
|||||||
}
|
}
|
||||||
return hashMapList;
|
return hashMapList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static List<HashMap<String,String>> getDensityDataRange(String fDateStart, String fDateEnd) {
|
||||||
|
List<HashMap<String,String>> hashMapList = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
Connection conn = getSQLConnection();
|
||||||
|
String sql = "SELECT\n" +
|
||||||
|
"\tProductDate AS TIME,\n" +
|
||||||
|
"\tAVG ( Density ) AS density \n" +
|
||||||
|
"FROM\n" +
|
||||||
|
"\t[dbo].[MouldingRealTimeDensity] \n" +
|
||||||
|
"WHERE\n" +
|
||||||
|
"\tCreatedOn >= '"+fDateStart+"' and CreatedOn <= '"+fDateEnd+"'" +
|
||||||
|
"GROUP BY\n" +
|
||||||
|
"\tProductDate \n" +
|
||||||
|
"ORDER BY\n" +
|
||||||
|
"\tMAX ( CreatedOn );";
|
||||||
|
Statement stmt = conn.createStatement();//
|
||||||
|
System.out.println(sql);
|
||||||
|
|
||||||
|
ResultSet rs = stmt.executeQuery(sql);
|
||||||
|
while (rs.next()) {
|
||||||
|
// 截面积(mm2)
|
||||||
|
HashMap<String,String> map = new HashMap<>();
|
||||||
|
map.put("density",rs.getString("density"));
|
||||||
|
map.put("time",rs.getString("time"));
|
||||||
|
hashMapList.add(map);
|
||||||
|
|
||||||
|
}
|
||||||
|
rs.close();
|
||||||
|
stmt.close();
|
||||||
|
conn.close();
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
|
||||||
|
}
|
||||||
|
return hashMapList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,15 +1,17 @@
|
|||||||
package com.ruoyi.project.fx_density.controller;
|
package com.ruoyi.project.fx_density.controller;
|
||||||
|
|
||||||
import com.ruoyi.db.mssql.DB_Ajax_DashBoard_Density_48102;
|
import com.ruoyi.db.mssql.DB_Ajax_DashBoard_Density_48102;
|
||||||
|
import com.ruoyi.db.mssql.DB_Ajax_DashBoard_Technologist_48102;
|
||||||
import com.ruoyi.framework.web.controller.BaseController;
|
import com.ruoyi.framework.web.controller.BaseController;
|
||||||
import com.ruoyi.framework.web.domain.AjaxResult;
|
import com.ruoyi.framework.web.domain.AjaxResult;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 服务器监控
|
* 服务器监控
|
||||||
*
|
*
|
||||||
* @author ruoyi
|
* @author ruoyi
|
||||||
*/
|
*/
|
||||||
@RestController
|
@RestController
|
||||||
@ -36,4 +38,12 @@ public class DensityController extends BaseController
|
|||||||
{
|
{
|
||||||
return AjaxResult.success(DB_Ajax_DashBoard_Density_48102.DoGetGroupDensityListMap());
|
return AjaxResult.success(DB_Ajax_DashBoard_Density_48102.DoGetGroupDensityListMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@GetMapping("/getDensityDataRange/{fDateStart}/{fDateEnd}")
|
||||||
|
public AjaxResult getDateRange(@PathVariable String fDateStart, @PathVariable String fDateEnd) throws Exception
|
||||||
|
{
|
||||||
|
return AjaxResult.success(DB_Ajax_DashBoard_Density_48102.getDensityDataRange(fDateStart,fDateEnd));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user