尝试根据数据值自定义工具提示。线条图的角落上还有这些小的圆形连接器或连接线,当线条上升或下降时,我也试图改变它的颜色,对于那些我甚至不知道从哪里开始的颜色。以下是我正在使用的代码的一部分,我尝试返回并使用Chart.js更改工具提示颜色
tooltips: {
mode: 'index',
intersect: false,
callbacks: {
label: function(tooltipItem, data) {
if (tooltipItem.yLabel === 1) {
//return 'Normal';
return { 'Normal',
tooltipFillColor: 'rgb(255, 99, 132)', // red
};
} else if (tooltipItem.yLabel === 2) {
// return 'Active';
return { 'Acitve',
tooltipFillColor: 'rgb(75, 192, 192)', // green
};
}
}
}
},
感谢您的帮助!
答案 0 :(得分:2)
除了chart.js提供的配置选项之外,您几乎想要自定义工具提示的外观,您必须使用custom tooltips。自定义工具提示的好处在于它们是基于html / css的,因此您的样式选项是无穷无尽的。
在这种情况下,由于您尝试根据数据的值更改工具提示背景颜色,您可以简单地定义一些css类来处理两种样式选项,然后在自定义工具提示函数中实现逻辑以指定适当的基于值的css类。
这是一个例子。
custom: function(tooltip) {
// get the tooltip element
var tooltipEl = document.getElementById('chartjs-tooltip');
// create one if it does not yet exist
if (!tooltipEl) {
tooltipEl = document.createElement('div');
tooltipEl.id = 'chartjs-tooltip';
tooltipEl.innerHTML = "<table></table>"
document.body.appendChild(tooltipEl);
}
// hide the tooltip and restore the cursor
// if there isn't one to display yet
if (tooltip.opacity === 0) {
tooltipEl.style.opacity = 0;
$(this._chart.canvas).css("cursor", "default");
return;
} else {
// otherwise change the cursor to pointer
$(this._chart.canvas).css("cursor", "pointer");
}
// clear all classes and add the correct background color
tooltipEl.classList.remove('active', 'normal');
if (tooltip.dataPoints[0].yLabel === 2) {
tooltipEl.classList.add('active');
} else {
tooltipEl.classList.add('normal');
}
function getBody(bodyItem) {
return bodyItem.lines;
}
// set tooltip text
if (tooltip.body) {
var titleLines = tooltip.title || [];
var bodyLines = tooltip.body.map(getBody);
var innerHtml = '<thead>';
titleLines.forEach(function(title) {
innerHtml += '<tr><th>' + title + '</th></tr>';
});
innerHtml += '</thead><tbody>';
bodyLines.forEach(function(body, i) {
// map the number that is going to be displayed state value
if (tooltip.dataPoints[0].yLabel === 2) {
body = 'Active';
} else {
body = 'Normal';
}
var colors = tooltip.labelColors[i];
var style = 'background:' + colors.backgroundColor;
style += '; border-color:' + colors.borderColor;
style += '; border-width: 2px';
var span = '<span class="chartjs-tooltip-key" style="' + style + '"></span>';
innerHtml += '<tr><td>' + span + body + '</td></tr>';
});
innerHtml += '</tbody>';
var tableRoot = tooltipEl.querySelector('table');
tableRoot.innerHTML = innerHtml;
}
// get the position of tooltip
var position = this._chart.canvas.getBoundingClientRect();
// set display, position, and font styles
tooltipEl.style.opacity = 1;
tooltipEl.style.left = position.left + tooltip.caretX + 'px';
tooltipEl.style.top = position.top + tooltip.caretY + 'px';
tooltipEl.style.fontFamily = tooltip._fontFamily;
tooltipEl.style.fontSize = tooltip.fontSize;
tooltipEl.style.fontStyle = tooltip._fontStyle;
tooltipEl.style.padding = tooltip.yPadding + 'px ' + tooltip.xPadding + 'px';
}
听起来您还想根据数据值自定义点颜色。这实际上非常简单,不需要使用任何类型的回调。您只需将一组颜色传递给pointBackgroundColor
和pointBorderColor
属性,其中数组中的每个索引都映射到数据数组中的索引。
例如,如果您希望第一个和第三个点是不同的颜色,那么您的数组可能看起来像[blue, red, blue, red]
。您可以在构建图表数据对象时构建颜色数组(例如,在prepareDataForChart()
函数中。
这是一个例子。
// this function processess our raw data and converts
// it to a format that chart.js can understand
var prepareDataForChart = function(data) {
var chartData = {
data: [],
pointColors: [],
};
data.forEach(function(d) {
var yValue;
var pointColor;
// since we cannot use a category scale on the y-axis,
// lets map the eventState to an arbitrary numerical value
// and set the point color
if (d.eventState === 'A') {
yValue = 2;
pointColor = chartColors.red;
} else if (d.eventState === 'N') {
yValue = 1;
pointColor = chartColors.blue;
}
// we have to use the 'alternate' dataset format
// in order to graph this correctly
chartData.data.push({
x: d.eventTime,
y: yValue,
});
// add our point color to the colors array
chartData.pointColors.push(pointColor);
});
return chartData;
};
然后,当您创建图表时,只需使用函数返回的pointColors
数组。
var ctx = document.getElementById("myChart");
var myChart = new Chart(ctx, {
type: 'line',
data: {
datasets: [{
label: "Object 1",
fill: false,
borderColor: chartColors.red,
borderWidth: 2,
backgroundColor: chartColors.white,
pointBorderColor: chartData.pointColors,
pointBackgroundColor: chartData.pointColors,
pointBorderWidth: 1,
pointHoverRadius: 5,
pointHitRadius: 20,
steppedLine: true,
data: chartData.data,
}]
},
// ...rest of chart options...
这是一个codepen example,展示了所讨论的所有内容(彩色工具提示和点)。
答案 1 :(得分:0)
或者,您可以使用标签颜色功能。
tooltips: {
callbacks: {
labelColor: function(tooltipItem,data) {
if (tooltipItem.datasetIndex === 0) {
return {
borderColor: "#FFFFFF",
backgroundColor: "#FFCD2E"
};
}