Как заполнить определенную долю срезов на круговой диаграмме?

0

Вопрос

Я пытаюсь воспроизвести такой график:

Я пытаюсь понять, как заполнить определенный процент срезов в середине круговой диаграммы, но также и как заполнить диаграмму пончиков таким же образом.

Я пытался использовать fillRect (), но это не заполнило срезы так, как я хотел. Дайте мне знать, если у вас есть какие-либо идеи о том, как я мог бы получить график, аналогичный тому, который я представил выше.

var canvas = document.getElementById('Arc');
var context = canvas.getContext('2d');
var centerX = canvas.width / 2;
var centerY = canvas.height / 2;

function draw() {
  context.save();
  context.beginPath();
  context.arc(centerX, centerY, 50, 50, (Math.PI) / 2, true);
  context.clip();
  context.fillStyle = '#090A09';
  context.fillRect(centerX, centerY, -25, 50);
  context.lineWidth = 5;
  context.strokeStyle = '#000000';
  context.stroke();
}
draw();
<canvas id="Arc"></canvas>

canvas donut-chart graphics javascript
2021-11-22 16:11:56
1

Лучший ответ

0

fillRect-это просто прямоугольник, если вам нужен пирог, мы можем сделать это с помощью дуг.

Пироги, которые начинаются с центра круга, мы просто перемещаем в центр, затем рисуем дуги и заполняем их, для пирогов с пончиками мы должны сделать две дуги в противоположных направлениях и разного радиуса и позвонить fill()

смотрите примеры ниже:

var canvas = document.getElementById('Arc');
var context = canvas.getContext('2d');
var centerX = canvas.width / 2;
var centerY = canvas.height / 2;

context.beginPath();
context.strokeStyle = 'red';
context.arc(centerX, centerY, 50, 0, Math.PI * 2);
context.stroke();

context.beginPath();
context.fillStyle = 'blue';
context.moveTo(centerX, centerY)
context.arc(centerX, centerY, 50, 0, Math.PI * 0.5);
context.fill()

context.beginPath();
context.fillStyle = 'black';
context.moveTo(centerX, centerY)
context.arc(centerX, centerY, 45, Math.PI * 1.6, Math.PI * 1.8);
context.fill()

context.beginPath();
context.fillStyle = 'lime';
context.arc(centerX, centerY, 51, Math.PI, Math.PI * 1.2);
context.arc(centerX, centerY, 95, Math.PI * 1.2, Math.PI, true);
context.fill()

context.beginPath();
context.fillStyle = 'green';
context.arc(centerX, centerY, 60, Math.PI * 1.8, Math.PI * 2.1);
context.arc(centerX, centerY, 95, Math.PI * 2.1, Math.PI * 1.8, true);
context.fill()
<canvas id="Arc"></canvas>

2021-11-22 17:47:32

Большое спасибо! Это именно то, что я пытался сделать! :)
Théo

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................