使用Highcharts突出显示散点图中的区域

时间:2017-05-03 17:52:56

标签: charts highcharts scatter-plot scatter

我正在使用散点图。并试图实现这一目标: enter image description here

到目前为止,我根据需要放置了绿色标记,并绘制了一个红色标记。唯一剩下的就是突出显示所有绿色和红色标记出现的区域。

我到目前为止创造了这个东西: enter image description here

$(function () {
$('#container').highcharts({
    title: {
        text: ''
    },
    chart: {
        backgroundColor: 'rgba(0,0,0,0)',
        type: 'scatter',
        style: {
            fontFamily: 'Helvetica',
            fontSize: '16px'
        },
        width: 500,
        height: 500
    },
    credits: {
        enabled: false
    },
    xAxis: {
        minRange: 1,
        title: {
            enabled: true,
            text: 'Strategic Alignment'
        },
        startOnTick: true,
        endOnTick: true,
        showLastLabel: true,
        min: 0,
        max: 5
    },
    yAxis: {
        minRange: 1,
        gridLineWidth: 0,
        minorGridLineWidth: 0,
        title: {
            text: 'Process & Technology Integration'
        },
        style: {
            fontWeight: 'bold',
            color: (Highcharts.theme && Highcharts.theme.textColor) || 'black'
        },
        lineWidth: 1,
        min: 0,
        max: 5
    },
    tooltip: {
        enabled: false,
    },
    series: [{
            showInLegend: false,
            name: ' ',
            color: 'Red',
            lineWidth: 1,
            marker: {
                radius: 10,
                symbol: "url()"
            },
            data: [
                [-9999, 3],
                [3, 3],
                [3, -9999]
            ],
            dataLabels: {
                enabled: false,
            }
        }, {
            showInLegend: false,
            type: 'scatter',
            data: [
                [1.1, 2.1], [3.1, 1.1], [3, 4], [1.9, 1.5], [2.9, 1.9],
            ],
            marker: {
                symbol: "url()"
            },
            dataLabels: {
                enabled: false,
            }
        }
    ]


});

});

我已为此附加了代码。请帮我解决该怎么做或如何实现这一目标? 这是jsFiddle:http://jsfiddle.net/seebu/g3q8eLq5/#fork

1 个答案:

答案 0 :(得分:0)

对于矩形,您可以使用带有四个点的多边形系列作为数据,并将系列颜色设置为某个模式 - 模式可以与Highcharts模式填充插件docs here一起使用。对于与您完全相同的模式,您可能需要创建自己的模式。

定义模式

    defs: {
  patterns: [{
    'id': 'custom-pattern',
    'path': {
      d: 'M 0 0 L 10 10 M 9 -1 L 11 1 M -1 9 L 1 11',
      stroke: 'red',
      strokeWidth: 2
    }
  }]
},

多边形系列的配置:

 {
  type: 'polygon',
  enableMouseTracking: false,
  showInLegend: false,
  data: [
    [50, 10],
    [50, 100],
    [120, 100],
    [120, 10]
  ],
  zIndex: -99,
  color: 'url(#custom-pattern)'
  }

示例:http://jsfiddle.net/m18rtzf6/

polygon