前一篇博文记录了echart图例诸如柱图、折线图、饼图、map图等的前后台交互和最终显示结果,但是Map图还有两个小问题没有解决,正好今天解决这两个问题。
第一个问题:
Map图中数据根据value的排序问题,这个问题比较简单,就是利用Collections.sort()进行排序就可以了
List<Map.Entry<String, Double>> list = new ArrayList<Map.Entry<String, Double>>(size);
list.addAll(map.entrySet());
// 通过Collections.sort()排序
Collections.sort(list, new Comparator<Map.Entry<String, Double>>() {
public int compare(Map.Entry<String, Double> o1, Map.Entry<String, Double> o2) {
return o1.getValue().compareTo(o2.getValue());
};
});
第二个问题:
Map图的图例范围如果设置为动态,需要根据数据的输入范围来界定其图例范围。但是如果是简单的利用输入数据的最小值和最大值来界定范围就会在一些特殊情况下发生范围不明显的情况,比如有一组数:1,2,3,2,6,2,5,324;如果简单的根据输入数据的最大值和最小值进行界定,则会发生最大值为324导致大部分数据集中在特别小的局部,从而导致层次不明显,无法起到该有的作用,因此需要寻找一种算法,实现异常数据的剔除。
此过程中发现格拉布斯准则是比较贴近这种情况的。格拉布斯准则解决的是同一个参数经过若干次测量,但是测量结果偏差较大的问题。本次问题虽然不是同一参数的多个数据,而是不同省份的value值,但是还是可以看成类似的模型。
首先,说一下格拉布斯准则的主要内容:
第一步:根据数据输入,计算得出数据的算数平均数x;
第二步:根据数据输入和算数平均数,计算得出数据集的标准差standard;
第三步:对数据进行排序,计算最大值和最小值的偏差|(num-x)/standard|,找到可疑值,根据检出水平alpha查询临界值,从而确定异常值
第四步:剔除异常值,重新寻找新的异常值。
更详细的解释可以查询:格拉布斯准则剔除异常值
回到之前Map的图例展示,之前由于只是传的data数据,没有传其他参数,所以只是传了一个数组而已,而现在要传map的visualMap的max和min值,所以需要更多的参数,为了数据的简单化,就不在echartData中增加字段,而是新建一个mapChartData 的series来进行数据的传递。
public class MapSeries {
public Integer Max;
public Integer Min;
public List<Object> list;
public MapSeries(Integer max,Integer min,List&l