Parallax | Html Css And JavaScript

Follow Us On Telegram  

Get Full Source Code Zipped File  

Telegram link

HTML
<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title>CODEATNOW - Parallax </title>
  <link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&display=swap" rel="stylesheet">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap" rel="stylesheet"><link rel="stylesheet" href="./style.css">

</head>
<body>
<!-- partial:index.partial.html -->
<body>
   <header class="header">
      <div class="left-wrap">
        <span class="header-text js-header-text">
          Unusual Stories.
        </span>
      </div>
      <div class="right-wrap">
        <ul class="header-menu js-header-menu">
          <li class="header-link">Tales</li>
          <li class="header-link">About</li>
          <li class="header-link">Contacts</li>
        </ul>
      </div>
   </header>
  <main>
    <section class="hero">
      <div class="hero-bg">
        <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/parallax-sky.png"/>
      </div>
      <div class="hero-parallax">
        <div class="parallax-item parallax-tree">
          <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/parallax-tree.png"/>
        </div>
        <div class="parallax-item parallax-castle">
          <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/parallax-castle.png"/>
        </div>
        <div class="parallax-item parallax-mountains">
          <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/parallax-moutains.png"/>
        </div>
      </div>
      <div class="container">
        <div class="subtitle js-anim-subtitle">
          <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/subtitle-left-arrow.svg" class="subtitle-left-arrow">
          <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/subtitle-right-arrow.svg" class="subtitle-right-arrow">
          <div class="subtitle-bg">
            <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/subtitle-bg.png">
          </div>
          <span class="btn-1">The Good Knight</span>
        </div>
        <div class="title-block">
          <h1 class="title-h1 js-anim-title">The Story of the Dilmays Kingdom</h1>
        </div>
        <div class="text-block">
          <p class="desc-1 js-anim-desc">
            King Olav is old and has only his kingdom. His daughter was kidnapped 
by the dragon Liuf. He has declared five trials: strength, honesty, generosity, courage, and sympathy.
          </p>
        </div>
        
        <div class="btn-block">
          <div class="btn">
            <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/btn-left-arrow.svg" class="btn-right-arrow">
            <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/btn-right-arrow.svg" class="btn-left-arrow">
            <div class="btn-bg">
              <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/btn-bg.png">
            </div>
            <span class="btn-2">Start the story</span>
        </div>
        </div>
      </div> 
    </section>
  </main>
  <footer>
    <div class="left-wrap">
      <span class="footer-link">Privacy policy</span>
      <span class="divider"></span>
      <span class="footer-link">Terms and conditions</span>
    </div>
    <div class="center-wrap">
      <span class="footer-link">© 2022, Zajno</span>
    </div>
    <div class="right-wrap">
      <a href="https://www.facebook.com/zajnocrew/" class="social-icon facebook-icon" target="_blank">
        <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/facebook.svg">
      </a>
      <a href="https://www.instagram.com/zajno/" class="social-icon insta-icon" target="_blank">
        <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/insta.svg">
      </a>
      <a href="https://twitter.com/ZajnoCrew" class="social-icon twitter-icon" target="_blank">
        <img src="https://cdn.zajno.com/dev/codepen/story-dilmays/twitter.svg">
      </a>
    </div>
  </footer>
</body>
<!-- partial -->
  <script src='https://unpkg.co/gsap@3/dist/gsap.min.js'></script>
<script src='https://unpkg.com/gsap@3/dist/ScrollTrigger.min.js'></script>
<script src='https://assets.codepen.io/16327/CustomEase3.min.js'></script>
<script src='https://assets.codepen.io/16327/SplitText3.min.js'></script><script  src="./script.js"></script>

</body>
</html>
CSS
@font-face {
  font-family: "Shippori Mincho";
}
@font-face {
  font-family: "Figtree";
}
html {
  font-size: 6.9444444444vw;
}

body::-webkit-scrollbar {
  display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
body {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

:root {
  --main-font: "Shippori Mincho", serif;
  --sub-font: "Figtree", serif;
  --color-black: #303030;
  --color-white: #FDFAF7;
  --font-size-h1: 0.98rem;
  --font-size-desc-1: 0.18rem;
  --font-size-header-text: 0.24rem;
  --font-size-header-link: 0.22rem;
  --font-size-btn-1: 0.14rem;
  --font-size-btn-2: 0.22rem;
  --font-size-footer-link: 0.12rem;
  --line-height-h1: 1.17rem;
  --line-height-desc-1: 0.28rem;
  --line-height-header-text: 0.24rem;
  --line-height-header-link: 0.22rem;
  --line-height-btn-1: 0.14rem;
  --line-height-btn-2: 0.22rem;
  --line-height-footer-link: 0.12rem;
}

.title-h1 {
  font-size: var(--font-size-h1);
  line-height: var(--line-height-h1);
  font-weight: 600;
  color: var(--color-black);
  font-family: var(--main-font);
}

.desc-1 {
  font-size: var(--font-size-desc-1);
  line-height: var(--line-height-desc-1);
  font-weight: 500;
  color: var(--color-black);
  font-family: var(--sub-font);
}

.header-text {
  font-size: var(--font-size-header-text);
  line-height: var(--line-height-header-text);
  font-weight: 500;
  color: var(--color-black);
  font-family: var(--main-font);
}

.header-link {
  font-size: var(--font-size-header-link);
  line-height: var(--line-height-header-link);
  font-weight: 400;
  color: var(--color-black);
  font-family: var(--sub-font);
}

.btn-1 {
  font-size: var(--font-size-btn-1);
  line-height: var(--line-height-btn-1);
  font-weight: 500;
  color: var(--color-black);
  font-family: var(--sub-font);
}

.btn-2 {
  font-size: var(--font-size-btn-2);
  line-height: var(--line-height-btn-2);
  font-weight: 600;
  color: var(--color-black);
  font-family: var(--sub-font);
}

.footer-link {
  font-size: var(--font-size-footer-link);
  line-height: var(--line-height-footer-link);
  font-weight: 500;
  color: var(--color-black);
  font-family: var(--sub-font);
}

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

img,
svg,
video {
  display: block;
  max-width: 100%;
  width: 100%;
}

img {
  display: block;
  user-drag: none;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

/* extra long transition to hide blue autofill background */
input:-webkit-autofill,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:focus {
  -webkit-transition: background-color 100000000000000000000000000000s 0s, color 100000000000000000000000000000s 0s;
  transition: background-color 100000000000000000000000000000s 0s, color 100000000000000000000000000000s 0s;
}

/* Remove Safari autofill*/
input::-webkit-contacts-auto-fill-button {
  visibility: hidden;
  display: none !important;
  pointer-events: none;
  position: absolute;
  right: 0;
}

input[type=text],
input[type=number],
input[type=email],
input[type=tel],
textarea {
  /* remove autofill blue background */
  box-shadow: inset 0 0 0 150px rgba(255, 255, 255, 0) !important;
  -webkit-box-shadow: inset 0 0 0 150px rgba(255, 255, 255, 0) !important;
  -webkit-text-fill-color: currentColor !important;
  font-size: 1rem;
  line-height: 1.5rem;
  background-color: transparent;
}

input[type=number] {
  -moz-appearance: textfield;
}

body {
  background: var(--color-white);
  position: relative;
}

.container {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0 1.22rem;
}

.header {
  display: flex;
  justify-content: space-between;
  padding: 0.64rem 0.88rem 0;
}
.header .left-wrap {
  display: flex;
}
.header .header-menu {
  display: flex;
  list-style: none;
}
.header .header-menu .header-link:not(:last-child) {
  margin-right: 0.3rem;
}

.subtitle {
  position: relative;
  width: 1.62rem;
  height: 0.41rem;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 0.12rem;
}
.subtitle-left-arrow {
  position: absolute;
  width: 0.33rem;
  height: 0.14rem;
  right: calc(100% + 0.16rem);
  top: 50%;
  transform: translateY(-50%);
}
.subtitle-right-arrow {
  position: absolute;
  width: 0.33rem;
  height: 0.14rem;
  left: calc(100% + 0.16rem);
  top: 50%;
  transform: translateY(-50%);
}
.subtitle-bg {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.subtitle-bg img {
  width: 100%;
  height: 100%;
  display: block;
}
.subtitle .btn-1 {
  text-transform: uppercase;
}

.btn {
  position: relative;
  width: 2.84rem;
  height: 0.73rem;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 0.72rem;
}
.btn-left-arrow {
  position: absolute;
  width: 0.72rem;
  height: 0.63rem;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
}
.btn-right-arrow {
  position: absolute;
  width: 0.72rem;
  height: 0.63rem;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
}
.btn-bg {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.btn-bg img {
  width: 100%;
  height: 100%;
  display: block;
}
.btn .btn-2 {
  text-transform: uppercase;
}

.hero {
  padding-top: 0.61rem;
  position: relative;
  overflow: hidden;
}
.hero .title-block {
  width: 8.7rem;
  text-align: center;
  margin: 0 auto 0.78rem;
}
.hero .text-block {
  width: 3.35rem;
  padding-bottom: 5.59rem;
}
.hero-bg {
  width: 14.4rem;
  height: 11rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.hero-bg img {
  width: 100%;
  height: 100%;
  display: block;
}
.hero-parallax {
  width: 14.4rem;
  height: 12.12rem;
  position: absolute;
  top: -0.5rem;
  left: 0;
  z-index: -1;
}
.hero .parallax-item {
  position: absolute;
}
.hero .parallax-item img {
  width: 100%;
  height: 100%;
  display: block;
}
.hero .parallax-tree {
  bottom: 0;
  left: 0;
  width: 14.41rem;
  height: 6.28rem;
  z-index: 3;
}
.hero .parallax-castle {
  bottom: 0;
  left: 0;
  width: 11.86rem;
  height: 8.91rem;
  z-index: 2;
}
.hero .parallax-mountains {
  bottom: 0;
  left: 0;
  width: 14.4rem;
  height: 3.65rem;
  z-index: 1;
}

footer {
  display: flex;
  justify-content: space-between;
  padding: 0 0.88rem 0.6rem;
  position: relative;
}
footer .left-wrap {
  display: flex;
  align-items: center;
}
footer .left-wrap .divider {
  margin: 0 0.14rem;
  height: 0.12rem;
  width: 1px;
  background: #737373;
}
footer .left-wrap span {
  display: flex;
}
footer .center-wrap {
  display: flex;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
footer .right-wrap {
  display: flex;
}
footer .right-wrap .social-icon {
  margin-right: 0.32rem;
}
footer .right-wrap .social-icon img {
  width: 100%;
  height: 100%;
  display: block;
}
footer .right-wrap .social-icon.facebook-icon {
  width: 0.09rem;
  height: 0.18rem;
}
footer .right-wrap .social-icon.insta-icon {
  width: 0.16rem;
  height: 0.16rem;
}
footer .right-wrap .social-icon.twitter-icon {
  width: 0.19rem;
  height: 0.16rem;
}
JS
gsap.registerPlugin(CustomEase, ScrollTrigger, SplitText);

const heroSection = document.querySelector('.hero');
const parallaxTree = document.querySelector('.parallax-tree');
const parallaxCastle = document.querySelector('.parallax-castle');
const parallaxMountains = document.querySelector('.parallax-mountains');

const headerText = document.querySelector('.js-header-text');
const headerMenu = document.querySelector('.js-header-menu');
const subtitle = document.querySelector('.js-anim-subtitle');
const title = document.querySelector('.js-anim-title');
const desc = document.querySelector('.js-anim-desc');

const parallaxEase = CustomEase.create('parallax-ease-in', '0.51, 0.00, 0.45, 1.00');
const customEase = CustomEase.create('custom-ease-in', '0.17, 0.17, 0.51, 1.00');
const fourtyFrames = 1.3333333;
const oneFrame = 0.0166666;
const fourFrames = 0.133333;

const titleLines = new SplitText(title, { type: "lines" }).lines;
const descChars = new SplitText(desc, { type: "lines, chars" }).lines;

gsap.set(parallaxTree, { y: '1.4rem' });
gsap.set(parallaxCastle, { y: '2.8rem' });
gsap.set(parallaxMountains, { y: '4.2rem' });

const tl = gsap.timeline({
  scrollTrigger: {
    trigger: heroSection,
    start: 'top top',
    end: 'bottom bottom-=15%',
    scrub: 1,
  },
});

const parallaxBase = { overwrite: true, ease: parallaxEase };

tl
  .to(parallaxTree, { y: 0, ...parallaxBase }, 0)
  .to(parallaxCastle, { y: 0, ...parallaxBase }, 0)
  .to(parallaxMountains, { y: 0, ...parallaxBase }, 0);

const showElements = () => {
  const timeline = gsap.timeline();
  
  const base = { duration: fourtyFrames, ease: customEase };
  
  timeline
        .fromTo(headerText, { autoAlpha: 0, y: '0.5rem' }, { autoAlpha: 1, y: 0, ...base}, 0)
        .fromTo(headerMenu, { autoAlpha: 0, y: '0.5rem' }, { autoAlpha: 1, y: 0, ...base}, fourFrames)
        .fromTo(subtitle, { autoAlpha: 0, y: '0.5rem' }, { autoAlpha: 1, y: 0, ...base}, fourFrames * 2)
        .fromTo(titleLines, { autoAlpha: 0, y: '0.5rem' }, { autoAlpha: 1, y: 0, ...base, stagger: fourFrames }, fourFrames * 3)
        .fromTo(descChars, { autoAlpha: 0, y: '0.5rem' }, { autoAlpha: 1, y: 0, ...base, stagger: fourFrames / 2 }, fourFrames * 3);
  
  return timeline;
}


document.addEventListener('DOMContentLoaded', () => {
  showElements();
});

Post a Comment

0Comments
Post a Comment (0)