嗨,我有下面的代碼,在畫布上生成螺旋,我想要的是螺旋被動畫,因爲它是繪製,在這一刻下面的代碼,螺旋是當頁面加載時完全繪製。我想看到正在繪製的螺旋。我想使用requestAnimationFrame來完成這項工作。如何動畫螺旋的繪製
我的HTML
<!DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" href="styles.css">
<meta charset="utf-8">
<title>Spiral</title>
</head>
<body>
<canvas id="canvas" style="border: 1px solid black" width="300" height="300"></canvas>
<script src="scripts.js"></script>
</body>
</html>
和我的javascript
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
var centerX = canvas.width/2;
var centerY = canvas.height/2;
ctx.moveTo(centerX,centerY);
var gap =2;
var steps = 60;
var increment = 2*Math.PI/steps;
var theta = increment;
while(theta < 20*Math.PI) {
var newX = centerX + theta * Math.cos(theta) * gap;
var newY = centerY + theta * Math.sin(theta) * gap;
ctx.lineTo(newX,newY);
theta = theta + increment;
}
ctx.stroke();
請參閱的jsfiddle https://jsfiddle.net/gustav1105/hx8tm43k/
看一看這個線程:http://stackoverflow.com/questions/31096766/creating-the-butterfly-curve-with-arrays特別是要注意'tavnab's'答案,它提供了靜態和動畫版本。 (完全不同的曲線) – enhzflep