首页 分享 用HTML Canvas和JavaScript创建美丽的花朵动画效果

用HTML Canvas和JavaScript创建美丽的花朵动画效果

来源:花匠小妙招 时间:2024-11-25 17:31

目录

一、程序代码

二、代码原理

三、运行效果

一、程序代码

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>炫酷花朵</title>

<style>

* {

margin: 0;

padding: 0;

overflow: hidden;

background-color: black;

}

</style>

</head>

<body>

<canvas id="c"></canvas>

<script>

var C = document.getElementById("c");

var Ctx = C.getContext("2d");

var Cw = C.width = window.innerWidth,

Cx = Cw / 2;

var Ch = C.height = window.innerHeight,

Cy = Ch / 2;

var c = document.createElement("canvas");

var ctx = c.getContext("2d");

var cw = c.width = 400,

cx = cw / 2;

var ch = c.height = 400,

cy = ch / 2;

var rad = Math.PI / 180;

var frames = 0;

var stopped = true;

var Rx = 150,

Ry = 150,

kx = 3,

ky = 4,

x, y, x1, y1, x2, y2, t;

var petals = 7;

ctx.lineWidth = .25;

Ctx.translate(Cw / 2, Ch / 2);

Ctx.scale(.75, .75);

function Draw() {

frames += .3;

Ctx.clearRect(-Cw, -Ch, 2 * Cw, 2 * Ch);

t = frames * rad;

rx = Rx * Math.abs(Math.cos(t)) + 50;

ry = Ry * Math.abs(Math.sin(t)) + 50;

x = cx + rx * Math.sin(kx * t + Math.PI / 2);

y = cy + ry * Math.sin(ky * t + Math.PI / 2);

x1 = cx + rx * Math.sin(kx * t + Math.PI);

y1 = cy - ry * Math.sin(ky * t + Math.PI);

x2 = cx + rx * Math.sin(kx * t);

y2 = cy - ry * Math.sin(ky * t);

ctx.beginPath();

ctx.moveTo(x, y);

ctx.quadraticCurveTo(x1, y1, x2, y2);

ctx.strokeStyle = "hsl(" + (frames % 360) + ", 100%, 50%)";

ctx.stroke();

ctx.globalCompositeOperation = "lighter";

var img = c;

for (var i = 0; i < petals; i++) {

Ctx.globalCompositeOperation = "source-over";

Ctx.drawImage(img, -200, -400);

Ctx.rotate(2 * Math.PI / petals);

}

requestId = window.requestAnimationFrame(Draw);

}

function start() {

requestId = window.requestAnimationFrame(Draw);

stopped = false;

}

function stopAnim() {

if (requestId) {

window.cancelAnimationFrame(requestId);

}

stopped = true;

}

window.addEventListener("load", function() {

start();

}, false);

function cleanSlate() {

ctx.clearRect(0, 0, cw, ch);

stopped = true;

start();

window.setTimeout(function() {

stopAnim();

}, 30000);

}

window.setTimeout(function() {

stopAnim();

}, 30000);

C.addEventListener("click", function() {

cleanSlate();

}, false);

</script>

</body>

</html>

二、代码原理

这段代码使用HTML Canvas和JavaScript实现了一个美丽的花朵动画效果。代码中通过使用canvas元素和其上下文对象来绘制花朵的路径曲线和花瓣。其中,花朵的路径曲线是由数学公式计算得出的,并随着时间的推移而不断变化。花瓣是通过将临时canvas元素中的图形复制多次而生成的,形成了一个完整的花朵。此外,代码中还包含了一些交互功能,如点击canvas来清空临时canvas并重新开始动画。

使用 <!DOCTYPE html> 来定义文档类型为 HTML5。定义了一个包含头部信息和 body 的 HTML 页面结构。在 head 中设置页面标题和样式表,其中,样式表中通过 * 选择器来将所有元素的 margin、padding、背景色等属性设置为 0,overflow 设置为 hidden。在 body 中创建一个 canvas 元素,并设置 id 属性为 c。在 JavaScript 部分,首先获取 canvas 元素及其上下文,然后设置 canvas 的宽度和高度,并创建一个临时的 canvas 元素及其上下文,用于绘制花瓣。定义一些绘制花朵所需要的变量,例如旋转角度、花朵路径曲线的参数、花瓣数量等。将坐标原点移动到 canvas 中心,并缩放画布,然后定义绘制函数 Draw。在绘制函数中,更新帧数,清空整个 canvas,计算花朵的路径,绘制花朵的路径曲线。绘制花瓣,并请求下一帧绘制。定义开始动画函数 start 和停止动画函数 stopAnim。在页面加载完成后开始动画。定义清空临时 canvas 并重新开始动画的函数 cleanSlate。在点击 canvas 时清空临时 canvas 并重新开始动画。在页面加载后和 30 秒后,分别调用停止动画函数来停止动画。

三、运行效果

相关知识

❤️创意网页:创建一个浪漫的樱花飘落动画效果
javascript实现玫瑰花
html语言玫瑰花代码,javascript+HTML5的canvas实现七夕情人节3D玫瑰花效果代码
使用canvas技术在网页上绘制鲜花
用HTML5 + JavaScript绘制花、树
JavaScript实现情人节红玫瑰(附完整源码)
HTML入门:创建你的第一个网页
HTML + CSS + JavaScript 两小时快速入门教程
扁平化粒子动画引导页美化设计
html鲜花网站课程设计

网址: 用HTML Canvas和JavaScript创建美丽的花朵动画效果 https://www.huajiangbk.com/newsview721886.html

所属分类:花卉
上一篇: 娇的笔顺(笔画顺序)汉字娇的笔顺
下一篇: 深圳拍照|玫瑰花海里的浪漫记

推荐分享