一个好看的圆环进程时钟美化代码

用圆形进度条告诉时间,将鼠标悬停或聚集在日期、小时、分钟和秒上单独查看他们!

<!-- saved from url=(0043)https://leigb.cn -->
<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>clock</title>
        <style>
            * {
                border: 0;
                box-sizing: border-box;
                margin: 0;
                padding: 0;
            }

            :root {
                --hue: 223;
                --bg: hsl(var(--hue),10%,90%);
                --fg: hsl(var(--hue),10%,10%);
                font-size: calc(16px + (24 - 16) * (100vw - 320px) / (1280 - 320));
            }

            body, button {
                /*color: #fff;*/
                color: #888a8f;
                /*color: #000;*/
                font: 1em/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
            }

            body {
                /*background-color: #1F1F1F;*/
                /*background-color: #FFFFFF;*/
                height: 100vh;
                display: grid;
                place-items: center;
            }

            .progress-clock {
                display: grid;
                justify-content: center;
                align-content: center;
                position: relative;
                text-align: center;
                width: 16em;
                height: 16em;
            }

            .progress-clock__time-date, .progress-clock__time-digit, .progress-clock__time-colon, .progress-clock__time-ampm {
                transition: color 0.2s linear;
                -webkit-user-select: none;
                -moz-user-select: none;
                user-select: none;
            }

            .progress-clock__time-date, .progress-clock__time-digit {
                background: transparent;
            }

            .progress-clock__time-date, .progress-clock__time-ampm {
                grid-column: 1 / 6;
            }

            .progress-clock__time-date {
                font-size: 0.75em;
                line-height: 1.33;
            }

            .progress-clock__time-digit, .progress-clock__time-colon {
                font-size: 2em;
                font-weight: 400;
                grid-row: 2;
            }

            .progress-clock__time-colon {
                line-height: 1.275;
            }

            .progress-clock__time-ampm {
                cursor: default;
                grid-row: 3;
            }

            .progress-clock__rings {
                display: block;
                position: absolute;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                z-index: -1;
            }

            .progress-clock__ring {
                opacity: 0.1;
            }

            .progress-clock__ring-fill {
                transition: opacity 0s 0.3s linear, stroke-dashoffset 0.3s ease-in-out;
            }

            .progress-clock__ring-fill--360 {
                opacity: 0;
                stroke-dashoffset: 0;
                transition-duration: 0.3s;
            }

            [data-group]:focus {
                outline: transparent;
            }

            [data-units] {
                transition: opacity 0.2s linear;
            }

            [data-group="d"]:focus, [data-group="d"]:hover {
                color: hsl(333,90%,55%);
            }

            [data-group="h"]:focus, [data-group="h"]:hover {
                color: hsl(33,90%,55%);
            }

            [data-group="m"]:focus, [data-group="m"]:hover {
                color: hsl(213,90%,55%);
            }

            [data-group="s"]:focus, [data-group="s"]:hover {
                color: hsl(273,90%,55%);
            }

            [data-group]:focus ~ .progress-clock__rings [data-units], [data-group]:hover ~ .progress-clock__rings [data-units] {
                opacity: 0.2;
            }

            [data-group="d"]:focus ~ .progress-clock__rings [data-units="d"], [data-group="d"]:hover ~ .progress-clock__rings [data-units="d"], [data-group="h"]:focus ~ .progress-clock__rings [data-units="h"], [data-group="h"]:hover ~ .progress-clock__rings [data-units="h"], [data-group="m"]:focus ~ .progress-clock__rings [data-units="m"], [data-group="m"]:hover ~ .progress-clock__rings [data-units="m"], [data-group="s"]:focus ~ .progress-clock__rings [data-units="s"], [data-group="s"]:hover ~ .progress-clock__rings [data-units="s"] {
                opacity: 1;
            }

            /* Dark theme */
            @media (prefers-color-scheme: dark) {
                :root {
                    --bg: hsl(var(--hue),10%,10%);
                    --fg: hsl(var(--hue),10%,90%);
                }

                .progress-clock__ring {
                    opacity: 0.2;
                }
            }
        </style>
    <style id="translate-plugin-css_1694057326023" type="text/css">@charset "utf-8";
      :focus {outline:none;}
      .jsfyg {position:relative; display:flex;flex-direction: column;height:100%;}
      .jsfyg h5 {display: flex;width: 100%;justify-content: space-between;align-items: center;}
      .jsfyg h5 span i {width:20px; height:20px; background:url() no-repeat -120px 0px; display: inline-block; vertical-align:middle; margin:0px 5px;}
      .jsfyg h5 em ,.webgcopy,.webbcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle; margin-right: 10px;}
      .jsfyg h5 em:hover { background-position:-100px -20px; cursor:pointer;}
      .jsfyg h5 span i.bd { background-position:-120px -22px; width:60px;}
      .jsfyg .baidu {flex:1; overflow-y:auto; padding:5px 10px; line-height:26px;word-wrap:break-word;word-break:break-all;}
      .jsfyg .baidu::-webkit-scrollbar {width:6px; background-color:#fff;}
      .jsfyg .baidu::-webkit-scrollbar-track {border-radius:10px;} 
      .jsfyg .baidu::-webkit-scrollbar-thumb {border-radius:10px;background:#d7d7d7;}
      .jsfytxt { position:relative;}
      .jsfyloading {
        position:absolute;
        top: 45%;
        left: 50%;
        color: #121212;
        font-size: 4px;
        width: 1em;
        height: 1em;
        border-radius: 50%;
        text-indent: -9999em;
        animation: load4 1.3s infinite linear;
        transform: translateX(-50%);
      }
      @keyframes load4 {
        0%,
        100% {
          box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
        }
        12.5% {
          box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
        }
        25% {
          box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
        }
        37.5% {
          box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em;
        }
        50% {
          box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em;
        }
        62.5% {
          box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
        }
        75% {
          box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0;
        }
        87.5% {
          box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em;
        }
      }

      @media (prefers-color-scheme: dark) {
        .jsfyloading{
          color: #9b9797 !important;
        }
      }
      .jsfyloading img{
        display:none;
      }

      .jsfytxtlayer { display:none; font-size:14px; color:#333;position:absolute; left:50%; top:30px; margin-left:-100px; background:#fff; width:340px; height:260px; padding:5px;z-index:200000001; border:1px solid #cfcfcf;}
      .jsfytxtlayer .jsfyg h5 { border-bottom:none; margin:10px auto 5px auto;}
      .jsfycorner { width: 0px;height: 0px;border-width: 8px 8px;border-color: transparent transparent #fff;border-style: solid; position: absolute; top:-15px; left:28%; margin-left:-8px; z-index:100001;}
      .jsfycornerbg { width: 0px;height: 0px;border-width: 9px 9px;border-color: transparent transparent #cfcfcf;border-style: solid; position: absolute; top:-18px; left:28%; margin-left:-9px; z-index:100001;}
      .jsfytxtlayerbox {height:250px; padding:5px;}
      .jsfytxttotal  {position: absolute;right: 10px;bottom: 5px; color:#666;}
      .jsfyg h5 .webgcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle;}
      .no-events{pointer-events: none !important;}
    </style></head>
    <body style="">
        
        <!-- 禁用右键开始 -->
    <script type="text/Javascript">
      document.oncontextmenu = function(e) {
        return false;
      };
      document.onselectstart = function(e) {
        return false;
      };
    </script>
    <!-- 禁用右键结束 -->
        
        <div id="clock" class="progress-clock">
            <button class="progress-clock__time-date" data-group="d" type="button">
                <small data-unit="w">星期四</small>
                <br>
                <span data-unit="y">2023</span><span>年</span>
                <span data-unit="mo">09月</span>
                <span data-unit="d">07</span><span>日</span>
            </button>
            <button class="progress-clock__time-digit" data-unit="h" data-group="h" type="button">11</button>
            <span class="progress-clock__time-colon">:</span>
            <button class="progress-clock__time-digit" data-unit="m" data-group="m" type="button">28</button>
            <span class="progress-clock__time-colon">:</span>
            <button class="progress-clock__time-digit" data-unit="s" data-group="s" type="button">56</button>
            <span class="progress-clock__time-ampm" data-unit="ap">AM</span>
            <svg class="progress-clock__rings" width="256" height="256" viewBox="0 0 256 256">
                <defs>
                    <lineargradient id="pc-red" x1="1" y1="0.5" x2="0" y2="0.5">
                        <stop offset="0%" stop-color="hsl(343,90%,55%)"></stop>
                        <stop offset="100%" stop-color="hsl(323,90%,55%)"></stop>
                    </lineargradient>
                    <lineargradient id="pc-yellow" x1="1" y1="0.5" x2="0" y2="0.5">
                        <stop offset="0%" stop-color="hsl(43,90%,55%)"></stop>
                        <stop offset="100%" stop-color="hsl(23,90%,55%)"></stop>
                    </lineargradient>
                    <lineargradient id="pc-blue" x1="1" y1="0.5" x2="0" y2="0.5">
                        <stop offset="0%" stop-color="hsl(223,90%,55%)"></stop>
                        <stop offset="100%" stop-color="hsl(203,90%,55%)"></stop>
                    </lineargradient>
                    <lineargradient id="pc-purple" x1="1" y1="0.5" x2="0" y2="0.5">
                        <stop offset="0%" stop-color="hsl(283,90%,55%)"></stop>
                        <stop offset="100%" stop-color="hsl(263,90%,55%)"></stop>
                    </lineargradient>
                </defs>
                <!-- Days of Month -->
                <g data-units="d">
                    <circle class="progress-clock__ring" cx="128" cy="128" r="74" fill="none" opacity="0.1" stroke="url(#pc-red)" stroke-width="12"></circle>
                    <circle class="progress-clock__ring-fill" data-ring="mo" cx="128" cy="128" r="74" fill="none" stroke="url(#pc-red)" stroke-width="12" stroke-dasharray="465 465" stroke-dashoffset="364.5843981481482" stroke-linecap="round" transform="rotate(-90,128,128)"></circle>
                </g>
                <!-- Hours of Day -->
                <g data-units="h">
                    <circle class="progress-clock__ring" cx="128" cy="128" r="90" fill="none" opacity="0.1" stroke="url(#pc-yellow)" stroke-width="12"></circle>
                    <circle class="progress-clock__ring-fill" data-ring="d" cx="128" cy="128" r="90" fill="none" stroke="url(#pc-yellow)" stroke-width="12" stroke-dasharray="565.5 565.5" stroke-dashoffset="294.95013888888883" stroke-linecap="round" transform="rotate(-90,128,128)"></circle>
                </g>
                <!-- Minutes of Hour -->
                <g data-units="m">
                    <circle class="progress-clock__ring" cx="128" cy="128" r="106" fill="none" opacity="0.1" stroke="url(#pc-blue)" stroke-width="12"></circle>
                    <circle class="progress-clock__ring-fill" data-ring="h" cx="128" cy="128" r="106" fill="none" stroke="url(#pc-blue)" stroke-width="12" stroke-dasharray="666 666" stroke-dashoffset="344.84" stroke-linecap="round" transform="rotate(-90,128,128)"></circle>
                </g>
                <!-- Seconds of Minute -->
                <g data-units="s">
                    <circle class="progress-clock__ring" cx="128" cy="128" r="122" fill="none" opacity="0.1" stroke="url(#pc-purple)" stroke-width="12"></circle>
                    <circle class="progress-clock__ring-fill" data-ring="m" cx="128" cy="128" r="122" fill="none" stroke="url(#pc-purple)" stroke-width="12" stroke-dasharray="766.5 766.5" stroke-dashoffset="51.09999999999999" stroke-linecap="round" transform="rotate(-90,128,128)"></circle>
                </g>
            </svg>
        </div>
    
        
        <script type="text/javascript">
            window.addEventListener("DOMContentLoaded", ()=>{
                const clock = new ProgressClock("#clock");
            }
        );

        class ProgressClock {
            constructor(qs) {
                this.el = document.querySelector(qs);
                this.time = 0;
                this.updateTimeout = null;
                this.ringTimeouts = [];
                this.update();
            }
            getDayOfWeek(day) {
                switch (day) {
                case 1:
                    return "星期一";
                case 2:
                    return "星期二";
                case 3:
                    return "星期三";
                case 4:
                    return "星期四";
                case 5:
                    return "星期五";
                case 6:
                    return "星期六";
                default:
                    return "星期日";
                }
            }
            getMonthInfo(mo, yr) {
                switch (mo) {
                case 1:
                    return {
                        name: "02月",
                        days: yr % 4 === 0 ? 29 : 28
                    };
                case 2:
                    return {
                        name: "03月",
                        days: 31
                    };
                case 3:
                    return {
                        name: "04月",
                        days: 30
                    };
                case 4:
                    return {
                        name: "05月",
                        days: 31
                    };
                case 5:
                    return {
                        name: "06月",
                        days: 30
                    };
                case 6:
                    return {
                        name: "07月",
                        days: 31
                    };
                case 7:
                    return {
                        name: "08月",
                        days: 31
                    };
                case 8:
                    return {
                        name: "09月",
                        days: 30
                    };
                case 9:
                    return {
                        name: "10月",
                        days: 31
                    };
                case 10:
                    return {
                        name: "11月",
                        days: 30
                    };
                case 11:
                    return {
                        name: "12月",
                        days: 31
                    };
                default:
                    return {
                        name: "01月",
                        days: 31
                    };
                }
            }
            update() {
                this.time = new Date();

                if (this.el) {
                    // date and time
                    const dayOfWeek = this.time.getDay();
                    const year = this.time.getFullYear();
                    const month = this.time.getMonth();
                    const day = this.time.getDate();
                    const hr = this.time.getHours();
                    const min = this.time.getMinutes();
                    const sec = this.time.getSeconds();
                    const dayOfWeekName = this.getDayOfWeek(dayOfWeek);
                    const monthInfo = this.getMonthInfo(month, year);
                    const m_progress = sec / 60;
                    const h_progress = (min + m_progress) / 60;
                    const d_progress = (hr + h_progress) / 24;
                    const mo_progress = ((day - 1) + d_progress) / monthInfo.days;
                    const units = [{
                        label: "y",
                        value: year
                    }, {
                        label: "w",
                        value: dayOfWeekName
                    }, {
                        label: "mo",
                        value: monthInfo.name,
                        progress: mo_progress
                    }, {
                        label: "d",
                        value: day < 10 ? "0" + day : day,
                        progress: d_progress
                    }, {
                        label: "h",
                        value: hr > 12 ? ((hr - 12) < 10 ? "0" + (hr - 12) : (hr - 12)) : (hr < 10 ? "0" + hr : hr),
                        progress: h_progress
                    }, {
                        label: "m",
                        value: min < 10 ? "0" + min : min,
                        progress: m_progress
                    }, {
                        label: "s",
                        value: sec < 10 ? "0" + sec : sec
                    }, {
                        label: "ap",
                        value: hr > 12 ? "PM" : "AM"
                    }];

                    // flush out the timeouts
                    this.ringTimeouts.forEach(t=>{
                        clearTimeout(t);
                    }
                    );
                    this.ringTimeouts = [];

                    // update the display
                    units.forEach(u=>{
                        // rings
                        const ring = this.el.querySelector(`[data-ring="${u.label}"]`);

                        if (ring) {
                            const strokeDashArray = ring.getAttribute("stroke-dasharray");
                            const fill360 = "progress-clock__ring-fill--360";

                            if (strokeDashArray) {
                                // calculate the stroke
                                const circumference = +strokeDashArray.split(" ")[0];
                                const strokeDashOffsetPct = 1 - u.progress;

                                ring.setAttribute("stroke-dashoffset", strokeDashOffsetPct * circumference);

                                // add the fade-out transition, then remove it
                                if (strokeDashOffsetPct === 1) {
                                    ring.classList.add(fill360);

                                    this.ringTimeouts.push(setTimeout(()=>{
                                        ring.classList.remove(fill360);
                                    }
                                    , 600));
                                }
                            }
                        }

                        // digits
                        const unit = this.el.querySelector(`[data-unit="${u.label}"]`);

                        if (unit)
                            unit.innerText = u.value;
                    }
                    );
                }

                clearTimeout(this.updateTimeout);
                this.updateTimeout = setTimeout(this.update.bind(this), 1e3);
            }
        }
        </script>
    

</body></html>
一个好看的圆环进程时钟美化代码-夕子小屋
THE END
喜欢就支持一下吧
点赞38 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码

    暂无评论内容