3

我用长标签绘制了一个 flot 饼图,结果很丑,我认为可以在远离饼图或饼图下方的地方显示标签。我使用的 javascript 是

function onSuccess(series) {
            var tickLabels = [];
            var pieData= [];
            for (var i =0;i<series.length;i++){
                tickLabels.push([i,series[i][0]]);
                var obj = {};
                obj['label']=series[i][0];
                obj['data']=series[i][1];
                pieData.push(obj);
                series[i][0] = i;
            }
            var data = [series];
        var pieArea = $("#pieChart");  

        pieArea.css("height", "400px");  
        pieArea.css("width", "600px"); 


            $.plot( $("#barChart"), data, {
        series: {
         bars: {
            show:true,
            barWidth: 0.5,
            align: "center"
         },
            points: {
                show: true
            }
        },
        grid: {
            hoverable: true,
            clickable: true
        },
        xaxis: {
            labelWidth:12,
            labelAngle: 45,
            ticks: tickLabels
        }
        } ); 

图表 丑陋的饼图

有没有人知道这个的任何解决方案

4

2 回答 2

8

您可以将图例放在不同的容器中,然后使用 CSS 将其放置在您想要的任何位置。

legend: {
    container: '#graphLegend'     
}

从 API 文档:

如果您希望图例出现在 DOM 中的其他位置,您可以将“容器”指定为 jQuery 对象/表达式以将图例表放入其中。“位置”和“保证金”等选项将被忽略。请注意,Flot 将覆盖容器的内容。

我更新了Mark's fiddle来演示这个替代方案。

于 2013-08-28T00:29:17.440 回答
4

您可以结合使用图例positionmargin属性来执行此操作:

例如,这会将其推到northwest角落右侧 400 像素。

legend: {
    position: 'nw',
    margin: [400,0]     
}

在这里看小提琴。

于 2013-08-27T14:27:06.000 回答