gsap实现鼠标悬浮卡片交互式动画效果代码
代码语言:html
所属分类:悬停
代码描述:gsap实现鼠标悬浮卡片交互式动画效果代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<style>
@import url("https://fonts.cdnfonts.com/css/pp-neue-montreal");
:root {
--color-text: #332211;
--color-bg: #111111;
--font-primary: "PP Neue Montreal", sans-serif;
--padding: 2rem;
--grid-gutter: 1rem;
--card-size: min(
calc((100vh - 6 * var(--padding)) / 3),
calc((100vw - 6 * var(--padding)) / 3)
);
}
* {
box-sizing: border-box;
margin: 0;
padding: 0;
font-family: var(--font-primary);
}
body {
background-color: var(--color-bg);
margin: 0;
padding: 0;
width: 100vw;
height: 100vh;
overflow: hidden;
position: relative;
display: flex;
justify-content: center;
align-items: center;
letter-spacing: -0.02em;
z-index: 0;
}
/* Background noise effect */
body::before {
content: "";
position: fixed;
top: -50%;
left: -50%;
width: 200%;
height: 200%;
background: transparent
url("//repo.bfw.wiki/bfwrepo/image/5dfd8574f13f0.png") repeat 0 0;
background-size: 300px 300px;
-webkit-animation: noise-animation 0.3s steps(5) infinite;
animation: noise-animation 0.3s steps(5) infinite;
opacity: 0.15;
will-change: transform;
z-index: 500;
pointer-events: none;
}
@-webkit-keyframes noise-animation {
0% {
transform: translate(0, 0);
}
10% {
transform: translate(-5%, -5%);
}
20% {
transform: translate(-10%, 5%);
}
30% {
transform: translate(5%, -10%);
}
40% {
transform: translate(-5%, 15%);
}
50% {
transform: translate(-10%, 5%);
}
60% {
transform: translate(15%, 0);
}
70% {
transform: translate(0, 10%);
}
80% {
transform: translate(-15%, 0);
}
90% {
transform: translate(10%, 5%);
}
100% {
transform: translate(5%, 0);
}
}
@keyframes noise-animation {
0% {
transform: translate(0, 0);
}
10% {
transform: translate(-5%, -5%);
}
20% {
transform: translate(-10%, 5%);
}
30% {
transform: translate(5%, -10%);
}
40% {
transform: translate(-5%, 15%);
}
50% {
transform: translate(-10%, 5%);
}
60% {
transform: translate(15%, 0);
}
70% {
transform: translate(0, 10%);
}
80% {
transform: translate(-15%, 0);
}
90% {
transform: translate(10%, 5%);
}
100% {
transform: translate(5%, 0);
}
}
/* Dust/Scratches background effect for the entire site */
body::after {
content: "";
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-image: url("https://img.freepik.com/premium-photo/white-dust-scratches-black-background_279525-2.jpg?w=640");
background-repeat: repeat;
opacity: 0.08;
mix-blend-mode: screen;
pointer-events: none;
z-index: 1;
}
.grid-container {
width: calc(3 * var(--card-size) + 2 * var(--grid-gutter));
height: calc(3 * var(--card-size) + 2 * var(--grid-.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0