送给自己喜欢的人系列_玫瑰花

这篇博客展示了一段JavaScript代码,用于在网页上创建动态的玫瑰花特效。通过利用数学函数和Canvas API,作者创建了一个复杂而美丽的视觉效果。这段代码涉及到了图形渲染、动画帧更新和颜色处理等技术。
摘要由CSDN通过智能技术生成

玫瑰花特效

如何侵权,请联系删除
感觉不是很好看,可以练练手

// An highlighted block
<canvas id="c"></canvas>
<script type="text/javascript">
  var b = document.body;
  var c = document.getElementsByTagName("canvas")[0];
  var a = c.getContext("2d");
  document.body.clientWidth;

  with ((m = Math)) (C = cos), (S = sin), (P = pow), (R = random);
  c.width = c.height = f = 600;
  h = -250;
  function p(a, b, c) {
    if (c > 60)
      return [
        S(a * 7) * (13 + 5 / (0.2 + P(b * 4, 4))) - S(b) * 50,
        b * f + 50,
        625 + C(a * 7) * (13 + 5 / (0.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 = 0.5 / (a + 0.01) + C(b * 125) * 3 - 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) * 99 - j * 300,
          0.4 -
            a * 0.1 +
            P(1 - B * B, -h * 6) * 0.15 -
            a * b * 0.4 +
            C(a + b) / 5 +
            P(C((o * (a + 1) + (B > 0 ? w : -w)) / 25), 30) * 0.1 * (1 - B * B),
          o / 1e3 + 0.7 - o * w * 3e-6
        ];
      }
      if (c > 32) {
        c = c * 1.16 - 0.15;
        o = a * 45 - 20;
        w = b * b * h;
        z = o * S(c) + w * C(c) + 620;
        return [
          o * C(c) - w * S(c),
          28 + C(B * 0.5) * 99 - b * b * b * 60 - z / 2 - h,
          z,
          (b * b * 0.3 + P(1 - A * A, 7) * 0.15 + 0.3) * b,
          b * 0.7
        ];
      }
      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) * 0.9 + a * 0.1,
        P(1 - b, 20) / 4 + 0.05
      ];
    }
  }
  setInterval(
    'for(i=0;i<1e4;i++)if(s=p(R(),R(),i%46/.74)){z=s[2];x=~~(s[0]*f/z-h);y=~~(s[1]*f/z-h);if(!m[q=y*f+x]|m[q]>z)m[q]=z,a.fillStyle="rgb("+~(s[3]*h)+","+~(s[4]*h)+","+~(s[3]*s[3]*-80)+")",a.fillRect(x,y,1,1)}',
    0
  );
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值