Как избежать обрезания изображения с помощью <canvas> вращать?
Когда вы поворачиваете изображение с помощью холста, оно будет обрезано - как этого избежать? Я уже сделал элемент холста больше, чем изображение, но он все же отрезал края.
Пример:
<html>
<head>
<title>test</title>
<script type="text/javascript">
function startup() {
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var img = new Image();
img.src = 'player.gif';
img.onload = function() {
ctx.rotate(5 * Math.PI / 180);
ctx.drawImage(img, 0, 0, 64, 120);
}
}
</script>
</head>
<body onload='startup();'>
<canvas id="canvas" style="position: absolute; left: 300px; top: 300px;" width="800" height="800"></canvas>
</body>
</html>
Ответы
Ответ 1
Вращение всегда происходит вокруг текущего источника. Таким образом, вы можете сначала использовать перевод, чтобы перевести холст в положение, вокруг которого вы хотите повернуть (скажем, центр), затем повернуть.
например.
ctx.translate(85, 85);
ctx.rotate(5 * Math.PI / 180);
Теперь холст вращается вокруг (85, 85).
Ответ 2
В дополнение к вращению холста перед вращением вам нужно будет использовать "переводить" снова перед размещением изображения так:
ctx.translate(85, 85);
ctx.rotate(5 * Math.PI / 180); // for 5 degrees like the example from Vincent
И затем перед добавлением использования изображения снова переведите
ctx.translate(-85, -85);
Это переместит координату (0,0) ctx.drawImage(img, 0,0,10,10) обратно в ожидаемую координату 0,0 CANVAS.
Ответ 3
или просто включить функции сохранения и восстановления в холсте
ctx.save();
ctx.translate(85,85);
ctx.rotate(5 * Math.PI / 180);
ctx.fillRect(10,10,10,10);
ctx.restore();
Если вы хотите повернуть вокруг оси рисованных объектов, вы переводите их по местоположению x и y. Затем при создании объекта его местоположение x будет отрицательным на половину его ширины, а y будет отрицательной половиной его высоты.
Пример:
Square = {
x:10,
y:10,
width:10,
height:10,
angle:5
}
ctx.save();
ctx.translate(Square.x,Square.y);
ctx.rotate(Square.angle * Math.PI / 180);
ctx.fillRect(-Square.width/2,-Square.height/2,Square.width,Square.height);
ctx.restore();
Надеюсь, это поможет кому-то:)
Ответ 4
Я создал полную функцию, которая упорядочивает изображение в соответствии с углом и положением
function drawImage(myContext,imgSrc, x, y, size, rotate) {<br/>
var halfS = size / 2;<br/>
var imageCursor = new Image();<br/>
imageCursor.src = imgSrc;<br/>
myContext.save();<br/>
var tX = x - halfS;<br/>
var tY = y - halfS;<br/>
myContext.translate(tX, tY);<br/>
myContext.rotate(Math.PI / 180 * rotate);<br/>
var dX = 0, dY = 0;<br/>
if (rotate == 0) { dX = 0; dY = 0; }<br/>
else if (rotate > 0 && rotate < 90) { dX = 0; dY = -(size / (90 / rotate)); }<br/>
else if (rotate == 90) { dX = 0; dY = -size; }<br/>
else if (rotate > 90 && rotate < 180) { dX = -(size / (90 / (rotate - 90))); dY = -size; }<br/>
else if (rotate == 180) { dX = dY = -size; }<br/>
else if (rotate > 180 && rotate < 270) { dX = -size; dY = -size + (size / (90 / (rotate - 180))); }<br/>
else if (rotate == 270) { dX = -size; dY = 0; }<br/>
else if (rotate > 270 && rotate < 360) { dX = -size + (size / (90 / (rotate - 270))); dY = 0; }<br/>
else if (rotate == 360) { dX = 0; dY = 0; }<br/>
myContext.drawImage(imageCursor, dX, dY, size, size);<br/>
myContext.restore();<br/>
}