Charts.js: thin donut chart background

Mobile Technologies Mobile Computing 2 years ago

0 1 0 0 0 tuteeHUB earn credit +10 pts

5 Star Rating 1 Rating
_x000D_ _x000D_ I want to create a donut chart with a thin gray background in it. The only way I found to create it is adding a second donut chart to create the background. Is there any way to do it simpler? HTML:
CSS: .chart-cont { position: relative; } #pointsUsed { position: absolute; top: 0; left: 0; z-index: 2; } #pointsUsedBg { position: absolute; top: 0; left: 0; transform: scale(0.96,0.96); } JavaScript: var pointsUsed = [ { value: 44250, color: "#FF5F33", }, { value: 100000, color: "transparent", }, ]; var pointsUsedBg = [ { value: 100000, color: "#EEEEEE", }, ]; var pointsUsed_ctx = document.getElementById("pointsUsed").getContext("2d"); var pointsUsedBg_ctx = document.getElementById("pointsUsedBg").getContext("2d"); var pointsUsed = new Chart(pointsUsed_ctx).Doughnut(pointsUsed, { segmentShowStroke: false, segmentStrokeWidth : 0, percentageInnerCutout: 87, showTooltips: false, animationEasing: 'easeInOutCubic', responsive: true }); var pointsUsedBg = new Chart(pointsUsedBg_ctx).Doughnut(pointsUsedBg, { segmentShowStroke: false, segmentStrokeWidth : 0, percentageInnerCutout: 94, showTooltips: false, animation: false, responsive: true }); JSFiddle Thanks!

Posted on 16 Aug 2022, this text provides information on Mobile Computing related to Mobile Technologies. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Take Quiz To Earn Credits!

Turn Your Knowledge into Earnings.

tuteehub_quiz

Answers (1)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 2 years ago
_x000D_ You can extend the Doughnut chart to do this, like so Chart.types.Doughnut.extend({ name: "DoughnutAlt", initialize: function (data) { // call the actual initialize Chart.types.Doughnut.prototype.initialize.apply(this, arguments); // save the actual clear method var originalClear = this.clear; // override the clear method to draw the background after each clear this.clear = function () { // call the original clear method first originalClear.apply(this, arguments) var ctx = this.chart.ctx; // use any one of the segments to get the inner and outer radius and center x and y var firstSegment = this.segments[0]; // adjust 0.3 to increaase / decrease the width of the background var gap = (firstSegment.outerRadius - firstSegment.innerRadius) * (1 - 0.3) / 2; // draw the background ctx.save(); ctx.fillStyle = "#EEE"; ctx.beginPath(); ctx.arc(firstSegment.x, firstSegment.y, firstSegment.outerRadius - gap, 0, 2 * Math.PI); ctx.arc(firstSegment.x, firstSegment.y, firstSegment.innerRadius + gap, 0, 2 * Math.PI, true); ctx.closePath(); ctx.fill(); ctx.restore(); } } }); You would call it like this var pointsUsed = new Chart(pointsUsed_ctx).DoughnutAlt(pointsUsed, { ... Fiddle - http://jsfiddle.net/7nfL1m7d/

No matter what stage you're at in your education or career, TuteeHub will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.

Important Mobile Technologies Links