ZetCode

JavaScript Canvas Rotate Tutorial

last modified April 3, 2025

In this article, we explore the Canvas rotation methods in JavaScript. Rotation is a fundamental transformation that allows you to spin shapes and paths around a point. Mastering rotation is crucial for creating dynamic graphics.

Basic Definition

Canvas rotation refers to the process of spinning shapes around a specified point (usually the origin). The rotation angle is measured in radians, with positive values rotating clockwise.

The main rotation method is rotate(angle), which applies a rotation transformation to the canvas. Rotation affects all subsequent drawing operations until the canvas state is restored.

Basic Rotation Example

This example demonstrates how to rotate a simple rectangle on canvas.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic Canvas Rotation</title>
</head>
<body>

<canvas id="myCanvas" width="300" height="200"></canvas>

<script>
    const canvas = document.getElementById('myCanvas');
    const ctx = canvas.getContext('2d');
    
    // Save the default state
    ctx.save();
    
    // Rotate 45 degrees (convert to radians)
    ctx.rotate(Math.PI / 4);
    
    // Draw a rectangle
    ctx.fillStyle = 'blue';
    ctx.fillRect(50, 50, 100, 50);
    
    // Restore the default state
    ctx.restore();
</script>

</body>
</html>

In this basic example, we first save the default canvas state. We then rotate the canvas by 45 degrees (π/4 radians) using the rotate method.

The rectangle is drawn after rotation, so it appears rotated. Finally, we restore the canvas to its original state using restore.

Rotation Around a Point

This example shows how to rotate a shape around a specific point.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Rotation Around Point</title>
</head>
<body>

<canvas id="myCanvas" width="300" height="200"></canvas>

<script>
    const canvas = document.getElementById('myCanvas');
    const ctx = canvas.getContext('2d');
    
    const centerX = 150;
    const centerY = 100;
    const angle = Math.PI / 6; // 30 degrees
    
    ctx.save();
    
    // Move to center point, rotate, then move back
    ctx.translate(centerX, centerY);
    ctx.rotate(angle);
    ctx.translate(-centerX, -centerY);
    
    // Draw rectangle
    ctx.fillStyle = 'red';
    ctx.fillRect(centerX - 50, centerY - 25, 100, 50);
    
    ctx.restore();
    
    // Mark the rotation point
    ctx.fillStyle = 'black';
    ctx.beginPath();
    ctx.arc(centerX, centerY, 5, 0, Math.PI * 2);
    ctx.fill();
</script>

</body>
</html>

To rotate around a specific point, we first translate to that point, rotate, then translate back. This technique is essential for controlled rotation.

The example rotates a rectangle 30 degrees around its center point (150,100). We also draw a small black dot to mark the rotation center.

Animated Rotation

This example demonstrates smooth animation using rotation.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Animated Rotation</title>
</head>
<body>

<canvas id="myCanvas" width="300" height="300"></canvas>

<script>
    const canvas = document.getElementById('myCanvas');
    const ctx = canvas.getContext('2d');
    
    let angle = 0;
    const centerX = canvas.width / 2;
    const centerY = canvas.height / 2;
    
    function draw() {
        // Clear canvas
        ctx.clearRect(0, 0, canvas.width, canvas.height);
        
        ctx.save();
        ctx.translate(centerX, centerY);
        ctx.rotate(angle);
        ctx.translate(-centerX, -centerY);
        
        // Draw triangle
        ctx.fillStyle = 'green';
        ctx.beginPath();
        ctx.moveTo(centerX, centerY - 50);
        ctx.lineTo(centerX - 30, centerY + 40);
        ctx.lineTo(centerX + 30, centerY + 40);
        ctx.closePath();
        ctx.fill();
        
        ctx.restore();
        
        // Increase angle for next frame
        angle += 0.02;
        if (angle > Math.PI * 2) angle = 0;
        
        // Request next animation frame
        requestAnimationFrame(draw);
    }
    
    // Start animation
    draw();
</script>

</body>
</html>

This example creates a continuously rotating triangle using the requestAnimationFrame method for smooth animation.

The rotation angle increases slightly each frame, creating the animation effect. The canvas is cleared before each redraw to prevent smearing.

Multiple Rotated Objects

This example shows how to draw multiple objects with different rotations.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Multiple Rotated Objects</title>
</head>
<body>

<canvas id="myCanvas" width="400" height="300"></canvas>

<script>
    const canvas = document.getElementById('myCanvas');
    const ctx = canvas.getContext('2d');
    
    function drawRotatedRect(x, y, width, height, angle, color) {
        ctx.save();
        ctx.translate(x, y);
        ctx.rotate(angle);
        
        ctx.fillStyle = color;
        ctx.fillRect(-width/2, -height/2, width, height);
        
        ctx.restore();
    }
    
    // Draw multiple rotated rectangles
    drawRotatedRect(100, 100, 80, 40, Math.PI/6, 'blue');
    drawRotatedRect(200, 150, 60, 60, Math.PI/4, 'red');
    drawRotatedRect(300, 100, 100, 30, Math.PI/3, 'green');
</script>

</body>
</html>

Here we create a helper function drawRotatedRect that draws a rectangle rotated around its center. The function handles translation and rotation internally.

We then use this function to draw three rectangles at different positions with different rotation angles and colors. This demonstrates reusable rotation code.

Combining Rotation with Other Transformations

This example combines rotation with scaling and translation.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Combined Transformations</title>
</head>
<body>

<canvas id="myCanvas" width="400" height="300"></canvas>

<script>
    const canvas = document.getElementById('myCanvas');
    const ctx = canvas.getContext('2d');
    
    // Draw original shape (reference)
    ctx.fillStyle = 'rgba(200, 200, 200, 0.5)';
    ctx.fillRect(100, 100, 100, 50);
    
    // Apply transformations
    ctx.save();
    ctx.translate(200, 150);  // Move origin
    ctx.rotate(Math.PI / 3);  // Rotate 60 degrees
    ctx.scale(1.5, 1.5);      // Scale up
    
    // Draw transformed shape
    ctx.fillStyle = 'rgba(255, 0, 0, 0.7)';
    ctx.fillRect(-50, -25, 100, 50); // Draw centered on new origin
    
    ctx.restore();
</script>

</body>
</html>

This example demonstrates how transformations are applied in sequence: first translation, then rotation, then scaling. The order matters.

We draw a semi-transparent gray rectangle as reference, then a transformed red rectangle. The transformed rectangle is scaled, rotated, and moved.

Source

MDN Canvas rotate Documentation

In this article, we have explored various techniques for rotating shapes on HTML canvas. Mastering rotation is essential for creating dynamic and interactive graphics in web applications.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all JS Canvas tutorials.