How to create bouncing div animation

后端 未结 7 537
臣服心动
臣服心动 2021-02-01 19:12

I\'m trying to re-create the bouncing arrow animation like on: http://www.codecomputerlove.com/ but it\'s not going well...

The closest I\'ve got with trying to use the

7条回答
  •  余生分开走
    2021-02-01 19:36

    You can do it manually, frame-by-frame using CSS or you can probably automate it with SCSS with a bit of math and iteration.

    body{ overflow:hidden; } 
    
    .ball{
      --size: 50px;
      --bounceHeight: 120px;
      --duration: .4s;
      width: var(--size);
      height: var(--size);
      margin: auto;
      position: absolute;
      top: 0; 
      left: 0;
      right: 0;
      perspective: 1000px;
    }
    
    /* bouncing */
    .ball::before{
      content: '';
      display: block;
      width: inherit;
      height: inherit;
      background: radial-gradient(ellipse at 30% 20%, LightSalmon, transparent 40%), 
                  radial-gradient(circle at -20% -30%, tomato 60%, darkred);
      border-radius: 50%;
      box-shadow: 0 0 10px rgba(0,0,0,.1) inset;
      animation: bounce var(--duration) infinite alternate cubic-bezier(1,0,.8,.9); 
    }
    
    /* shadow */
    .ball::after{
      content: '';
      position: absolute;
      z-index: -1;
      bottom: 0; 
      left: 0;
      right: 0;
      display: block;
      width: inherit;
      height: 20%;
      color: #CCC;
      background-color: currentColor;
      border-radius: 50%;
      transform: translateY(var(--bounceHeight)) scale(.8);
      animation: bounceShadow var(--duration) infinite alternate cubic-bezier(1,0,.8,.9); 
    }
    
    @keyframes bounce {
        85%  { transform: translateY(calc(var(--bounceHeight) - 3px)); }
        86%  { transform: translateY(calc(var(--bounceHeight) - 3px)) scale(1.1, .9); }
        100%  { transform: translateY(var(--bounceHeight)) scale(1.4, .5); }
    }
    
    @keyframes bounceShadow {
        0%  { box-shadow: 0 0 10px 8px currentColor; color:#EEE; }
        90%  { box-shadow: 0 0 3px 3px currentColor; }
        91%  { box-shadow: 0 0 2px 2px currentColor; }
        100%  { box-shadow: 0 0 0px currentColor; }
    }

提交回复
热议问题