使用HTML5 Canvas进行静态/噪音动画

所以我刚刚在Awwwards探索了一大堆新的网站.其中一个特别引起我注意的是this.我刚刚做了一些基本的中间CSS内容.我想知道这些家伙是如何得到他们的字体的噪音/干扰?我完全无能为力.试过检查代码,无法理解.

我知道我不能很快建立整个事物,但我喜欢嘈杂背景的想法.

我该怎么办?任何指针将不胜感激:)

最佳答案
这是Lucas Bebber的Glitch SVG效果.

这是original and working demo

这是代码片段

body {
  background: black;
  font-family: 'Varela',sans-serif;
}
.glitch {
  color: white;
  font-size: 100px;
  position: relative;
  width: 400px;
  margin: 0 auto;
}
@keyframes noise-anim {
  $steps: 20;
  @for $i from 0 through $steps {
    # {
      percentage($i*(1/$steps))
    }
    {
      clip: rect(random(100)+px,9999px,random(100)+px,0);
    }
  }
}
.glitch:after {
  content: attr(data-text);
  position: absolute;
  left: 2px;
  text-shadow: -1px 0 red;
  top: 0;
  color: white;
  background: black;
  overflow: hidden;
  clip: rect(0,900px,0);
  animation: noise-anim 2s infinite linear alternate-reverse;
}
@keyframes noise-anim-2 {
  $steps: 20;
  @for $i from 0 through $steps {
    # {
      percentage($i*(1/$steps))
    }
    {
      clip: rect(random(100)+px,0);
    }
  }
}
.glitch:before {
  content: attr(data-text);
  position: absolute;
  left: -2px;
  text-shadow: 1px 0 blue;
  top: 0;
  color: white;
  background: black;
  overflow: hidden;
  clip: rect(0,0);
  animation: noise-anim-2 3s infinite linear alternate-reverse;
}

相关文章

vue阻止冒泡事件 阻止点击事件的执行 <div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些