搜索
开启左侧

注释

[复制链接]
赴爱 发表于 2025-6-15 04:07:40 | 显示全部楼层 |阅读模式

let timerInterval, currentCounter, lastUpdateTime, color, translationStrings, emsCount;

const elements = {
    container: document.getElementById('container'),
    color: document.querySelector('.color'),
    dyingHeader: document.querySelector(".dying-header"),
    emergencyText: document.querySelector(".emergency"),
    body: document.body,
    timer: document.querySelector('.timer'),
    timerHeader: document.querySelector(".timer-header"),
    timerSubheader: document.querySelector(".timer-subheader"),
    minuteTens: document.getElementById('minute-tens'),
    minuteOnes: document.getElementById('minute-ones'),
    secondTens: document.getElementById('second-tens'),
    secondOnes: document.getElementById('second-ones'),
    timerBoxes: document.querySelectorAll('.timer-box'),
    timerSeparator: document.querySelector(".timer-separator"),
    timerContainer: document.querySelector('.timer-container'),
    ems: document.querySelector('.ems'),
    online: document.querySelector('.online'),
    emsCounter: document.querySelector('.ems-counter')
};

const adjustEMS = (emsOnline, color, showCount) => {
    if (!showCount) {
        elements.ems.style.display = "none";
        elements.online.style.display = "none";
        return;
    }

    if (emsOnline < 1) {
        elements.ems.style.color = "rgba(195, 7, 63, 1)";
        elements.online.style.display = "none";
        elements.ems.innerHTML = translationStrings.ems_offline;
        elements.emsCounter.style.bottom = "40px";
    } else {
        elements.ems.style.color = color;
        elements.ems.innerHTML = translationStrings.ems_online;
        elements.online.innerHTML = translationStrings.currently_online + emsOnline;
        elements.online.style.display = "block";
    }

    elements.ems.style.display = "block";
};


const updateTimerDisplay = (timeLeft) => {
    const minutes = Math.floor(timeLeft / 60).toString().padStart(2, '0');
    const seconds = (timeLeft % 60).toString().padStart(2, '0');
    elements.timer.innerHTML = `${minutes}:${seconds}`;
    if (timeLeft <= 0) elements.timer.innerHTML = "00:00";
};

const setColorCSSRule = (color) => {
    const styleSheet = document.styleSheets[1];
    const cssRule = `.color { color: ${color}; }`;
    styleSheet.insertRule ? styleSheet.insertRule(cssRule, styleSheet.cssRules.length) : styleSheet.addRule('.color', `color: ${color};`);
};

const displayScreenOne = (data, color) => {
    Object.assign(elements.body.style, { backgroundImage: 'none', backgroundColor: 'rgba(0, 0, 0, 0.329)' });
    Object.assign(elements.emsCounter.style, {
        fontWeight: "bold",
        display: "block",
        top: "10px",
        left: "50%",
        transform: "translateX(-50%)",
        textAlign: "center"
    });

    adjustEMS(data.emsOnline, color, data.showCount);

    if (data.dispatched) elements.emergencyText.innerHTML = translationStrings.ems_on_the_way;
    if (data.canRespawn) {
        elements.dyingHeader.innerHTML = translationStrings.player_passed;
        elements.timerHeader.innerHTML = translationStrings.player_hurt_respawn;
    }

    Object.assign(elements.timer.style, {
        fontWeight: "bold",
        fontSize: "2rem",
        padding: "1%",
        display: "block",
        color: color !== "red" ? color : ''
    });

    elements.container.style.display = 'flex';
    updateTimerDisplay(data.counter);
};


const displayScreenTwo = (data, color) => {
    Object.assign(elements.emsCounter.style, {
        display: "block",
        top: "10px",
        left: "50%",
        transform: "translateX(-50%)",
        textAlign: "center"
    });

    adjustEMS(data.emsOnline, color, data.showCount);

    Object.assign(elements.timer.style, {
        fontWeight: "bold",
        fontSize: "2rem",
        padding: "1%",
        display: "flex",
        color: color !== "red" ? color : ''
    });

    if (data.dispatched) elements.emergencyText.innerHTML = translationStrings.ems_on_the_way;
    if (data.canRespawn) {
        elements.dyingHeader.innerHTML = translationStrings.player_passed;
        elements.timerHeader.innerHTML = translationStrings.player_hurt_respawn;
    }

    Object.assign(elements.dyingHeader.style, { fontSize: "1.2rem" });
    elements.body.style.backgroundColor = 'rgba(0, 0, 0, 0.329)';
    elements.container.style.display = 'flex';
    updateTimerDisplay(data.counter);
};


const colorNameToHex = (color) => {
    const colors = {
        "aliceblue": "#f0f8ff",
        "antiquewhite": "#faebd7",
        "aqua": "#00ffff",
        "aquamarine": "#7fffd4",
        "azure": "#f0ffff",
        "beige": "#f5f5dc",
        "bisque": "#ffe4c4",
        "black": "#000000",
        "blanchedalmond": "#ffebcd",
        "blue": "#0000ff",
        "blueviolet": "#8a2be2",
        "brown": "#a52a2a",
        "burlywood": "#deb887",
        "cadetblue": "#5f9ea0",
        "chartreuse": "#7fff00",
        "chocolate": "#d2691e",
        "coral": "#ff7f50",
        "cornflowerblue": "#6495ed",
        "cornsilk": "#fff8dc",
        "crimson": "#dc143c",
        "cyan": "#00ffff",
        "darkblue": "#00008b",
        "darkcyan": "#008b8b",
        "darkgoldenrod": "#b8860b",
        "darkgray": "#a9a9a9",
        "darkgreen": "#006400",
        "darkkhaki": "#bdb76b",
        "darkmagenta": "#8b008b",
        "darkolivegreen": "#556b2f",
        "darkorange": "#ff8c00",
        "darkorchid": "#9932cc",
        "darkred": "#8b0000",
        "darksalmon": "#e9967a",
        "darkseagreen": "#8fbc8f",
        "darkslateblue": "#483d8b",
        "darkslategray": "#2f4f4f",
        "darkturquoise": "#00ced1",
        "darkviolet": "#9400d3",
        "deeppink": "#ff1493",
        "deepskyblue": "#00bfff",
        "dimgray": "#696969",
        "dodgerblue": "#1e90ff",
        "firebrick": "#b22222",
        "floralwhite": "#fffaf0",
        "forestgreen": "#228b22",
        "fuchsia": "#ff00ff",
        "gainsboro": "#dcdcdc",
        "ghostwhite": "#f8f8ff",
        "gold": "#ffd700",
        "goldenrod": "#daa520",
        "gray": "#808080",
        "green": "#008000",
        "greenyellow": "#adff2f",
        "honeydew": "#f0fff0",
        "hotpink": "#ff69b4",
        "indianred": "#cd5c5c",
        "indigo": "#4b0082",
        "ivory": "#fffff0",
        "khaki": "#f0e68c",
        "lavender": "#e6e6fa",
        "lavenderblush": "#fff0f5",
        "lawngreen": "#7cfc00",
        "lemonchiffon": "#fffacd",
        "lightblue": "#add8e6",
        "lightcoral": "#f08080",
        "lightcyan": "#e0ffff",
        "lightgoldenrodyellow": "#fafad2",
        "lightgray": "#d3d3d3",
        "lightgreen": "#90ee90",
        "lightpink": "#ffb6c1",
        "lightsalmon": "#ffa07a",
        "lightseagreen": "#20b2aa",
        "lightskyblue": "#87cefa",
        "lightslategray": "#778899",
        "lightsteelblue": "#b0c4de",
        "lightyellow": "#ffffe0",
        "lime": "#00ff00",
        "limegreen": "#32cd32",
        "linen": "#faf0e6",
        "magenta": "#ff00ff",
        "maroon": "#800000",
        "mediumaquamarine": "#66cdaa",
        "mediumblue": "#0000cd",
        "mediumorchid": "#ba55d3",
        "mediumpurple": "#9370db",
        "mediumseagreen": "#3cb371",
        "mediumslateblue": "#7b68ee",
        "mediumspringgreen": "#00fa9a",
        "mediumturquoise": "#48d1cc",
        "mediumvioletred": "#c71585",
        "midnightblue": "#191970",
        "mintcream": "#f5fffa",
        "mistyrose": "#ffe4e1",
        "moccasin": "#ffe4b5",
        "navajowhite": "#ffdead",
        "navy": "#000080",
        "oldlace": "#fdf5e6",
        "olive": "#808000",
        "olivedrab": "#6b8e23",
        "orange": "#ffa500",
        "orangered": "#ff4500",
        "orchid": "#da70d6",
        "palegoldenrod": "#eee8aa",
        "palegreen": "#98fb98",
        "paleturquoise": "#afeeee",
        "palevioletred": "#db7093",
        "papayawhip": "#ffefd5",
        "peachpuff": "#ffdab9",
        "peru": "#cd853f",
        "pink": "#ffc0cb",
        "plum": "#dda0dd",
        "powderblue": "#b0e0e6",
        "purple": "#800080",
        "rebeccapurple": "#663399",
        "red": "#ff0000",
        "rosybrown": "#bc8f8f",
        "royalblue": "#4169e1",
        "saddlebrown": "#8b4513",
        "salmon": "#fa8072",
        "sandybrown": "#f4a460",
        "seagreen": "#2e8b57",
        "seashell": "#fff5ee",
        "sienna": "#a0522d",
        "silver": "#c0c0c0",
        "skyblue": "#87ceeb",
        "slateblue": "#6a5acd",
        "slategray": "#708090",
        "snow": "#fffafa",
        "springgreen": "#00ff7f",
        "steelblue": "#4682b4",
        "tan": "#d2b48c",
        "teal": "#008080",
        "thistle": "#d8bfd8",
        "tomato": "#ff6347",
        "turquoise": "#40e0d0",
        "violet": "#ee82ee",
        "wheat": "#f5deb3",
        "white": "#ffffff",
        "whitesmoke": "#f5f5f5",
        "yellow": "#ffff00",
        "yellowgreen": "#9acd32"
    };
    return colors[color.toLowerCase()] || color;
};



回复 论坛版权

使用道具 举报

ChatGPT 发表于 2025-6-15 04:08:33 | 显示全部楼层
以下是代码的注释及其中文翻译:
let timerInterval, currentCounter, lastUpdateTime, color, translationStrings, emsCount;

// 获取DOM元素
const elements = {
    container: document.getElementById('container'), // 主容器
    color: document.querySelector('.color'), // 颜色元素
    dyingHeader: document.querySelector(".dying-header"), // 濒死标题
    emergencyText: document.querySelector(".emergency"), // 紧急文本
    body: document.body, // 文档主体
    timer: document.querySelector('.timer'), // 定时器元素
    timerHeader: document.querySelector(".timer-header"), // 定时器标题
    timerSubheader: document.querySelector(".timer-subheader"), // 定时器副标题
    minuteTens: document.getElementById('minute-tens'), // 分钟十位
    minuteOnes: document.getElementById('minute-ones'), // 分钟个位
    secondTens: document.getElementById('second-tens'), // 秒钟十位
    secondOnes: document.getElementById('second-ones'), // 秒钟个位
    timerBoxes: document.querySelectorAll('.timer-box'), // 定时器框
    timerSeparator: document.querySelector(".timer-separator"), // 定时器分隔符
    timerContainer: document.querySelector('.timer-container'), // 定时器容器
    ems: document.querySelector('.ems'), // EMS (紧急医疗服务) 元素
    online: document.querySelector('.online'), // 在线元素
    emsCounter: document.querySelector('.ems-counter') // EMS计数器
};

// 调整EMS状态的函数
const adjustEMS = (emsOnline, color, showCount) => {
    if (!showCount) { // 如果不显示计数
        elements.ems.style.display = "none"; // 隐藏EMS元素
        elements.online.style.display = "none"; // 隐藏在线元素
        return;
    }

    if (emsOnline < 1) { // 如果没有在线EMS
        elements.ems.style.color = "rgba(195, 7, 63, 1)"; // 设置颜色为红色
        elements.online.style.display = "none"; // 隐藏在线元素
        elements.ems.innerHTML = translationStrings.ems_offline; // 显示离线文本
        elements.emsCounter.style.bottom = "40px"; // 调整EMS计数器位置
    } else { // 如果有在线EMS
        elements.ems.style.color = color; // 设置相应颜色
        elements.ems.innerHTML = translationStrings.ems_online; // 显示在线文本
        elements.online.innerHTML = translationStrings.currently_online + emsOnline; // 显示当前在线数量
        elements.online.style.display = "block"; // 显示在线元素
    }

    elements.ems.style.display = "block"; // 显示EMS元素
};

// 更新定时器显示的函数
const updateTimerDisplay = (timeLeft) => {
    const minutes = Math.floor(timeLeft / 60).toString().padStart(2, '0'); // 计算分钟并格式化
    const seconds = (timeLeft % 60).toString().padStart(2, '0'); // 计算秒钟并格式化
    elements.timer.innerHTML = `${minutes}:${seconds}`; // 更新定时器显示
    // 如果时间还剩余
    if (timeLeft) {
        const styleSheet = document.styleSheets[1];
        const cssRule = `.color { color: ${color}; }`; // 设置颜色样式
        styleSheet.insertRule ? styleSheet.insertRule(cssRule, styleSheet.cssRules.length) : styleSheet.addRule('.color', `color: ${color};`);
    }
};

// 显示第一个界面的函数
const displayScreenOne = (data, color) => {
    Object.assign(elements.body.style, { backgroundImage: 'none', backgroundColor: 'rgba(0, 0, 0, 0.329)' }); // 设置背景样式
    Object.assign(elements.emsCounter.style, {
        fontWeight: "bold",
        display: "block",
        top: "10px",
        left: "50%",
        transform: "translateX(-50%)",
        textAlign: "center"
    });

    adjustEMS(data.emsOnline, color, data.showCount); // 调整EMS状态

    if (data.dispatched) elements.emergencyText.innerHTML = translationStrings.ems_on_the_way; // 显示EMS正在路上的信息
    if (data.canRespawn) { // 如果可以复活
        elements.dyingHeader.innerHTML = translationStrings.player_passed; // 显示玩家已去世文本
        elements.timerHeader.innerHTML = translationStrings.player_hurt_respawn; // 显示复活倒计时文本
    }

    Object.assign(elements.timer.style, {
        fontWeight: "bold",
        fontSize: "2rem",
        padding: "1%",
        display: "block",
        color: color !== "red" ? color : ''
    });

    elements.container.style.display = 'flex'; // 显示容器
    updateTimerDisplay(data.counter); // 更新定时器显示
};

// 显示第二个界面的函数
const displayScreenTwo = (data, color) => {
    Object.assign(elements.emsCounter.style, {
        display: "block",
        top: "10px",
        left: "50%",
        transform: "translateX(-50%)",
        textAlign: "center"
    });

    adjustEMS(data.emsOnline, color, data.showCount); // 调整EMS状态

    Object.assign(elements.timer.style, {
        fontWeight: "bold",
        fontSize: "2rem",
        padding: "1%",
        display: "flex",
        color: color !== "red" ? color : ''
    });

    if (data.dispatched) elements.emergencyText.innerHTML = translationStrings.ems_on_the_way; // 显示EMS正在路上的信息
    if (data.canRespawn) { // 如果可以复活
        elements.dyingHeader.innerHTML = translationStrings.player_passed; // 显示玩家已去世文本
        elements.timerHeader.innerHTML = translationStrings.player_hurt_respawn; // 显示复活倒计时文本
    }

    Object.assign(elements.dyingHeader.style, { fontSize: "1.2rem" }); // 设置死亡标题字体大小
    elements.body.style.backgroundColor = 'rgba(0, 0, 0, 0.329)'; // 设置背景颜色
    elements.container.style.display = 'flex'; // 显示容器
    updateTimerDisplay(data.counter); // 更新定时器显示
};

// 将颜色名称转换为十六进制值的函数
const colorNameToHex = (color) => {
    const colors = { 
        // ... (省略的颜色映射)
    };
    return colors[color.toLowerCase()] || color; // 返回对应的十六进制值或原始颜色
};

### 注释总结:
- 此代码主要用于处理一个网页的紧急医疗服务(EMS)界面,包含显示EMS状态、倒计时、以及界面的不同显示。
- 每个函数和逻辑块都有详细的注释,指明其功能和用途,便于理解。
回复

使用道具 举报

文明发言,和谐互动
文明发言,和谐互动
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|FiveM技术教程分享 ( 冀ICP备2021005225号-1 ) |网站地图

GMT+8, 2025-6-27 21:26 , Processed in 0.096624 second(s), 9 queries , Gzip On, Redis On.

Powered by Discuz! X3.4

© 2001-2013 ELITE论坛【技术无价-分享快乐】

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