strokeRect (0, 0, canvasWidth, canvasHeight);
рисует полный прямоугольник, но ширина линии уменьшается вдвое, вот пример:
<canvas></canvas>
<script>
var canvas = document.getElementsByTagName ("canvas");
var lineWidth = 10;
var canvasHeight = canvas[0].height;
var canvasWidth = canvas[0].width;
var ctx = canvas[0].getContext ("2d");
ctx.lineWidth = lineWidth;
ctx.strokeRect (0, 0, canvasWidth, canvasHeight);
</script>
data:image/s3,"s3://crabby-images/37b3f/37b3fb6fd2abca65c71645e67a0334fff772422c" alt="screenshot of problem"
Я могу это исправить, но не элегантно:
<canvas></canvas>
<script>
var canvas = document.getElementsByTagName ("canvas");
var lineWidth = 10;
var canvasHeight = canvas[0].height - lineWidth;
var canvasWidth = canvas[0].width - lineWidth;
var ctx = canvas[0].getContext ("2d");
ctx.lineWidth = lineWidth;
lineWidth /= 2;
ctx.strokeRect (lineWidth, lineWidth, canvasWidth, canvasHeight);
</script>
data:image/s3,"s3://crabby-images/0f38f/0f38fda8a747b49d4540ea4cedf230830845693f" alt="screenshot of inelegant solution"
Есть ли нативный способ сделать это? Что-то вроде атрибута css3 "box-sizing":
canvas {
box-sizing: border-box;
}
Спасибо.