JavaScript - Chart.js tooltip shows wrong x-axis value

前端 未结 3 1122
滥情空心
滥情空心 2021-01-20 05:16

I have a chart with two different datasets, but sometimes they have the same x, y coordinates. But when I hover a shared point, it sometimes shows the wrong date. T

相关标签:
3条回答
  • 2021-01-20 05:46

    I belive that you need pass the labels.

    labels: ["09:00", "09:30", "09:50", "10:10", "10:30", "10:50", "11:10"],
    

    //////////////////////////////////////////////

    var chartPluginLineaHorizontal = {
            afterDraw: function (chartobj, chartobjDos) {
                if (chartobj.options.lineaHorizontal) {
                    var ctx = chartobj.chart.ctx;
                    var valorY = chartobj.scales["y-axis-0"].getPixelForValue(chartobj.options.lineaHorizontal);
                    ctx.beginPath();
                    ctx.moveTo(0, valorY);
                    ctx.lineTo(chartobj.chart.width, valorY);
                    ctx.strokeStyle = "red";
                    ctx.stroke();
    
                }
            }
        }
        Chart.pluginService.register(chartPluginLineaHorizontal);
    
        var chartPluginLineaHorizontalDos = {
            afterDraw: function (chartobj) {
                if (chartobj.options.lineaHorizontal) {
                    var ctx = chartobj.chart.ctx;
                    var valorY = chartobj.scales["y-axis-0"].getPixelForValue(chartobj.options.lineaHorizontalDos);
                    ctx.beginPath();
                    ctx.moveTo(0, valorY);
                    ctx.lineTo(chartobj.chart.width, valorY);
                    ctx.strokeStyle = "red";
                    ctx.stroke();
                }
            }
        }
        Chart.pluginService.register(chartPluginLineaHorizontalDos);
    
        // Define a plugin to provide data labels
        Chart.plugins.register({
            afterDatasetsDraw: function (chartobj) {
                var ctx = chartobj.chart.ctx;
    
                chartobj.data.datasets.forEach(function (dataset, i) {
                    //debugger
                    var meta = chartobj.getDatasetMeta(i);
                    if (!meta.hidden) {
                        meta.data.forEach(function (element, index) {
                            // Draw the text in black, with the specified font
                            ctx.fillStyle = 'rgb(0, 0, 0)';
    
                            var fontSize = 16;
                            var fontStyle = 'inherit';
                            var fontFamily = 'sans-serif';
                            ctx.font = Chart.helpers.fontString(fontSize, fontStyle, fontFamily);
    
                            // Just naively convert to string for now
                            var dataString = dataset.data[index].y.toString();
    
                            // Make sure alignment settings are correct
                            ctx.textAlign = 'center';
                            ctx.textBaseline = 'middle';
    
                            var padding = 5;
                            var position = element.tooltipPosition();
                            ctx.fillText(dataString, position.x, position.y - (fontSize / 2) - padding);
                        });
                    }
                });
            }
        });
    
                    var ctx = document.getElementById('myChart').getContext('2d');
                    var myChart = new Chart(ctx, {
                        type: 'line',
                        data: {
                            labels: ["09:00", "09:30", "09:50", "10:10", "10:30", "10:50", "11:10"],
                            datasets: [{
                                label: "My First dataset",
                                data: [
                                        {
                                            x: "09:30",
                                            y: 127
                                        },
                                       {
                                           x: "09:30",
                                           y: 140
                                       },
                                       {
                                           x: "09:50",
                                           y: 135
                                       },
                                       {
                                           x: "10:10",
                                           y: 122
                                       }, {
                                           x: "10:30",
                                           y: 135
                                       }, {
                                           x: "10:50",
                                           y: 135
                                       }],
                                backgroundColor: "rgba(0,255,51,0.5)",
                                            borderColor: "rgba(0,255,51,0.5)",
                                            fill: false
                            },
                                    {
                                        label: "My second dataset",
                                        data: [
                                            {
                                                x: "09:50",
                                                y: 95
                                            },
                                       {
                                           x: "10:10",
                                           y: 140
                                       },
                                       {
                                           x: "10:30",
                                           y: 130
                                       },
                                       {
                                           x: "10:50", 
                                           y: 150
                                       },
                                       {
                                           x: "11:10",
                                           y: 143
                                       }],
                                                    backgroundColor: "rgba(0,98,31,0.5)",
                                                    borderColor: "rgba(0,98,31,0.5)",
                                                    fill: false
                                    }]
                        },
                        options: {
                            lineaHorizontal: 140,
                            lineaHorizontalDos: 100,
                            elements: {
                                line: {
                                    tension: 0
                                }
                            }
    
                        }
    
    
                    })
    
    0 讨论(0)
  • 2021-01-20 05:50

    You defined a custom scale for a category cartesian axis in your chart configuration. Set the type for your xAxes to 'category'. This may not be neccessary as ChartJS picks this up by default.

    options: {
        scales: {
            xAxes: [{
                type: 'category',
                ....
    

    Also, the second data set isn't formatted properly. You should supply the data points in {x: xval, y: yval} format.

    References:

    http://www.chartjs.org/docs/latest/axes/cartesian/time.html#time-cartesian-axis

    0 讨论(0)
  • 2021-01-20 06:12

    I solved my problem by using tooltip callback like this:

    options: {
        tooltips: {
            callbacks: {
                title: function(tooltipItems, data) {
                    return data.datasets[tooltipItems[0].datasetIndex].data[tooltipItems[0].index].x;
                }
            }
        }
    }
    

    Now my tooltips getting their title directly from the corresponding dataset.

    Chartjs Version : 2.9.3

    0 讨论(0)
提交回复
热议问题