考试时钟是宝中各年级相互借鉴学习的产物。2021年3月19日,为照顾看不清挂钟的学生,2020级要求在考试时在班级一体机上展示时间。2021年3月23日。2019级年级张主任询问我是否可以为考试制作科目倒计时。历经几天时间,考试时钟在2019级的大型考试上与大家见面了,随后它又经过了几次升级、界面变化,如2021年4月26日使用了卡片排版。2021年6月25日,考试时钟受到2020级几名电教管理员的推荐,开始在2020级大型考试上使用。2021年8月1日,考试时钟被外部机构“借用”一次。2021年9月18日,考试时钟支持手动添加一场科目。在这期间,我学到了许多知识,也十分感谢各位的支持。
我没有JS基础,但我上路了。
01 “沉着冷静 诚信考试”
曾经有学生使用开发者工具修改了这行字。
当我得知这个消息时,很难说清楚是什么滋味。考试时钟剩下的主体部分都是自动更新的,使用一般的方法修改过也能自动恢复。
后来,我禁用了右键和键盘,勉强不让学生调出开发者工具。
oncontextmenu = onkeydown = onselectstart = function () {
return false;
}
02 “高一”
文理分科,同时考试,但是生物的考试时间减到了90分钟。原本我是使用两个网页的,但我还想把它们整合在一起。
对于我一个技术小白来说,需要一定的时间,后来索性高二高三文科理科全部都上了,反正功能写好,添加其他年级类型都是一行代码的事,造好轮子就能好好玩了。
function change(totype) {
// 切换类型时需要重新初始化的内容
now = new Date();
end = 0, progress = 0, order = 0;
today = fixDigit(now.getMonth() + 1) + "-" + fixDigit(now.getDate());
type = totype;
// console.log(type);
output("type", type);
// 切换类型的对焦动画
eleMain.style.filter = "blur(.5em)";
setTimeout(function () {
eleMain.style.filter = "blur(0)";
updateTime();
}, 500);
}
当高一入学时,我去了一趟高一年级部,向他们推荐了这个作品。
他们的反应不很正常。先是问我是不是学生会的,又问我属于哪个社团,最后还问考试时钟的控制中心在哪。
从属?是那只有百来人的学校技术交流群,还是2019级年级直属?都和考试时钟不太相属。
在哪?是我那装有系统的移动硬盘里,或是大洋之外GitHub的机房里?听起来都很不合理。
高一年级主任来了,他问:“考试时为什么要用这个?”
我如实回答:“这是年级之间相互借鉴学习的产物,2020级最先安排考试时屏幕上展示时间,随后……”
说明白了,不就是内卷嘛。 切换到“高一”时,考试时钟上还是那行字,“高一暂未启用考试时钟”。
03 “+ 临时”
这个功能的出现,来源于8月份的一个需求。
调试的路已经被堵得差不多了,不好操作,当然我得亲自在后台添加科目了。
9月份,考试时钟终于支持添加临时科目了。这当然只是在尝试与学习技术而已。
function setTemp(sh, sm, eh, em) {
sh = prompt("考试开始时间所在的小时", 17);
sm = prompt("考试开始时间所在的分钟", 0);
eh = prompt("考试结束时间所在的小时", 18);
em = prompt("考试结束时间所在的分钟", 0);
$(prompt("考试科目名称", "临时"),
today + "T" + fixDigit(sh) + ":" + fixDigit(sm),
today + "T" + fixDigit(eh) + ":" + fixDigit(em));
alert("考试科目:" + subject + "\n起止时间:"
+ getClock(start) + "~" + getClock(end));
}
04 “设置”
出于美观,时钟没有采用等宽字体,曾经出现过晚上“20:00”卡片膨胀到两行的情况;考试时有人觉得字体白色过于亮眼,有人喊反光看不清时间。最后也是为尝试与学习技术,做出了这个功能。
<div><i class="bi bi-aspect-ratio-fill"></i>缩放
<div class="selectbar">
<a onclick="relStyle('fontSize',-0.05,'em',0.75,1.25)">-</a>
<span id="fontSize">1</span>
<a onclick="relStyle('fontSize',+0.05,'em',0.75,1.25)">+</a>
</div>
</div>
<p class="dim">非必要情况请勿修改缩放</p>
<div><i class="bi bi-circle-half"></i>对比度
<div class="selectbar">
<a onclick="relStyle('opacity',-0.05,'',0.5,1)">-</a>
<span id="opacity">0.75</span>
<a onclick="relStyle('opacity',+0.05,'',0.5,1)">+</a>
</div>
</div>
<p class="dim">减少光干扰,视环境光设置</p>
你没有看错,一个function可以同时改变两种样式。
function relStyle(prop, delta, unit, minVal, maxVal) {
propVal = Number(eleMain.style[prop].replace(unit, "")) + delta;
propVal = Math.max(propVal, minVal);
propVal = Math.min(propVal, maxVal);
eleMain.style[prop] = propVal + unit;
// 保留两位小数
output(prop, Math.round(propVal * 1e2) / 1e2);
}
05 “调试”
只是为了测试考试时间轮换是否正常而写出来的功能。
if (String(location).indexOf("debug") == -1) {
updateTime = function () {
now = new Date();
// 铃声校准
// now.setMinutes(now.getMinutes() + 1);
output("clock", getClock(now));
updateExam();
}
setInterval(updateTime, 2000);
}
else {
alert("已进入调试模式,关闭本页面可返回正常模式。")
// 调试模式初始时间
now = new Date("2021-09-18T15:00+08:00");
updateTime = function () {
// 最晚结束时间
now > new Date("2021-09-20T19:00+08:00") ? change(type) : null;
// 调试模式跳过夜晚
if (now.getHours() == 19) {
now.setHours(31);
today = fixDigit(now.getMonth() + 1)
+ "-" + fixDigit(now.getDate());
}
// 调试模式速度设置
// now.setMinutes(now.getMinutes() + 1);
now.setSeconds(now.getSeconds() + 30);
output("clock", getClock(now));
updateExam();
}
setInterval(updateTime, 20);
}
updateTime();
06 “屏保预警已关闭”
屏保嘛,这种东西在考试时蹦出来让人很不舒服。
onload = function () {
// 希沃屏保剩余时间
SCREENSAVER_TIME = 45;
String(location).indexOf("noscreensaver") == -1
? setInterval(updateSST, 60000)
: null;
}
onmousemove = onmousedown = onkeydown
= function () { SCREENSAVER_TIME = 45; }
// 希沃屏保预警,2021-09屏保已经更换内容且被信息中心关闭
function updateSST() {
eleSST = document.getElementById("SSTBubble");
SCREENSAVER_TIME -= 1;
if (SCREENSAVER_TIME < 0) {
eleSST.style.backgroundColor = "rgba(255,255,255,.2)";
output("SST", "已经");
}
else if (SCREENSAVER_TIME < 10) {
eleSST.style.display = "flex";
eleSST.style.backgroundColor = "#f52";
output("SST", "在" + SCREENSAVER_TIME + "分钟后");
}
else {
eleSST.style.display = "";
}
}
07 “帮助”
如图,遇到的一些意想不到的事情。
08 鸣谢
在接下任务,学习技术的过程中,我也认识了很多朋友,与许多社团建立了沟通与联系,这大约是我高中十分宝贵的经历。
当然了,点击“阅读原文”,你也可以访问到它如今的模样。也许就在一个小时后,某个角落还有一场考试呢。
评论区
评论加载中...