gsap实现六种鼠标悬浮照片拖影丝滑动画效果代码

代码语言:html

所属分类:画廊相册

代码描述:gsap实现六种鼠标悬浮照片拖影丝滑动画效果代码

代码标签: gsap 六种 鼠标 悬浮 照片 拖影 丝滑 动画

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en" >

<head>
  <meta charset="UTF-8">
  


  
<style>
@font-face {
  font-family: "PPSupplyMono";
  src: url("//repo.bfw.wiki/bfwrepo/font/PPSupplyMono-Regular.ttf")
    format("truetype");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: "GT Standard";
  src: url("//repo.bfw.wiki/bfwrepo/font/GT-Standard-VF-Trial.woff2")
    format("woff2-variations");
  font-weight: 300 900;
  font-stretch: 0% 150%;
  font-style: normal;
}

:root {
  --font-sans: "GT Standard", system-ui, "Segoe UI", Roboto, Helvetica, Arial,
    sans-serif;
  --font-mono: "PPSupplyMono", "Courier New", monospace;
  --color-bg: #ff3300;
  --color-text: #ffffff;
  --color-accent: #000000;
  --color-text-dark: #888888;
  --color-text-darker: #666666;
  --color-text-light: #5a5a5a;
  --color-gradient-1: #3a3a3a;
  --color-gradient-2: #3f3f3f;
  --color-gradient-3: #444444;
  --color-gradient-4: #494949;
  --color-gradient-5: #4e4e4e;
  --color-gradient-6: #535353;
  --color-gradient-7: #585858;
  --color-gradient-8: #5d5d5d;
  --color-gradient-9: #626262;
  --color-gradient-10: #676767;
  --color-gradient-11: #6c6c6c;
  --color-gradient-12: #717171;
  --color-gradient-13: #767676;
  --color-gradient-14: #7b7b7b;
  --color-gradient-15: #808080;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
  overflow-x: hidden;
}

body {
  font-family: var(--font-sans);
  background-color: #000;
  touch-action: pan-y;
}

body::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("https://assets.codepen.io/7558/noise-002.png");
  background-repeat: repeat;
  background-size: 200px 200px;
  opacity: 0.05;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: screen;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background-color: transparent;
  padding: 2rem;
}

.container {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
}

.logo-container {
  display: block;
  width: 3rem;
  height: 1.5rem;
  position: relative;
}

.logo-circles {
  position: relative;
  width: 100%;
  height: 100%;
}

.circle {
  position: absolute;
  border-radius: 50%;
  transition: transform 0.3s ease;
  width: 1.4rem;
  height: 1.4rem;
  background-color: var(--color-text);
  top: 50%;
}

.circle-1 {
  left: 0;
  transform: translate(0, -50%);
}

.circle-2 {
  left: 0.8rem;
  transform: translate(0, -50%);
  mix-blend-mode: exclusion;
}

.logo-container:hover .circle-1 {
  transform: translate(-0.5rem, -50%);
}

.logo-container:hover .circle-2 {
  transform: translate(0.5rem, -50%);
}

.effects {
  text-align: left;
}

.social {
  text-align: right;
}

ul {
  list-style: none;
}

header a {
  position: relative;
  cursor: pointer;
  color: var(--color-text);
  padding: 0;
  display: inline-block;
  z-index: 1;
  text-decoration: none;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  opacity: 0.7;
  transition: color 0.3s ease;
}

header a::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: var(--color-text);
  z-index: -1;
  transition: width 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

header a:hover::after {
  width: 100%;
}

header a:hover {
  color: #222220;
  mix-blend-mode: difference;
  opacity: 1;
}

header a.active {
  opacity: 1;
  color: #222220;
  mix-blend-mode: difference;
}

header a.active::after {
  width: 100%;
}

.hero-section {
  position: relative;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, #0a0a0a 100%);
  overflow: hidden;
  margin: 0;
  padding: 0;
}

/* Text Columns */
.text-columns {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
  width: 100vw;
  padding: 0 2rem;
}

.text-column {
  grid-column: span 4;
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

.text-item {
  font-family: var(--font-sans);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.5px;
  opacity: 0;
  transform: translateY(20px);
  filter: blur(10px);
}

.text-item:nth-child(1) {
  color: var(--color-gradient-1);
}

.text-item:nth-child(2) {
  color: var(--color-gradient-2);
}

.text-item:nth-child(3) {
  color: var(--color-gradient-3);
}

.text-item:nth-child(4) {
  color: var(--color-gradient-4);
}

.text-item:nth-child(5) {
  color: var(--color-gradient-5);
}

.text-item:nth-child(6) {
  color: var(--color-gradient-6);
}

.text-item:nth-child(7) {
  color: var(--color-gradient-7);
}

.text-item:nth-child(8) {
  color: var(--color-gradient-8);
}

.text-item:nth-child(9) {
  color: var(--color-gradient-9);
}

.text-item:nth-child(10) {
  color: var(--color-gradient-10);
}

.text-item:nth-child(11) {
  color: var(--color-gradient-11);
}

.text-item:nth-child(12) {
  color: var(--color-gradient-12);
}

.text-item:nth-child(13) {
  color: var(--color-gradient-13);
}

.text-item:nth-child(14) {
  color: var(--color-gradient-14);
}

.text-item:nth-child(15) {
  color: var(--color-gradient-15);
}

.text-item.visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0px);
}

/* Rotated Text - Right Bottom */
.rotated-text {
  position: absolute;
  right: 50px;
  top: 0;
  height: 100vh;
  z-index: 5;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  align-items: center;
}

.rotated-item {
  color: var(--color-text-dark);
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.5px;
  transform: rotate(90deg);
  transform-origin: center;
  white-space: nowrap;
  opacity: 0;
  filter: blur(10px);
}

.rotated-item.visible {
  opacity: 1;
  filter: blur(0px);
}

.hero-svg {
  width: 100vw;
  height: auto;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

/* Individual Letter Z-Indexes for layering effect */
.letter-f {
  z-index: 13;
}

.letter-l {
  z-index: 11;
}

.letter-a {
  z-index: 13;
}

.letter-m {
  z-index: 11;
}

.letter-e {
  z-index: 13;
}

.trail-img {
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  transform-origin: center;
  pointer-events: none;
  will-change: transform;
  z-index: 12;
}

.trail-image {
  position: absolute;
  overflow: hidden;
  will-change: transform;
  transform-origin: center;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
  z-index: 12;
}

.image-fragment {
  position: absolute;
  overflow: hidden;
  will-change: transform,.........完整代码请登录后点击上方下载按钮下载查看

网友评论0