Холст HTML5: как сделать загрузчик, поворачивая изображение в градусах?
Я делаю загрузчик с холстом html5. У меня есть рисунок на холсте, но когда я поворачиваю его, изображение поворачивается с холста. Как я могу сказать, что это крутит графику в ее центральной точке?
<!DOCTYPE html>
<html>
<head>
<title>Canvas test</title>
<script type="text/javascript">
window.onload = function() {
var drawingCanvas = document.getElementById('myDrawing');
// Check the element is in the DOM and the browser supports canvas
if(drawingCanvas && drawingCanvas.getContext) {
// Initaliase a 2-dimensional drawing context
var context = drawingCanvas.getContext('2d');
//Load the image object in JS, then apply to canvas onload
var myImage = new Image();
myImage.onload = function() {
context.drawImage(myImage, 0, 0, 27, 27);
}
myImage.src = "img/loading.png";
context.rotate(45);
}
}
</script>
</head>
<body>
<canvas id="myDrawing" width="27" height="27">
</canvas>
</body>
</html>
Ответы
Ответ 1
Вот полный рабочий пример:)
<!DOCTYPE html>
<html>
<head>
<title>Canvas Cog</title>
<script type="text/javascript">
var cog = new Image();
function init() {
cog.src = ''; // Set source path
setInterval(draw,10);
}
var rotation = 0;
function draw(){
var ctx = document.getElementById('myCanvas').getContext('2d');
ctx.globalCompositeOperation = 'destination-over';
ctx.save();
ctx.clearRect(0,0,27,27);
ctx.translate(13.5,13.5); // to get it in the origin
rotation +=1;
ctx.rotate(rotation*Math.PI/64); //rotate in origin
ctx.translate(-13.5,-13.5); //put it back
ctx.drawImage(cog,0,0);
ctx.restore();
}
init();
</script>
</head>
<body>
<canvas width="27" height="27" id="myCanvas"></canvas>
</body>
</html>
Ответ 2
rotate
поворачивает холст (?) вокруг вашей текущей позиции, которая начинается 0, 0. вам нужно "переместиться" в нужную центральную точку, которую вы можете выполнить с помощью
context.translate(x,y);
после перемещения точки отсчета, вы хотите центрировать изображение над этой точкой. вы можете сделать это, позвонив
context.drawImage(myImage, -(27/2), -(27/2), 27, 27);
это говорит браузеру начать рисовать изображение сверху и слева от текущей точки отсчета, иметь размер изображения, тогда как перед тем, как вы начали с вашей точки отсчета и рисовали целиком ниже и вправо ( все направления относительно поворота холста).
так как ваш холст - это размер вашего изображения, ваш вызов translate
будет использовать одно и то же измерение (27/2) для координат x и y.
поэтому, чтобы собрать все это вместе
// initialization:
context.translate(27/2, 27/2);
// onload:
context.rotate(Math.PI * 45 / 180);
context.drawImage(myImage, -(27/2), -(27/2), 27, 27);
edit: также, единицы вращения являются радианами, поэтому вам нужно будет перевести градусы в радианы в вашем коде.
редактирует для переупорядочения вещей.
Ответ 3
Для всех, кто смотрит в нечто подобное, вы можете посмотреть на этот script, который выполняет именно то, что изначально запрашивалось:
http://projects.nickstakenburg.com/spinners/
Здесь вы можете найти источник github:
https://github.com/staaky/spinners
Он использует rotate, сохраняя кэш прямоугольников, которые медленно исчезают, чем старше они.
Ответ 4
Я нахожу другой способ сделать html load spinner. Вы можете использовать анимацию листа спрайтов. Этот подход может работать как с помощью html5 canvas, так и с обычным html/javascript/css. Вот простой способ, реализуемый html/javascript/css.
В качестве фона используется изображение листа спрайта. Он создает таймер Javascript для изменения положения фонового изображения для управления анимацией листа спрайтов. Ниже приведен пример кода. Вы также можете проверить результат здесь: http://jmsliu.com/1769/html-ajax-loading-spinner.html
<html>
<head><title></title></head>
<body>
<div class="spinner-bg">
<div id="spinner"></div>
</div>
<style>
.spinner-bg
{
width:44px;
height:41px;
background: #000000;
}
#spinner
{
width: 44px;
height: 41px;
background:url(./preloadericon.png) no-repeat;
}
</style>
<script>
var currentbgx = 0;
var circle = document.getElementById("spinner");
var circleTimer = setInterval(playAnimation, 100);
function playAnimation() {
if (circle != null) {
circle.style.backgroundPosition = currentbgx + "px 0";
}
currentbgx -= 44; //one frame width, there are 5 frame
//start from 0, end at 176, it depends on the png frame length
if (currentbgx < -176) {
currentbgx = 0;
}
}
</script>
</body>