飘云阁

 找回密码
 加入我们

QQ登录

只需一步,快速开始

查看: 3383|回复: 16

[原创] 比赛倒计时2.0《大字体显示比赛倒计时器PRO》是一款简洁实用的倒计时软件

[复制链接]
  • TA的每日心情
    开心
    2024-8-8 11:24
  • 签到天数: 75 天

    [LV.6]常住居民II

    发表于 2024-4-30 15:50:21 | 显示全部楼层 |阅读模式
    首先我们先来看一下原版是这个样子。

    Snipaste_2024-04-30_15-44-21.jpg

    此次修改增加了全屏显示

    自定义修改时间

    中途暂停

    增加了快捷键控制(空格键或回车键)暂停继续

    Snipaste_2024-04-30_14-46-19.jpg

    【倒计时计时器】是一个简单易用的网页应用,可以帮助用户进行倒计时计时的操作。

    它提供了开始计时、暂停计时、全屏显示和清空数据等功能,方便用户根据自己的需求进行倒计时。

    此版本的升级内容主要包括新增暂停功能,让用户可以在倒计时进行中暂停计时,并在需要时恢复计时。

    同时增加了全屏显示按钮,提供更好的显示效果。

    Snipaste_2024-04-30_15-47-23.jpg

    此外,用户还可以使用空格键开始和暂停计时,以及回车键快速清空倒计时数据。

    所有这些改进使得倒计时计时器更加灵活、易于使用,满足用户的个性化需求。


    <!DOCTYPE html>
    <html lang="en">

    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>倒计时计时器</title>
        <style>
            body {
                font-family: Arial, sans-serif;
                margin: 0;
                padding: 0;
                box-sizing: border-box;
            }

            .header {
                background-color: #88001b;
                color: white;
                height: 180px;
                display: flex;
                justify-content: center;
                align-items: center;
                font-size: 100px;
            }

            .timer {
                display: flex;
                justify-content: center;
                align-items: center;
                height: calc(100vh - 280px);
                font-size: 30vw;
            }

            .buttons {
                position: fixed;
                bottom: 0;
                width: 100%;
                display: flex;
                justify-content: space-around;
                padding: 10px 0;
            }

            button {
                font-size: 20px;
                padding: 10px 20px;
            }
        </style>
    </head>

    <body>
        <div class="header">比赛倒计时</div>
        <div class="timer" id="timer">01:00</div>
        <div class="buttons">
            <button id="startTimer">开始计时</button>
            <button id="pauseTimer">暂停计时</button>
            <button id="fullscreenToggle">全屏显示</button>
            <button id="clearData">清空数据</button>
            <button id="customTime">自定义时间</button>
        </div>

        <audio id="startSound" src="start-timer-sound.mp3"></audio>
        <audio id="warningSound" src="warning-timer-sound.mp3"></audio>

        <script>
            let totalSeconds = 60;
            let countdown;
            let warningPlayed = false;
            let isPaused = false;

            function startTimer() {
                document.getElementById('startSound').play();
                if (!countdown && !isPaused) {
                    countdown = setInterval(timerFunction, 1000);
                } else if (isPaused) {
                    countdown = setInterval(timerFunction, 1000);
                    isPaused = false;
                }
            }

            function pauseTimer() {
                clearInterval(countdown);
                countdown = null;
                isPaused = true;
            }

            function timerFunction() {
                if (!isPaused) {
                    totalSeconds--;
                    const minutes = Math.floor(totalSeconds / 60);
                    const seconds = totalSeconds % 60;
                    document.getElementById('timer').textContent = `${String(minutes).padStart(2, '0')}:${String(seconds).padStart(2, '0')}`;

                    if (totalSeconds === 10 && !warningPlayed) {
                        document.getElementById('warningSound').play();
                        warningPlayed = true;
                    }

                    if (totalSeconds <= 0) {
                        clearInterval(countdown);
                        document.getElementById('timer').textContent = "时间到";
                    }
                }
            }

            // 按空格键开始或暂停计时
            document.addEventListener('keydown', function (event) {
                if (event.code === 'Space') {
                    event.preventDefault();
                    if (!countdown || isPaused) {
                        startTimer();
                    } else {
                        pauseTimer();
                    }
                }
            });

            // 按回车键清空数据
            document.getElementById('clearData').addEventListener('click', function () {
                totalSeconds = 60;
                clearInterval(countdown);
                countdown = null;
                isPaused = false;
                document.getElementById('timer').textContent = "01:00";
            });

            // 弹出自定义时间对话框
            document.getElementById('customTime').addEventListener('click', function () {
                const inputTime = prompt('请输入倒计时时间(单位:秒)');
                const time = parseInt(inputTime);
                if (isNaN(time)) {
                    alert('输入的时间无效,请输入一个有效的数字');
                } else {
                    totalSeconds = time;
                    document.getElementById('timer').textContent = `${String(Math.floor(time / 60)).padStart(2, '0')}:${String(time % 60).padStart(2, '0')}`;
                    if (document.fullscreenElement) {
                        document.exitFullscreen();
                    }
                }
            });

            document.getElementById('startTimer').addEventListener('click', startTimer);
            document.getElementById('pauseTimer').addEventListener('click', pauseTimer);

            document.getElementById('fullscreenToggle').addEventListener('click', function () {
                if (!document.fullscreenElement) {
                    document.documentElement.requestFullscreen().then(() => {
                        this.textContent = '退出全屏模式';
                    }).catch(err => {
                        alert(`无法进入全屏模式: ${err.message}`);
                    });
                } else {
                    if (document.exitFullscreen) {
                        document.exitFullscreen().then(() => {
                            this.textContent = '全屏显示';
                        }).catch(err => {
                            alert(`无法退出全屏模式: ${err.message}`);
                        });
                    }
                }
            });
        </script>
    </body>

    </html>


    评分

    参与人数 1威望 +1 飘云币 +1 收起 理由
    yun33 + 1 + 1 PYG有你更精彩!

    查看全部评分

    PYG19周年生日快乐!
  • TA的每日心情
    开心
    2025-1-14 19:31
  • 签到天数: 239 天

    [LV.7]常住居民III

    发表于 2024-5-2 21:34:40 | 显示全部楼层
    简单方便,谢谢大佬,如果能够同时提供那两个声音文件就完美了。
    PYG19周年生日快乐!
    回复 支持 1 反对 0

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-11 18:41
  • 签到天数: 805 天

    [LV.10]以坛为家III

    发表于 2024-4-30 18:49:40 | 显示全部楼层
    这个真不错
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-8 13:05
  • 签到天数: 1170 天

    [LV.10]以坛为家III

    发表于 2024-4-30 19:39:36 | 显示全部楼层
    这是干啥用的?
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2021-9-9 20:17
  • 签到天数: 53 天

    [LV.5]常住居民I

    发表于 2024-4-30 20:38:58 | 显示全部楼层
    能弄成EXE让我们这些小白也会使用就好了。
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-14 13:38
  • 签到天数: 538 天

    [LV.9]以坛为家II

    发表于 2024-4-30 23:33:10 来自手机 | 显示全部楼层
    大佬都是自己动手丰衣足食
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-14 07:47
  • 签到天数: 2793 天

    [LV.Master]伴坛终老

    发表于 2024-5-1 08:33:49 | 显示全部楼层
    楼主没有成品的吗。
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-14 07:47
  • 签到天数: 1855 天

    [LV.Master]伴坛终老

    发表于 2024-5-1 09:16:48 | 显示全部楼层
    谢谢楼主分享!
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2025-1-13 12:39
  • 签到天数: 2096 天

    [LV.Master]伴坛终老

    发表于 2024-5-1 15:52:34 | 显示全部楼层
    修改的不错。
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2025-1-14 11:11
  • 签到天数: 940 天

    [LV.10]以坛为家III

    发表于 2024-5-2 14:44:38 | 显示全部楼层
    挺好的,简单实用的很                                         
    PYG19周年生日快乐!
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 加入我们

    本版积分规则

    快速回复 返回顶部 返回列表