@ref21

Почему при отрисовке происходит вот так?

5d0b6581160cb857760117.png

Не могу разобраться почему так происходит.
Вот код. Я выделил проблемный участок коментарием // SOS

window.onload = function() {
	const canvas = document.getElementById("draws");
	const ctx = canvas.getContext('2d');

	const months = ["JAN", "FEB", "MAR", "APR", "MAY", "JUN", "JUL", "AUG", "SEP", "OCT", "NOV", "DEC"];

	const x0 = 30; // - padding
	const y0 = 30; // - padding
	const dec = 5; // - decorating line continuetion
	const xMax = 834; // - 814(length of the X-axis) + 30( x0 padding)
	const yMax = 440; // - 410(length of the Y-axis) + 30( y0 padding)

	const width = canvas.width - x0;
	console.log(width);
	const height = canvas.height - y0;
	console.log(height);

	const yMaxDivision = 10; // -
	const xMaxDivision = 11; // -

	const xStep = Math.round((xMax - x0) / xMaxDivision); // - 67
	console.log(xStep)
	const yStep = Math.round((yMax - y0) / yMaxDivision); // - 41
	console.log(yStep)

	const strokeColor = "#989898";

  // - Draw axes
  ctx.beginPath();
  ctx.moveTo(x0, (y0 - dec)); 
  ctx.lineTo(x0, yMax);
  ctx.moveTo(x0, yMax);
  ctx.lineTo((xMax + dec), yMax);
  ctx.strokeStyle = strokeColor;
  ctx.stroke();
  ctx.closePath();

  // - Draw the Y-axis markup
  for(let i = 0, yPosition = yMax; i <= yMaxDivision; i++, yPosition -= yStep) {
  	ctx.beginPath();
  	ctx.moveTo((x0 - 15), yPosition);
  	if(i === 0)
  		ctx.strokeText( (i * 10), (x0 - 15), (yPosition + 2));
  	else if(i < 10 && i !== 0)
  		ctx.strokeText( (i * 10), (x0 - 20), (yPosition + 2));
  	else
  		ctx.strokeText( (i * 10), (x0 - 25), (yPosition + 2));
  	ctx.closePath();
  }
  
  // - Draw the X-axis markup
  for(let i = 0, xPosition = x0; i < months.length; i++, xPosition += xStep ) {
  	ctx.beginPath();
  	ctx.moveTo(xPosition, (yMax - 15));
  	ctx.strokeText(months[i], (xPosition - 8), (yMax + 15));
  	ctx.closePath();
  }

// - SOS
  function drawGrid(axis, pos, division) {
  	for(let i = 0, position = pos; i < division; i++, position += pos) {
  		ctx.beginPath();

  		if(axis === "x")
  			ctx.moveTo((position + x0), yMax);
  			ctx.lineTo((position + x0), (y0 - dec));
  			ctx.stroke();
  		if(axis === "y")
  			ctx.moveTo(x0, (yMax - position));
  			ctx.lineTo(xMax, (yMax - position));
  			ctx.stroke();

  		ctx.closePath();
  	}
  }

  drawGrid("x", xStep, xMaxDivision);
  drawGrid("y", yStep, yMaxDivision);
// - SOS

}
  • Вопрос задан
  • 68 просмотров
Решения вопроса 1
0xD34F
@0xD34F Куратор тега JavaScript
if(axis === "x")
    ctx.moveTo((position + x0), yMax);
    ctx.lineTo((position + x0), (y0 - dec));
    ctx.stroke();
if(axis === "y")
    ctx.moveTo(x0, (yMax - position));
    ctx.lineTo(xMax, (yMax - position));
    ctx.stroke();

JS вам не Python. Фигурные скобки где?
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы