
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>全屏完整玫瑰花</title>
<style>
html, body {
margin: 0;
padding: 0;
width: 100%%;
height: 100%%;
overflow: hidden;
background: #000;
}
canvas {
display: block;
position: absolute;
top: 0;
left: 0;
width: 100%%;
height: 100%%;
}
</style>
</head>
<body>
<canvas id="c"></canvas>
</body>
<script>
var b = document.body;
var c = document.getElementsByTagName('canvas')[0];
var a = c.getContext('2d');
// 数学函数简写
with(m = Math) C = cos, S = sin, P = pow, R = random;
// 初始化画布尺寸和内存数组
var m1 = [], m2 = [], m3 = [];
var f; // 画布宽度
var h; // 缩放参数
// 设置画布为全屏并计算适当的缩放参数
function resizeCanvas() {
// 获取窗口尺寸
var windowWidth = window.innerWidth;
var windowHeight = window.innerHeight;
// 设置画布尺寸
c.width = f = windowWidth;
c.height = windowHeight;
// 根据窗口尺寸动态计算缩放参数
// 窗口越小,h的绝对值越大(花越小)
var minDimension = Math.min(windowWidth / 3, windowHeight);
h = -Math.max(300, Math.min(450, 150000 / minDimension));
// 清除画布
a.fillStyle = "#000";
a.fillRect(0, 0, c.width, c.height);
// 重置内存数组
m1 = [];
m2 = [];
m3 = [];
// 输出调试信息
console.log("Window size: " + windowWidth + "x" + windowHeight + ", h=" + h);
}
// 初始化时设置画布尺寸
resizeCanvas();
// 监听窗口大小变化,调整画布尺寸
window.addEventListener('resize', resizeCanvas);
// 玫瑰花生成函数
function p(a, b, c) {
if (c > 60) return [S(a * 7) * (13 + 5 / (.2 + P(b * 4, 4))) - S(b) * 50,
b * 600 + 50, 625 + C(a * 7) * (13 + 5 / (.2 + P(b * 4, 4))) + b * 400, a * 1 - b / 2, a
];
A = a * 2 - 1;
B = b * 2 - 1;
if (A * A + B * B < 1) {
// 花瓣部分 - 增强层次感和生动效果
if (c > 37) {
n = (j = c & 1) ? 6 : 4;
// 增加花瓣曲率变化,使花瓣更加立体
o = .5 / (a + .01) + C(b * 125) * 3.5 - a * 300;
w = b * h;
// 增加花瓣的层次变化
return [o * C(n) + w * S(n) + j * 610 - 390, o * S(n) - w * C(n) + 550 - j * 350,
1180 + C(B + A) * 120 - j * 300, // 增加深度变化
// 增强花瓣颜色变化,使其更加生动
.45 - a * .12 + P(1 - B * B, -h * 6) * .18 - a * b * .4 + C(a + b) / 4.5 +
P(C((o * (a + 1.1) + (B > 0 ? w : -w)) / 25), 30) * .12 * (1 - B * B) +
S(a * 5) * .05, // 添加细微波纹效果
// 增加花瓣色彩饱和度变化
o / 1e3 + .75 - o * w * 3e-6 + S(a * 4) * .05
]
}
// 叶子部分 - 调整颜色更鲜艳,形状更小
if (c > 32) {
c = c * 1.16 - .15;
// 缩小叶子形状,减小系数
o = a * 40 - 18; // 原来是 a * 45 - 20
// 减小叶子大小
w = b * b * h * 0.85; // 添加缩放因子0.85
z = o * S(c) + w * C(c) + 620;
return [o * C(c) - w * S(c),
// 调整叶子位置和形状
28 + C(B * .5) * 90 - b * b * b * 55 - z / 2 - h,
z,
// 增强叶子颜色,使绿色更鲜艳
(b * b * .35 + P((1 - (A * A)), 7) * .18 + .32) * b * 1.1, // 增加绿色饱和度
// 增强叶子颜色变化
b * .85 + S(a * 3) * .08 // 添加色彩变化
]
}
// 茎部分 - 略微调整使其更加鲜绿
o = A * (2 - b) * (80 - c * 2);
w = 99 - C(A) * 120 - C(b) * (-h - c * 4.9) + C(P(1 - b, 7)) * 50 + c * 2;
z = o * S(c) + w * C(c) + 700;
return [o * C(c) - w * S(c), B * 99 - C(P(b, 7)) * 50 - c / 3 - z / 1.35 + 450, z,
// 略微调整茎的颜色
(1 - b / 1.2) * .92 + a * .1,
P((1 - b), 20) / 4 + .07 // 增加绿色饱和度
]
}
}
// 渲染函数
function render() {
// 获取窗口尺寸
var windowWidth = window.innerWidth;
var windowHeight = window.innerHeight;
var sectionWidth = windowWidth / 3;
// 计算每个区域的中心点
var centerX1 = sectionWidth / 2;
var centerX2 = sectionWidth * 1.5;
var centerX3 = sectionWidth * 2.5;
var centerY = windowHeight / 2;
// 计算花朵大小和偏移量
// 根据屏幕尺寸动态计算,确保花朵完整显示
var flowerSize = Math.min(sectionWidth, windowHeight) * 0.4;
var xOffset = 80;
var yOffset = 120;
// 渲染循环
for(i=0; i<1.5e4; i++) {
// 确定绘制区域
var region = Math.floor(i %% 3);
if(s=p(R(), R(), i%%46/.74)) {
z = s[2];
// 根据区域选择中心点和偏移
var centerX;
var currentM;
if(region == 0) {
centerX = centerX1;
currentM = m1;
} else if(region == 1) {
centerX = centerX2;
currentM = m2;
} else {
centerX = centerX3;
currentM = m3;
}
// 计算坐标,使花朵居中显示
// 使用动态计算的偏移量,确保花朵完整显示
x = ~~(s[0]*600/z-h) + centerX - xOffset;
y = ~~(s[1]*600/z-h) + centerY - yOffset;
// 确保坐标在画布范围内
if(x >= 0 && x < windowWidth && y >= 0 && y < windowHeight) {
// 检查像素是否已绘制,或者当前像素是否更靠前
var q = y*f+x;
if(!currentM[q] || currentM[q]>z) {
currentM[q] = z;
// 根据区域选择不同的颜色
if(region == 0) {
// 红色玫瑰 - 原始颜色
a.fillStyle = "rgb("+~(s[3]*h*(1+R()*.1))+","+~(s[4]*h*(1+R()*.08))+","+~(s[3]*s[3]*-85-R()*12)+")";
} else if(region == 1) {
// 蓝色玫瑰 - 增加蓝色分量,减少红色分量
a.fillStyle = "rgb("+~(s[3]*h*0.2*(1+R()*.1))+","+~(s[4]*h*0.4*(1+R()*.08))+","+~(s[3]*h*1.2*(1+R()*.15))+")";
} else {
// 粉色玫瑰 - 增加红色和蓝色分量
a.fillStyle = "rgb("+~(s[3]*h*1.2*(1+R()*.15))+","+~(s[4]*h*0.3*(1+R()*.08))+","+~(s[3]*h*0.9*(1+R()*.1))+")";
}
a.fillRect(x, y, 1, 1);
}
}
}
}
// 请求下一帧动画
requestAnimationFrame(render);
}
// 开始渲染
render();
</script>
</html>
本文最后更新时间 2025-06-01
文章链接地址:https://xzlo.blog/index.php/archives/48/
本站文章除注明[转载|引用|原文]出处外,均为本站原生内容,转载前请注明出处