Open coleava opened 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>