记录一次基于Echart的数据可视化平台开发

最近公司有需求开发一个用于生产车间的数据可视化平台的项目,基于公司目前的WEB平台。

于是采用了之前就使用过几次的Echart来开发,使用起来也比较熟悉,作为展示也比较方便,故在此记录一下。

由于本人对于前台网页布局设计也不是很精通,所有开发出来的页面在美观方面表现不佳。

正文

1.页面布局方面,先上图

以上就是数据可视化平台的其中几个,对于页面的布局,大多采用Bootstrap 的布局规则进行。

2.使用Echart进行数据可视化渲染。

使用ajax请求后台数据。获取到数据后,再使用echart进行画图。这里省略了echart使用的介绍,详细的可以参考官网的API文档及Demo。

function GetForeLatterCapacityChart() {
    $.getJSON(ApiUrl + '/api/DataVApi/GetWipChart',
       function (data) {
           $.each(data.charts, function (index, chart) {
               var SeriesLineMachine = [];
               //再画echart图
               var option = {
                   title: {
                       text: chart.title + "-前后段WIP",
                       x: 'left',
                       textStyle: {
                           color: '#ccc',
                           fontSize: 12
                       }
                   },
                   tooltip: {
                       show: false
                   },
                   legend: {
                       data: chart.legend,
                       itemHeight: 12,
                       textStyle: {
                           color: '#ccc',
                           fontSize: 10
                       },
                       left: '30%'
                   },
                   xAxis: [{
                       type: 'category',
                       data: chart.xAxis,
                       axisLine: {
                           lineStyle: {
                               color: '#ccc'
                           }
                       },
                       axisLabel: {
                           interval: 0,//横轴信息全部显示
                           fontSize: 10
                       },
                   }],
                   yAxis: [{
                       type: 'value',
                       splitLine: { show: false },//去除网格线
                       min: function (value) {
                           return value.min;
                       },
                       max: function (value) {
                           return value.max;
                       },
                       axisLine: {
                           lineStyle: {
                               color: '#ccc'
                           }
                       },
                       axisLabel: {
                           show: true,
                           fontSize: 10,
                           formatter: '{value}'
                       },
                       //刻度朝内
                       axisTick: {
                           inside: true
                       }
                   }],
                   series: [
                       {
                           name: '前段',
                           type: 'bar',
                           color: '#0083D3',
                           stack: 'WIP',
                           itemStyle: {
                               normal: {
                                   color: '#0083D3'
                               }
                           },
                           label: {
                               normal: {
                                   show: true,
                                   position: 'inside',
                                   align: 'center',
                                   verticalAlign: 'middle',
                                   color: 'white',
                                   borderColor: '#9ACD32',
                                   formatter: function (params) {
                                       if (params.value == '0') {
                                           return '';
                                       } else {
                                           return params.value;
                                       }
                                   }
                               }
                           },
                           data: chart.CapacityForePart
                       },
                            {
                                name: '后段',
                                type: 'bar',
                                color: '#18FFF9',
                                stack: 'WIP',
                                itemStyle: {
                                    normal: {
                                        color: '#18FFF9'
                                    }
                                },
                                label: {
                                    normal: {
                                        show: true,
                                        position: 'inside',
                                        align: 'center',
                                        verticalAlign: 'middle',
                                        color: 'white',
                                        borderColor: '#E0FFFF',
                                        formatter: function (params) {
                                            if (params.value == '0') {
                                                return '';
                                            } else {
                                                return params.value;
                                            }
                                        }
                                    }
                                },
                                data: chart.CapacityLatterPart
                            }
                   ],
                   label: {
                       show: true,
                       position: 'top',
                       textStyle: {
                           color: 'black'
                       }
                   },
                   grid: {
                       left: 24,
                       top: 30,
                       right: 24,
                       bottom: 20
                   }
               };

               if (option && typeof option === "object") {
                   var dom = document.getElementById('WipCa' + index.toString());
                   var WIPCapacityChar = echarts.init(dom);
                   WIPCapacityChar.setOption(option);
               }

               window.addEventListener("resize", function () {
                   WIPCapacityChar.resize();
               });
           });
       });
    
}

  有时候需求轮播的图形,可以参考使用Swiper,但是Swiper5对Echart的支持还有点问题。Echart图形的点击事件会失效。

所有我使用的是Swiper3来对图形进行定时轮播。Swiper的使用介绍可以参考官网API。API挺详细的。

var mySwiper0 = new Swiper('.visual_swiper0', {
            loop: true,
            observer: true,
            observeParents: true
        })
setInterval(function () {
            mySwiper0.slidePrev();
        }, 60000);

  

posted on 2020-08-14 10:30  PingPo  阅读(463)  评论(0编辑  收藏  举报

导航