1
円チャートのツールチップ値の書式設定されたデータを表示しようとしています。私のデータは名前とサイズで構成されています(サイズはバイト数です)。Google Charts - 円グラフのカスタムツールチップ値
デフォルトのツールチップでは、サイズ値にカスタムフォーマッタを使用できません。文字列を使用すると、パーセント値と凡例の名前がツールチップに表示されなくなります。これを行う方法はありますか?
私は伝説の色、名前とパーセンテージを維持したいのですが、値がより読みやすい形式に
理想
現在の間違った
var entries = [{name: 'Test1', size: 1234}, {name: 'Test2', size: 324563425}, {name: 'Test3', size: 321453452345}, {name: 'Test4', size: 789078}]
var drawChart = function(entries, elementId) {
var options = {
width: "100%",
height: 148,
fontSize: 8,
tooltip: { textStyle: { bold: true, color: '#000000', fontSize: 13 }, showColorCode: true, isHtml: true, ignoreBounds: true, text: 'both', trigger: 'selection' },
legend: { position: 'right', textStyle: { fontSize: 10 } },
chartArea: { left: 5, top: 10, right: 5, bottom: 10, height: "148", width: "100%" },
sliceVisibilityThreshold: 0,
pieSliceText: 'none',
//pieHole: 0.4,
};
var chart = new google.visualization.PieChart(document.getElementById(elementId));
var data = new google.visualization.DataTable();
data.addColumn('string', 'Name');
data.addColumn('number', 'Size');
data.addColumn({ type: 'string', role: 'tooltip' });
data.addRows(entries.length);
var i = 0;
$.each(entries, function() {
data.setCell(i, 0, this.name);
data.setCell(i, 1, this.size);
// How to make this display correctly?
// If it stays like this i lose percentage and legend name from tooltip
data.setCell(i, 2, formatBytes(this.size));
i++;
});
chart.draw(data, options);
}
var formatBytes = function (bytes, precision) {
if (isNaN(parseFloat(bytes)) || !isFinite(bytes)) return '-';
if (typeof precision === 'undefined') precision = 1;
var units = ['bytes', 'kB', 'MB', 'GB', 'TB', 'PB'],
number = Math.floor(Math.log(bytes)/Math.log(1024));
return (bytes/Math.pow(1024, Math.floor(number))).toFixed(precision) + ' ' + units[number];
};
ああ、私は何時間もCustom Formatters、DataViews、Htmlツールチップを探していましたそして、それはsetCellにずっと続いていた。 FML LOL。どうもありがとう – Matt