gsap实现全屏图文水平时间线幻灯片切换效果代码
代码语言:html
所属分类:幻灯片
代码描述:gsap实现全屏图文水平时间线幻灯片切换效果代码
代码标签: gsap 全屏 图文 水平 时间线 幻灯片 切换
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Oswald:wght@500&display=swap");
body {
margin: 0;
background-color: #1a1a1a;
color: #FFFFFFDD;
position: relative;
overflow: hidden;
font-family: "Inter", sans-serif;
}
.card {
position: absolute;
left: 0;
top: 0;
background-position: center;
background-size: cover;
box-shadow: 6px 6px 10px 2px rgba(0, 0, 0, 0.6);
}
#btn {
position: absolute;
top: 690px;
left: 16px;
z-index: 99;
}
.card-content {
position: absolute;
left: 0;
top: 0;
color: #FFFFFFDD;
padding-left: 16px;
}
.content-place {
margin-top: 6px;
font-size: 13px;
font-weight: 500;
}
.content-place {
font-weight: 500;
}
.content-title-1,
.content-title-2 {
font-weight: 600;
font-size: 20px;
font-family: "Oswald", sans-serif;
}
.content-start {
width: 30px;
height: 5px;
border-radius: 99px;
background-color: #FFFFFFDD;
}
.details {
z-index: 22;
position: absolute;
top: 240px;
left: 60px;
}
.details .place-box {
height: 46px;
overflow: hidden;
}
.details .place-box .text {
padding-top: 16px;
font-size: 20px;
}
.details .place-box .text:before {
top: 0;
left: 0;
position: absolute;
content: "";
width: 30px;
height: 4px;
border-radius: 99px;
background-color: white;
}
.details .title-1,
.details .title-2 {
font-weight: 600;
font-size: 72px;
font-family: "Oswald", sans-serif;
}
.details .title-box-1,
.details .title-box-2 {
margin-top: 2px;
height: 100px;
overflow: hidden;
}
.details > .desc {
margin-top: 16px;
width: 500px;
}
.details > .cta {
width: 500px;
margin-top: 24px;
display: flex;
align-items: center;
}
.details > .cta > .bookmark {
border: none;
background-color: #ecad29;
width: 36px;
height: 36px;
border-radius: 99px;
color: white;
display: grid;
place-items: center;
}
.details > .cta > .bookmark svg {
width: 20px;
height: 20px;
}
.details > .cta > .discover {
border: 1px solid #ffffff;
background-color: transparent;
height: 36px;
border-radius: 99px;
color: #ffffff;
padding: 4px 24px;
font-size: 12px;
margin-left: 16px;
text-transform: uppercase;
}
nav {
position: fixed;
left: 0;
top: 0;
right: 0;
z-index: 50;
display: flex;
align-items: center;
justify-content: space-between;
padding: 20px 36px;
font-weight: 500;
}
nav svg {
width: 20px;
height: 20px;
}
nav .svg-container {
width: 20px;
height: 20px;
}
nav > div {
display: inline-flex;
align-items: center;
text-transform: uppercase;
font-size: 14px;
}
nav > div:first-child {
gap: 10px;
}
nav > div:last-child {
gap: 24px;
}
nav > div:last-child > .active {
position: relative;
}
nav > div:last-child > .active:after {
bottom: -8px;
left: 0;
right: 0;
position: absolute;
content: "";
height: 3px;
border-radius: 99px;
background-color: #ecad29;
}
.indicator {
position: fixed;
left: 0;
right: 0;
top: 0;
height: 5px;
z-index: 60;
background-color: #ecad29;
}
.pagination {
position: absolute;
left: 0px;
top: 0px;
display: inline-flex;
}
.pagination > .arrow {
z-index: 60;
width: 50px;
height: 50px;
border-radius: 999px;
border: 2px solid #ffffff55;
display: grid;
place-items: center;
}
.pagination > .arrow:nth-child(2) {
margin-left: 20px;
}
.pagination > .arrow svg {
width: 24px;
height: 24px;
stroke-width: 2;
color: #ffffff99;
}
.pagination .progress-sub-container {
margin-left: 24px;
z-index: 60;
width: 500px;
height: 50px;
display: flex;
align-items: center;
}
.pagination .progress-sub-container .progress-sub-background {
width: 500px;
height: 3px;
background-color: #ffffff33;
}
.pagination .progress-sub-container .progress-sub-background .progress-sub-foreground {
height: 3px;
background-color: #ecad29;
}
.pagination .slide-numbers {
width: 50px;
height: 50px;
overflow: hidden;
z-index: 60;
position: relative;
}
.pagination .slide-numbers .item {
width: 50px;
height: 50px;
position: absolute;
color: white;
top: 0;
left: 0;
display: grid;
place-items: center;
font-size: 32px;
font-weight: bold;
}
.cover {
position: absolute;
left: 0;
top: 0;
width: 100vw;
height: 100vh;
background-color: #fff;
z-index: 100;
}
</style>
</head>
<body>
<div class="indicator"></div>
<nav>
<div>
<div class="svg-container">
<svg
xmlns="http://www.w3.org/2000/svg"
fill="none"
viewBox="0 0 24 24"
stroke-width="1.5"
stroke="currentColor"
>
<path
stroke-linecap="round"
stroke-linejoin="round"
d="M12 21a9.004 9.004 0 008.716-6.747M12 21a9.004 9.004 0 01-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 017.843 4.582M12 3a8.997 8.997 0 00-7.843 4.582m15.686 0A11.953 11.953 0 0112 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0121 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0112 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 013 12c0-1.605.42-3.113 1.157-4.418"
/>
</svg>
</div>
<div>Globe Express</div>
</div>
<div>
<div class="active">Home</div>
<div>Holidays</div>
<div>Destinations</div>
<div>Flights</div>
<div>Offers</div>
<div>Contact</div>
<div class="svg-container">
<svg
xmlns="http://www.w3.org/2000/svg"
fill="none"
viewBox="0 0 24 24"
stroke-width="1.5"
stroke="currentColor"
>
<path
stroke-linecap="round"
stroke-linejoin="round"
d="M21 21l-5.197-5.197m0 0A7.5 7.5 0 105.196 5.196a7.5 7.5 0 0010.607 10.607z"
/>
</svg>
</div>
<div class="svg-container">
<svg
xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24"
fill="currentColor"
>
<path
fill-rule="evenodd"
d="M7.5 6a4.5 4.5 0 119 0 4.5 4.5 0 01-9 0zM3.751 20.105a8.25 8.25 0 0116.498 0 .75.75 0 01-.437.695A18.683 18.683 0 0112 22.5c-2.786 0-5.433-.608-7.812-1.7a.75.75 0 01-.437-.695z"
clip-rule="evenodd"
/>
</svg>
</div>
</div>
</nav>
<div id="demo"></div>
<div class="details" id="details-even">
<div class="place-box">
<div class="text">Switzerland Alps</div>
</div>
<div class="title-box-1"><div class="title-1">SAINT</div></div>
<div class="title-box-2"><div class="title-2">ANTONIEN</div></div>
<div class="desc">
.........完整代码请登录后点击上方下载按钮下载查看
网友评论0