gpt4 book ai didi

javascript - 使用 Chart.js,我可以为图表标题中的每一行文本指定不同的字体大小吗?

转载 作者:行者123 更新时间:2023-11-29 18:43:04 27 4
gpt4 key购买 nike

我使用的是 Chart.js 版本:2.7.3

我的图表标题有三行。我想让顶行的字体大小为 16,然后是第二行的字体大小为 14,第三行的字体大小为 12。我不确定这是否可能并且还没有找到方法。

这是我的代码的一部分,它定义了我的图表的选项...

options: {
title: {
display: true,
// Supply the title as an array and each array index prints on a separate line in the title section
text: ['My Chart','Last Month', 'Local Time'],
fontSize: 16,
callbacks: {
drawTitle: function(pt, vm, ctx, opacity) {
console.log("title.length: " + title.length);
var title = vm.title;

if (title.length) {
ctx.textAlign = vm._titleAlign;
ctx.textBaseline = 'top';

var titleFontSize = vm.titleFontSize;
var titleSpacing = vm.titleSpacing;

ctx.fillStyle = mergeOpacity(vm.titleFontColor, opacity);
ctx.font = helpers.fontString(titleFontSize, vm._titleFontStyle, vm._titleFontFamily);

var i, len;
for (i = 0, len = title.length; i < len; ++i) {
ctx.fillText(title[i], pt.x, pt.y);
pt.y += titleFontSize + titleSpacing; // Line Height and spacing

if (i + 1 === title.length) {
pt.y += vm.titleMarginBottom - titleSpacing; // If Last, add margin, remove spacing
}
}
}
}
}
},

我知道您可以指定“fontSize”,但这适用于图表标题中的所有文本。我想为每一行文本使用不同的 fontSize。我尝试指定回调,但在 checkin Chrome F12 devtools 时没有看到 console.log() 消息。

Chart.js 中有没有办法为图表标题中的每一行指定不同的字体大小?

谢谢!

解决方案更新

我接受了 Edi Carlos 的回答,因为这提供了有关如何将格式化文本附加到 Canvas 元素的有用建议,并且这可以在 Chart.js 动画回调中完成。

我的图表是启用了工具提示的散点图。使用公认的解决方案时,将鼠标悬停在标绘点上时,fillText 可能会消失或改变屏幕上的位置。我发现如果我使用 F12 Chrome 开发工具,文本也会消失。在接受的答案中的 jsfiddle 中也会发生同样的情况...如果您启用工具提示...尝试将鼠标悬停在条形图上或按 F12。

要在将鼠标悬停在工具提示上时阻止 fillText 移动位置,我发现我必须指定:

ctx.textBaseline = 'top';
ctx.textAlign = 'center';

为了阻止 fillText 在按下 F12 时消失,我发现我必须使用绝对位置对 canvas 元素设置 CSS 样式。

#canvas{
position:absolute;
}

这是我的 Chart.js 选项中的一段代码,展示了如何为 Chart.js 图表标题中的每一行文本指定不同的字体大小和样式:

options: {
animation: {
onProgress: function(animation) {
ctx.textBaseline = 'top';
ctx.textAlign = 'center';

// Set the font size and text position for the 2nd row in the Chart title
ctx.font = "bold 14px 'Helvetica Neue', Helvetica, Arial, sans-serif";
ctx.fillStyle = "#666";
ctx.fillText("Last 24 Hours", 610, 32);

// Set the font size and text position for the 3rd row in the Chart title
ctx.font = "bold 12px 'Helvetica Neue', Helvetica, Arial, sans-serif";
ctx.fillStyle = "#666";
ctx.fillText("Local Time | Limit=None", 610, 53);
}
},
title: {
display: true,
text: ['Sensor Chart',' ', ' '],
fontSize: 16
}
}

Chart.js 允许您提供一个字符串数组作为标题。然后每个数组索引打印在单独的一行上。我在文本中留下了空格:[] array index 1 and 2 所以图表标题中会有空格来定位 ctx.fillText() 到。

建议添加到 Chart.js

总的来说,这仍然是一种有点笨拙的方法。我认为 Chart.js 应该有一个更集成的解决方案。以同样的方式,你可以指定多个 y 轴,每个 y 轴都有自己的属性,使用:

yAxes: [
{
id: 'A',
..
..
},
{
id: 'B',
..
..
}
]

如果您可以为图表标题中的多行指定样式,那就太好了:

title: {
display: true,
titleRows: [
{
id: 'A',
text: 'Row1',
fontSize: 16,
..
},
{
id: 'B',
text: 'Row2',
fontSize: 14,
..
},
{
id: 'C',
text: 'Row3',
fontSize: 12,
..
}
]
}

最佳答案

您可以使用 fillText() 方法 使用 Chart.js 版本:2.7.3

使用 fillText() 在 Canvas 上写入 “Network!”“Stackoverflow”(带渐变):

var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");

ctx.font = "20px Georgia";
ctx.fillText("Network", 10, 50);

ctx.font = "30px Verdana";
// Create gradient
var gradient = ctx.createLinearGradient(0, 0, c.width, 0);
gradient.addColorStop("0"," magenta");
gradient.addColorStop("0.5", "blue");
gradient.addColorStop("1.0", "red");
// Fill with gradient
ctx.fillStyle = gradient;
ctx.fillText("Stackoverflow", 10, 90);

fillText() 方法在 Canvas 上绘制填充文本。文本的默认颜色为黑色。使用 font 属性指定字体和字体大小,并使用 fillStyle 属性以另一种颜色/渐变呈现文本。

我的 Fiddle例子

更新 ->您可以使用动画回调(onProgress 或 onComplete)来执行此操作,例如:

options: {
animation: {
onProgress: function(animation) {
// code above
}
}
}

更新 2 -> 完整代码

var ctx = document.getElementById('myChart').getContext('2d');
var myChart = new Chart(ctx, {
type: 'bar',
data: {
labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'],
datasets: [{
data: [2, 2, 3, 5, 2, 3],
backgroundColor: [
'rgba(255, 99, 132, 0.2)',
'rgba(54, 162, 235, 0.2)',
'rgba(255, 206, 86, 0.2)',
'rgba(75, 192, 192, 0.2)',
'rgba(153, 102, 255, 0.2)',
'rgba(255, 159, 64, 0.2)'
],
borderColor: [
'rgba(255, 99, 132, 1)',
'rgba(54, 162, 235, 1)',
'rgba(255, 206, 86, 1)',
'rgba(75, 192, 192, 1)',
'rgba(153, 102, 255, 1)',
'rgba(255, 159, 64, 1)'
],
borderWidth: 1
}]
},
options: {
tooltips: {
enabled: false
},
legend: {
display: false
},
scales: {
yAxes: [{
ticks: {
beginAtZero: true
}
}]
},
animation: {
onProgress: function(animation) {
var c = document.getElementById("myChart");
var ctx = c.getContext("2d");

ctx.font = "20px Georgia";
ctx.fillText("1 - Network", 45, 30);

ctx.font = "30px Verdana";
// Create gradient
var gradient = ctx.createLinearGradient(0, 0, c.width, 0);
gradient.addColorStop("0", "magenta");
gradient.addColorStop("0.5", "blue");
gradient.addColorStop("1.0", "red");
// Fill with gradient
ctx.fillStyle = gradient;
ctx.fillText("2 - Stackoverflow", 45, 70);
}
}
}
});

已满 Fiddle

希望对您有所帮助!

关于javascript - 使用 Chart.js,我可以为图表标题中的每一行文本指定不同的字体大小吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55711822/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com