我使用Chart.js创建饼图。我需要每张图表为76x76px。不幸的是,渲染图表总是比包装div和画布本身的尺寸小一点。
如果你在 FIDDLE 中检查图表,你就会明白我的意思:canvas
元素的大小是固定的,但图表本身并没有&# 39;完全填充它。
这几乎就像是为那些不存在的东西保留了一个上边距。
代码:
HTML
<div class="wrapper">
<canvas id="myChart" width="76" height="76"></canvas>
</div>
JS
var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
datasets: [{
data: [30, 70],
backgroundColor: [
'green',
'gray'
],
borderWidth: 0
}]
},
options: {
tooltips: {
enabled: false
},
events: []
}
});
CSS
.wrapper {
width: 76px;
height: 76px;
}
我应该怎样做才能让饼图填满76x76px画布?
答案 0 :(得分:5)
为legend
保留了额外空间,默认情况下已启用。只需禁用它,您就应该拥有图表的整个空间:
legend: {
display: false
}
一个工作示例:
var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
datasets: [{
data: [30, 70],
backgroundColor: [
'green',
'gray'
],
borderWidth: 0
}]
},
options: {
tooltips: {
enabled: false
},
legend: {
display: false // <- the important part
},
events: []
}
});
&#13;
.wrapper {
width: 76px;
height: 76px;
border: 1px solid black; /* for demonstration purposes*/
}
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.2/Chart.min.js"></script>
<div class="wrapper">
<canvas id="myChart" width="76" height="76"></canvas>
</div>
&#13;