1

我使用 jsreport.net 设置了一个基于 jsrender 的浮动图表,目前在多页图表的 y 轴上失败。正如您在第二张图片中看到的那样,y 轴与条形不正确匹配。

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

第一页: 第一页

第二页:

第二页

这是当前的源代码片段

        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++;
        }
4

1 回答 1

2

由于为每个其他页面添加的页眉/边距空间,似乎plot.offset().top计算错误。dsHook

第一个“解决方案”是修改您的计算以反映这一点:

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

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

第二个“解决方案”是在幻像配置中添加固定大小的空标题,还没有解释

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

我希望我会用更好的解释/解决方案来更新它

于 2015-01-27T20:02:35.377 回答