BIRT统计图中如何根据参数实现X轴动态分组

BIRT 统计图中如何根据参数实现 X 轴动态分组,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

创新互联建站主营建湖网站建设的网络公司,主营网站建设方案,app软件定制开发,建湖h5小程序定制开发搭建,建湖网站营销推广欢迎建湖等地区企业咨询

报表工具一般擅长处理规则一致的数据,若条件不一致的动态运算在报表中是很难实现的。常见做法是先写段程序把数据源准备好,然后传给BIRT再去画图,而不是在BIRT中去直接处理这种数据并画图。  

比如要处理这么个场景:统计图X轴以时间为刻度,根据传入不同参数条件显示不同值。统计1小时,每5分钟一条,要生成12条,期望结果:

BIRT 统计图中如何根据参数实现 X 轴动态分组

统计1天,每小时一条,要生成24条,期望结果:

BIRT 统计图中如何根据参数实现 X 轴动态分组

统计一周,每天一条,要生成7条,期望结果:

BIRT 统计图中如何根据参数实现 X 轴动态分组

可以利用BIRT提供的API修改X轴的刻度,代码大概要写成这样:

...

function beforeGeneration( chart, icsc )

{    //01 hour  02 day  03 week

        var type = icsc.getExternalContext().getScriptable().getParameterValue("type");

        ...

  var xAxisArray = chart.getAxes();

  xAxisArray[0].setCategoryAxis(false);

  if(type=='01'){

    xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().MINUTES_LITERAL);

    xAxisArray[0].getScale().setStep(5);

  }else if(type=='02'){

    xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().HOURS_LITERAL);

    xAxisArray[0].getScale().setStep(1);

  } else {

    xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().DAYS_LITERAL);

    xAxisArray[0].getScale().setStep(1);

  }

}

...

建议使用集算器,其丰富的集合运算可以方便地完成这类计算,比Java写的代码要短得多,比如类似的计算在集算器里可以这样写(假定数据表为tv,其中发生时刻列为t,统计值列为v):


A

B

1

=[]


2

if(type==“hour”)

>A1=12.(elapse@s(now(),-5*60*~))

3

else if(type==“day”)

>A1=24.(elapse@s(now(),-60*60*~))

4

else if(type==“week”)

>A1=7.(elapse(now(),-~))

5

=A1.(demo.query(“select sum(v) from tv where t>? and t<=?”,~, ifn(~[-1],now()))).new(~.v:Value)

通过接收参数(type)计算起止时间段序列,再根据起止时间段执行SQL进行汇总统计,得到每个时间段内的汇总结果,最后将整个结果集返回给BIRT,按普通统计图的方法去呈现即可。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


本文标题:BIRT统计图中如何根据参数实现X轴动态分组
标题网址:http://scyanting.com/article/joppgi.html