ドーナツグラフ内にテキストをレンダリングする方法チャートJs。
ベストアンサー1
他の回答では、テキストの量とドーナツのサイズに基づいてテキストのサイズが変更されることはありません。ここでは、任意の量のテキストを中央に動的に配置するために使用できる小さなスクリプトを紹介します。これにより、テキストのサイズが自動的に変更されます。
例: http://jsfiddle.net/kdvuxbtj/
ドーナツにぴったり合うサイズのテキストをドーナツ内に配置できます。端に触れないようにするには、円の内側の直径のパーセンテージとしてサイドパディングを設定できます。設定しない場合は、デフォルトで 20 になります。色、フォント、テキストも設定できます。残りの処理はプラグインが行います。
プラグイン コードは、基本フォント サイズ 30 ピクセルで開始します。そこからテキストの幅をチェックし、円の半径と比較し、円とテキストの幅の比率に基づいてサイズを変更します。
デフォルトの最小フォント サイズは 20 ピクセルです。テキストが最小フォント サイズの範囲を超える場合は、テキストが折り返されます。テキストを折り返すときのデフォルトの行の高さは 25 ピクセルですが、変更することができます。デフォルトの最小フォント サイズを false に設定すると、テキストは無限に小さくなり、折り返されなくなります。
また、テキストが足りず文字が大きすぎる場合に備えて、デフォルトの最大フォント サイズは 75 ピクセルに設定されています。
これはプラグインコードです
Chart.pluginService.register({
beforeDraw: function(chart) {
if (chart.config.options.elements.center) {
// Get ctx from string
var ctx = chart.chart.ctx;
// Get options from the center object in options
var centerConfig = chart.config.options.elements.center;
var fontStyle = centerConfig.fontStyle || 'Arial';
var txt = centerConfig.text;
var color = centerConfig.color || '#000';
var maxFontSize = centerConfig.maxFontSize || 75;
var sidePadding = centerConfig.sidePadding || 20;
var sidePaddingCalculated = (sidePadding / 100) * (chart.innerRadius * 2)
// Start with a base font of 30px
ctx.font = "30px " + fontStyle;
// Get the width of the string and also the width of the element minus 10 to give it 5px side padding
var stringWidth = ctx.measureText(txt).width;
var elementWidth = (chart.innerRadius * 2) - sidePaddingCalculated;
// Find out how much the font can grow in width.
var widthRatio = elementWidth / stringWidth;
var newFontSize = Math.floor(30 * widthRatio);
var elementHeight = (chart.innerRadius * 2);
// Pick a new font size so it will not be larger than the height of label.
var fontSizeToUse = Math.min(newFontSize, elementHeight, maxFontSize);
var minFontSize = centerConfig.minFontSize;
var lineHeight = centerConfig.lineHeight || 25;
var wrapText = false;
if (minFontSize === undefined) {
minFontSize = 20;
}
if (minFontSize && fontSizeToUse < minFontSize) {
fontSizeToUse = minFontSize;
wrapText = true;
}
// Set font settings to draw it correctly.
ctx.textAlign = 'center';
ctx.textBaseline = 'middle';
var centerX = ((chart.chartArea.left + chart.chartArea.right) / 2);
var centerY = ((chart.chartArea.top + chart.chartArea.bottom) / 2);
ctx.font = fontSizeToUse + "px " + fontStyle;
ctx.fillStyle = color;
if (!wrapText) {
ctx.fillText(txt, centerX, centerY);
return;
}
var words = txt.split(' ');
var line = '';
var lines = [];
// Break words up into multiple lines if necessary
for (var n = 0; n < words.length; n++) {
var testLine = line + words[n] + ' ';
var metrics = ctx.measureText(testLine);
var testWidth = metrics.width;
if (testWidth > elementWidth && n > 0) {
lines.push(line);
line = words[n] + ' ';
} else {
line = testLine;
}
}
// Move the center up depending on line height and number of lines
centerY -= (lines.length / 2) * lineHeight;
for (var n = 0; n < lines.length; n++) {
ctx.fillText(lines[n], centerX, centerY);
centerY += lineHeight;
}
//Draw text in center
ctx.fillText(line, centerX, centerY);
}
}
});
チャートオブジェクトでは次のオプションを使用します
options: {
elements: {
center: {
text: 'Red is 2/3 the total numbers',
color: '#FF6384', // Default is #000000
fontStyle: 'Arial', // Default is Arial
sidePadding: 20, // Default is 20 (as a percentage)
minFontSize: 20, // Default is 20 (in px), set to false and text will not wrap.
lineHeight: 25 // Default is 25 (in px), used for when text wraps
}
}
}
クレジット@ジェナ・スローンこのソリューションで使用されている数学に関するヘルプ。