Flot,jsrender&幻影:条形标签轴

时间:2015-01-27 09:42:30

标签: flot jsrender jsreport

我使用jsreport.net设置了基于jsrender的flot图表,目前在多页图表的y轴上失败。正如您在第二张图像上看到的那样,y轴没有正确匹配条。

更新:这是游乐场链接:https://playground.jsreport.net/#playground/WJmSGjkB5/2

第一页: First page

第二页:

Second page

这是当前的源代码段

        var seriesCount = 1; // current data series identifier

        // drawing series hook
        dsHook = function(plot, canvascontext, series){
            for (var i = 0; i < series.data.length; i++){

                // get relative position of plot
                var offset = plot.offset();

                // get data point
                var dP = series.data[i];

               var pos = plot.p2c({x: dP[0], y: dP[1]});

               var barWidth = plot.p2c({x: dP[0] + series.bars.barWidth, y: dP[1]}).left - pos.left;

               var posCorr; 
               // set horizontal position correction

               switch(seriesCount) {
                   case 1: posCorr = -72; break;
                   case 2: posCorr = -23; break;
                   case 3: posCorr = 24; break;
                   case 4: posCorr = -50; break;
                   case 5: posCorr = 2; break;
                } 

                pos.left += offset.left + posCorr; 
                pos.top += offset.top - 30;

                numFormatted = number_format(dP[1], 0, '', '\'');

                var aDiv = $('<div></div>').css({'width':barWidth, 'background-color':'white','color':'black','font-size':'12px','text-align':'center','position':'absolute','left': pos.left,'top':pos.top}).text(numFormatted).appendTo("body");

            }
            seriesCount++;
        }

1 个答案:

答案 0 :(得分:2)

plot.offset().top似乎错误地计算了dsHook,因为为每个其他网页添加了标题/边距空间。

第一个&#34;解决方案&#34;是修改您的计算以反映这一点:

pos.top += offset.top - 30 + ({{:ID}}-1)*20;

https://playground.jsreport.net/#playground/WJmSGjkB5/5

第二个&#34;解决方案&#34;是为幻像配置添加固定大小的空标题,还没有解释它

https://playground.jsreport.net/#playground/WJmSGjkB5/4

我希望我能用更好的解释/解决方案更新这个