使用带有数据数组的Jquery创建密度热图图表

时间:2015-12-11 14:12:30

标签: javascript jquery charts highcharts data-visualization

我在使用highcharts.js创建密度热图图表时遇到困难。

我可以创建热图图表,但热图图表不适合整个宽度。我期待我的热图图表看起来像下面的截图。任何帮助都感激不尽。此外,请建议任何其他插件,以满足预期的行为。 提前致谢。 [Expected Heatmap chart]

HTML

<div id="container" style="height: 400px; max-width: 400px; margin: 0 auto"></div>

JS

$('#container').highcharts({
    chart: {
        type: 'contour',
        inverted: false
    },
    xAxis: {
        categories: ['Alexander', 'Marie', 'Maximilian', 'Sophia', 'Lukas', 'Maria', 'Leon', 'Anna', 'Tim', 'Laura','Timd', 'Laudra'],

    },
    yAxis: {
        categories: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'],
        title: null
    },
   colorAxis: {
        stops: [
             [0, '#5974FF'],
            [0.5, '#7FFF59'],
            [0.9, '#FFAF59']
        ]

    },
    series: [{
        borderWidth: 0,
        data: [[0, 0, 10], [0, 1, 19], [0, 2, 8], [0, 3, 24], [0, 4, 67], [1, 0, 92], [1, 1, 58], [1, 2, 78], [1, 3, 117], [1, 4, 48], [2, 0, 35], [2, 1, 15], [2, 2, 123], [2, 3, 64], [2, 4, 52], [3, 0, 72], [3, 1, 132], [3, 2, 114], [3, 3, 19], [3, 4, 16], [4, 0, 38], [4, 1, 5], [4, 2, 8], [4, 3, 117], [4, 4, 115], [5, 0, 88], [5, 1, 32], [5, 2, 12], [5, 3, 6], [5, 4, 120], [6, 0, 13], [6, 1, 44], [6, 2, 88], [6, 3, 98], [6, 4, 96], [7, 0, 31], [7, 1, 1], [7, 2, 82], [7, 3, 32], [7, 4, 30], [8, 0, 85], [8, 1, 97], [8, 2, 123], [8, 3, 64], [8, 4, 84], [9, 0, 47], [9, 1, 114], [9, 2, 31], [9, 3, 48], [9, 4, 91],[10, 0, 47], [10, 1, 114], [10, 2, 31], [10, 3, 48], [10, 4, 91]],
        tooltip: {
            headerFormat: 'Temperature<br/>',
            pointFormat: '{point.x:%e %b, %Y} {point.y}:00: <b>{point.value} ℃</b>'
        }
    }]

});

代码在JSFiddle here中。

1 个答案:

答案 0 :(得分:0)

根据我对Highcharts的个人经验,您必须明确为容器div定义宽度,无论是百分比还是固定像素宽度。 max-width似乎被视为一种选择(经常被忽视)与命令。我希望这对你有所帮助。