coleava / me

1 stars 0 forks source link

上传之球状进度条 #33

Open coleava opened 2 years ago

coleava commented 2 years ago

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>progress</title>
    <style>
      .uploading-chart {
        width: 192px;
        height: 192px;
        background: #eaeaea;
        margin: 50px auto;
        border-radius: 50%;
        position: relative;
        transition: 0.5s;
        border: 0.5px solid #ffc831;
        padding: 4px;
      }
      .uploading-chart .process-anime {
        position: absolute;
        top: 50%;
        left: 50%;
        border: 4px solid #fff;
        transform: translate(-50%, -50%);
        width: 190px;
        height: 190px;
        background: linear-gradient(45deg, #ffc831, #fdeca6);
        border-radius: 50%;
        overflow: hidden;
      }
      .uploading-chart .process-anime .cube-a {
        background: rgba(53, 53, 53, 0.30196078431372547);
        animation: fx-rotate 15s linear infinite;
      }
      .uploading-chart .process-anime .cube-b {
        background: #fff;
        animation: fx-rotate 10s linear infinite reverse;
      }
      .uploading-chart .process-anime .cube {
        position: absolute;
        left: 50%;
        border-radius: 50%;
        width: 192px;
        height: 192px;
        transform-origin: 50% 50%;
        transition: 0.5s;
      }
      /* .uploading-chart .fx-mask {
        width: 100%;
        height: 100%;
        position: absolute;
        background: linear-gradient(137deg, hsla(0, 0%, 100%, 0.5), hsla(0, 0%, 100%, 0));
        top: 0;
        left: 0;
        z-index: 1;
      } */
      .uploading-chart .fx {
        position: absolute;
        z-index: 2;
        top: 20%;
        left: 10%;
        opacity: 0.5;
      }
      img {
        display: block;
        border-style: none;
      }
      #value {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%,-50%);
        font-size: 30px;
      }

       .tick {
        animation: tick 1.8s ease-out;
        animation-fill-mode: forwards;
        animation-delay: .93s;
        animation-delay: 0s;
        stroke-dasharray: 350;
        stroke-dashoffset: 0;
      }
      @keyframes tick {
        from {
          stroke-dashoffset: 300;
        }
        to {
          stroke-dashoffset: 0;
        }
      }
      @keyframes fx-rotate {
        0% {
          transform: translate(-50%) ;
        }
        100% {
          transform: translate(-50%) ;
        }
      }
    </style>
  </head>
  <body>
    <div class="uploading-chart uploading">
      <div class="process-anime">
        <div class="cube cube-a" style="top: 0%"></div>
        <div class="cube cube-b" style="top: 0%"></div>
        <div class="fx-mask"></div>
        <!-- <img
          src=""
          class="fx"
        /> -->
        <div id="value">
    </div>
    <svg width="190" height="170" id="svg" style="display: none">
      <!-- <circle fill="none" stroke="#68E534" stroke-width="20" stroke-linecap="round" cx="200" cy="200" r="190" class="circle" transform="rotate(-90 200 200)" /> -->
      <!-- <polyline fill="none" stroke="#68E534" stroke-width="18" points="88,214 173,284 304,138" stroke-linecap="round" stroke-linejoin="round"  /> -->
      <polyline fill="none" stroke="#68E534" stroke-width="18" points="52,102 85,135 145,66" stroke-linecap="round" stroke-linejoin="round"  />
    </svg>
    </div>

    <script>
        window.onload = function() {
            var num = 0
            setInterval(() => {

                if(num <= 100) {
                    num += 10;
                    let cube = document.querySelectorAll('.cube');
                    let value = document.getElementById('value');
                    let svg = document.getElementById('svg')
                    cube.forEach(node => {
                        node.style.top = -num + '%';
                        if(num < 101) {
                            value.style.display = 'block'
                            value.innerText = num + '%'

                            svg.style.display = 'none'
                        } else {
                            value.style.display = 'none';
                            svg.style.display = 'block'
                            svg.children[0].classList = 'tick'
                        }
                    })

                }
            },200)
        }
    </script>
  </body>
</html>