Highcharts - изменяемая ось Y для фигуры Candlestick & Volume - PullRequest
0 голосов
/ 05 ноября 2019

Все еще не найдя решения, я вынужден опубликовать здесь.

У меня есть график свечей и график объема от «Highcharts». Оба должны быть в одной оси. Когда я изменяю размер, оба должны изменить размер как один. Смотрите изображение ниже. enter image description here

В настоящее время Highchart поддерживает его как две панели, что для меня бесполезно. Любая помощь будет высоко ценится. enter image description here

1 Ответ

0 голосов
/ 06 ноября 2019

Изменение размера для осей, и серии могут быть назначены для любой оси, поэтому, если у вас будет несколько рядов в одном и том же YAXIS, изменение размера будет работать для всех рядов в этом YAXIS.

Демонстрационные данные по умолчанию для объема:примерно на 1 000 000 больше, чем данные OHLC, поэтому я настроил это в следующей демонстрации: https://jsfiddle.net/BlackLabel/oegqudbz/

Highcharts.getJSON('https://www.highcharts.com/samples/data/aapl-ohlcv.json', function (data) {

    // split the data set into ohlc and volume
    var ohlc = [],
        volume = [],
        dataLength = data.length,
        // set the allowed units for data grouping
        groupingUnits = [[
            'week',                         // unit name
            [1]                             // allowed multiples
        ], [
            'month',
            [1, 2, 3, 4, 6]
        ]],

        i = 0;

    for (i; i < dataLength; i += 1) {
        ohlc.push([
            data[i][0], // the date
            data[i][1], // open
            data[i][2], // high
            data[i][3], // low
            data[i][4] // close
        ]);

        volume.push([
            data[i][0], // the date
            data[i][5] / 1e6 // the volume in milions
        ]);
    }


    // create the chart
    Highcharts.stockChart('container', {

        rangeSelector: {
            selected: 1
        },

        title: {
            text: 'AAPL Historical'
        },

        yAxis: [{
            labels: {
                align: 'right',
                x: -3
            },
            title: {
                text: 'OHLC'
            },
            height: '60%',
            lineWidth: 2,
            resize: {
                enabled: true
            }
        }, {
            labels: {
                align: 'right',
                x: -3
            },
            title: {
                text: 'Volume'
            },
            top: '65%',
            height: '35%',
            offset: 0,
            lineWidth: 2
        }],

        tooltip: {
            split: true
        },

        series: [{
            type: 'candlestick',
            name: 'AAPL',
            data: ohlc,
            dataGrouping: {
                units: groupingUnits
            }
        }, {
            type: 'column',
            name: 'Volume',
            data: volume,
            dataGrouping: {
                units: groupingUnits
            }
        }]
    });
});
<script src="https://code.highcharts.com/stock/highstock.js"></script>
<script src="https://code.highcharts.com/stock/modules/data.js"></script>
<script src="https://code.highcharts.com/stock/modules/drag-panes.js"></script>
<script src="https://code.highcharts.com/stock/modules/exporting.js"></script>


<div id="container" style="height: 600px; min-width: 310px"></div>

Нет ограничений на количество панелей (или осей Y), которые можно изменять с помощью модуля перетаскиваемых панелей, поэтому вы можете иметь более 2 осей иболее 2-х преобразователей и более 2-х осей, назначенных одному преобразователю. Больше информации в справочнике API: https://api.highcharts.com/highstock/yAxis.resize

...