这个应该是已经有很多人做过的东西,我应该只是算手痒,想写一下,所以,花了点时间折腾了这个,顺便把 Dark Mode 的处理也加上了。

首先可以很明确的一点,这个真没技术含量存在,只是需要点耐心。

LED 数字包含了左右各两条线,中间三条线,一共 7 条线。所以,为了能够更容易辨识,在写 demo 的时候,我直接这样写了。

<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>

至于 digital_0 这个的作用,其实很简单,就是控制从 0 ~ 9 这十个数字的变化而存在的。

.digital_1 .c1,
.digital_1 .c2,
.digital_1 .c3,
.digital_1 .l1,
.digital_1 .l2,
.digital_2 .l1,
.digital_2 .r2,
.digital_3 .l1,
.digital_3 .l2,
.digital_4 .c1,
.digital_4 .c3,
.digital_4 .l2,
.digital_5 .l2,
.digital_5 .r1,
.digital_6 .r1,
.digital_7 .c2,
.digital_7 .c3,
.digital_7 .l1,
.digital_7 .l2,
.digital_9 .l2,
.digital_0 .c2 {
animation: changeDigital 200ms 0ms 1 ease-in forwards;
}

这里使用了一个 animation 动画,并且时间是 200ms,主要是为了让某些部分消失的时候,有一个过渡效果。

@keyframes changeDigital {
form {
opacity:;
}
to {
opacity:;
}
}

那么剩下来的就是最需要耐心的地方了,调整控制那 7 条线的位置,同时还要考虑每条线是带有斜角的,而且还稍微有点圆弧的感觉。带点圆弧的感觉那么直接使用 border-radius 就可以了,至于那个斜角的话,如果各位知道 CSS 中用边框画三角的方法,那么就应该明白怎么做这个斜角了。

当我们要画三角的时候,width 和 height 都是为 0,然后用过控制 border-width 而得到最终的三角的大小,那么这里如果我们根据线条的位置,适当选择 width 和 height 有具体的值,是不是就有斜角的感觉了呢。

接着,需要注意横着的中间那根线,也就是 .c2 这个元素,线条两边是三角突出的,可以实现的方式也很多,这里我选择使用 :after 和 :before 相叠加。

最后就是对每个元素的位置做调整,控制好大小位置就可以了,因为是使用定位的方式来操作,所以,调整起来还是很简单的。

.digital span {
position: absolute;
border-radius: 50vh;
box-sizing: border-box;
}
.digital .c1,
.digital .c2,
.digital .c3 {
height:;
width: 26px;
border-left: 4px solid transparent;
border-right: 4px solid transparent;
}
.digital .c1 {
top:;
left:;
border-top: 4px solid currentColor;
}
.digital .c2 {
top: 50%;
left:;
margin-top: -2px;
}
.digital .c2:before,
.digital .c2:after {
content: "";
height:;
width: 24px;
border-left: 2px solid transparent;
border-right: 2px solid transparent;
box-sizing: border-box;
}
.digital .c2:before {
position: absolute;
top:;
left: -3px;
border-bottom: 2px solid currentColor;
}
.digital .c2:after {
position: absolute;
top: 2px;
left: -3px;
border-top: 2px solid currentColor;
}
.digital .c3 {
bottom:;
left:;
border-bottom: 4px solid currentColor;
}
.digital .l1,
.digital .l2 {
height: 21px;
width:;
left:;
border-top: 2px solid transparent;
border-bottom: 2px solid transparent;
border-left: 4px solid currentColor;
}
.digital .l1 {
top: 1px;
border-top-width: 4px;
}
.digital .l2 {
top: 24px;
border-bottom-width: 4px;
}
.digital .r1,
.digital .r2 {
height: 21px;
width:;
right:;
border-top: 2px solid transparent;
border-bottom: 2px solid transparent;
border-right: 4px solid currentColor;
}
.digital .r1 {
top: 1px;
border-top-width: 4px;
}
.digital .r2 {
top: 24px;
border-bottom-width: 4px;
}

做完这些,剩下的就是简单的对外层元素做点优化,比如稍微倾斜一点。

.digital {
position: relative;
width: 26px;
height: 46px;
margin-left: 10px;
transform: skew(-6deg);
}

哦,忘了说了,这里的边框颜色我选择使用 currentColor 的方式,这样可以在暗黑模式切换的过程中,只需要修改 body 中的文字颜色和背景色就可以了。currentColor 会选择文字颜色来使用。

样式处理完之后,接着就是添加点 JS 来显示时钟了,只要把两个数字整出来放到不同的 div 中就好了。这里我取个位数的时候,是用 m%10 的方式取余;取十位数的时候是通过 parseInt(m/10) 的方式取整。取出来之后分别放到想对应的 div 中就 ok 了。

完整代码如下:

样式:

body {
color: #393e4d;
background-color: #f5f5f5;
}
@media screen and (prefers-color-scheme: dark) {
body {
color: #59f6fb;
background-color: #1c1b1e;
}
}
.digital {
position: relative;
width: 26px;
height: 46px;
margin-left: 10px;
transform: skew(-6deg);
}
.digital span {
position: absolute;
border-radius: 50vh;
box-sizing: border-box;
}
.digital .c1,
.digital .c2,
.digital .c3 {
height:;
width: 26px;
border-left: 4px solid transparent;
border-right: 4px solid transparent;
}
.digital .c1 {
top:;
left:;
border-top: 4px solid currentColor;
}
.digital .c2 {
top: 50%;
left:;
margin-top: -2px;
}
.digital .c2:before,
.digital .c2:after {
content: "";
height:;
width: 24px;
border-left: 2px solid transparent;
border-right: 2px solid transparent;
box-sizing: border-box;
}
.digital .c2:before {
position: absolute;
top:;
left: -3px;
border-bottom: 2px solid currentColor;
}
.digital .c2:after {
position: absolute;
top: 2px;
left: -3px;
border-top: 2px solid currentColor;
}
.digital .c3 {
bottom:;
left:;
border-bottom: 4px solid currentColor;
}
.digital .l1,
.digital .l2 {
height: 21px;
width:;
left:;
border-top: 2px solid transparent;
border-bottom: 2px solid transparent;
border-left: 4px solid currentColor;
}
.digital .l1 {
top: 1px;
border-top-width: 4px;
}
.digital .l2 {
top: 24px;
border-bottom-width: 4px;
}
.digital .r1,
.digital .r2 {
height: 21px;
width:;
right:;
border-top: 2px solid transparent;
border-bottom: 2px solid transparent;
border-right: 4px solid currentColor;
}
.digital .r1 {
top: 1px;
border-top-width: 4px;
}
.digital .r2 {
top: 24px;
border-bottom-width: 4px;
} .digital_1 .c1,
.digital_1 .c2,
.digital_1 .c3,
.digital_1 .l1,
.digital_1 .l2,
.digital_2 .l1,
.digital_2 .r2,
.digital_3 .l1,
.digital_3 .l2,
.digital_4 .c1,
.digital_4 .c3,
.digital_4 .l2,
.digital_5 .l2,
.digital_5 .r1,
.digital_6 .r1,
.digital_7 .c2,
.digital_7 .c3,
.digital_7 .l1,
.digital_7 .l2,
.digital_9 .l2,
.digital_0 .c2 {
animation: changeDigital 200ms 0ms 1 ease-in forwards;
} @keyframes changeDigital {
form {
opacity:;
}
to {
opacity:;
}
} .clock {
display: flex;
justify-content: center;
padding-top: 20px;
}
.gap {
height: 46px;
padding-left: 10px;
font-size: 50px;
font-weight: bold;
line-height: 0.8;
transform: skew(-6deg);
}

结构:

<div class="clock">
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
<div class="gap">:</div>
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
<div class="gap">:</div>
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
<div class="digital digital_0">
<span class="c1"></span>
<span class="c2"></span>
<span class="c3"></span>
<span class="l1"></span>
<span class="l2"></span>
<span class="r1"></span>
<span class="r2"></span>
</div>
</div>

JS:

var s1 = document.getElementsByClassName("digital")[5],
s2 = document.getElementsByClassName("digital")[4],
m1 = document.getElementsByClassName("digital")[3],
m2 = document.getElementsByClassName("digital")[2],
h1 = document.getElementsByClassName("digital")[1],
h2 = document.getElementsByClassName("digital")[0]; setInterval(function(){
var date = new Date();
var h = date.getHours();
var m = date.getMinutes();
var s = date.getSeconds();
if (h < 10) {
h1.className = 'digital digital_' + h;
h2.className = 'digital digital_0';
} else {
h1.className = 'digital digital_' + parseInt(h%10);
h2.className = 'digital digital_' + parseInt(h/10);
}
if (m < 10) {
m1.className = 'digital digital_' + m;
m2.className = 'digital digital_0';
} else {
m1.className = 'digital digital_' + parseInt(m%10);
m2.className = 'digital digital_' + parseInt(m/10);
}
if (s < 10) {
s1.className = 'digital digital_' + s;
s2.className = 'digital digital_0';
} else {
s1.className = 'digital digital_' + parseInt(s%10);
s2.className = 'digital digital_' + parseInt(s/10);
}
}, 1000)

这样一个简易的 LED 数字时钟就大功告成啦。

一个简易的 LED 数字时钟实现方法的更多相关文章

  1. Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

    Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)                                                           ...

  2. Android自己定义View之组合控件 ---- LED数字时钟

    先上图 LEDView效果如图所看到的. 之前看到一篇博客使用两个TextView实现了该效果.于是我想用自己定义控件的方式实现一个LEDView.使用时就可以直接使用该控件. 採用组合控件的方式,将 ...

  3. 【python】实现一个python编程的小时钟!

    [本实验内容] 1.GUI.PyQT5介绍2.实现此次实验效果 [一 GUI.PyQt5介绍] 1.Python简介 2.GUI介绍 几个常用的Python GUI库: (1)wxPython (2) ...

  4. 基于FPGA的简易数字时钟

    基于FPGA的可显示数字时钟,设计思路为自底向上,包含三个子模块:时钟模块,进制转换模块.led显示模块.所用到的FPGA晶振频率为50Mhz,首先利用它得到1hz的时钟然后然后得到时钟模块.把时钟模 ...

  5. 用canvas绘制一个简易时钟

    在见识了html5中canvas的强大,笔者准备制作一个简易时钟. 下面就是成果啦,制作之前我们先分析一下,绘制一个时钟需要做哪些准备. 一 . 1.首先这个时钟分为表盘,指针(时针,分针,秒针)和数 ...

  6. JS制作一个创意数字时钟

    通过js代码制作一个创意数字时钟 通过JS代码实现创意数字时钟效果如下:由数字化的卡通形象图片取代常规的数字显示当前实时北京时间.具体效果示例: 核心重点: (1)Date方法的初步了解 (2)构建模 ...

  7. Python练习——约瑟夫环问题、用类方法描述一个数字时钟

    一.约瑟夫环问题 有15个基督徒和15个非基督徒在海上遇险,为了能让一部分人活下来不得不将其中15个人扔到海里面去,有个人想了个办法就是大家围成一个圈,由某个人开始从1报数,报到9的人就扔到海里面,他 ...

  8. Java判断一个字符是否是数字的几种方法的代码

    在工作期间,将写内容过程经常用到的一些内容段做个记录,下面内容是关于Java判断一个字符是否是数字的几种方法的内容,希望能对码农们有好处. public class Test{ public stat ...

  9. [C#]一个简易的、轻量级的方法并行执行线程辅助类

      一个简易的.轻量级的方法并行执行线程辅助类 在实际应用中,经常要让多个方法并行执行以节约运行时间,线程就是必不可少的了,而多线程的管理经常又是一件头疼的事情,比如方法并行执行异步的返回问题,方法并 ...

随机推荐

  1. SpringData Jpa、Hibernate、Jpa 三者之间的关系

    JPA规范与ORM框架之间的关系是怎样的呢? JPA规范本质上就是一种ORM规范,注意不是ORM框架--因为JPA并未提供ORM实现,它只是制订了一些规范,提供了一些编程的API接口,但具体实现则由服 ...

  2. H3C NAT Server

  3. java 声明多个泛型类型和通配符

    若一个类中多个字段需要不同的泛型声明,则在声明类的时候指定多个泛型类型即可: 格式: public interface IDAO<PK, T> { PK add(T t); void re ...

  4. 2018-3-31-C#-谁改了我的代码

    title author date CreateTime categories C# 谁改了我的代码 lindexi 2018-3-31 21:15:3 +0800 2018-2-13 17:23:3 ...

  5. P1047 汉诺塔

    题目描述 汉诺塔是根据一个印度传说形成的数学问题:有三根杆子A, B, C, A杆上有n个穿孔圆盘, 盘的尺寸由下到上依次变小. 要求按照下列规则将所有圆盘移至C杆: 每次只能移动一个圆盘 大盘不能叠 ...

  6. P1041 查找元素

    题目描述 现在告诉你一个长度为 \(n\) 的有序数组 \(a_1, a_2, ..., a_n\) ,以及 \(q\) 次询问,每次询问会给你一个数 \(x\) ,对于每次询问,你需要确定在数组中是 ...

  7. tomcat下的work目录和temp目录

    1. tomcat下的work目录 1    用tomcat作web服务器的时候,部署的程序在webApps下,这些程序都是编译后的程序(发布到tomcat的项目里含的类,会被编译成.class后才发 ...

  8. vue-learning:8-template-v-on-and-modifier

    绑定元素事件的指令 v-on 及事件和修饰符 目录 对比原生事件绑定.jQuery事件绑定 Vue事件绑定 Vue绑定事件中获取事件对象event 事件修饰符 事件行为修饰符: stop / prev ...

  9. <Standard Template Library>标准模板库专项复习总结(一)

    看了看博客园的申请时间也一年多了...想想自己一年多以来一直处于各种划水状态,现在又要面临ACM的冲击... 还是要抓紧时间赶紧复习一下了- -毕竟校园新生赛还是有奖金的.. 1.栈 先进后出(LIF ...

  10. 超简单!pytorch入门教程(三):构造一个小型CNN

    torch.nn只接受mini-batch的输入,也就是说我们输入的时候是必须是好几张图片同时输入. 例如:nn. Conv2d 允许输入4维的Tensor:n个样本 x n个色彩频道 x 高度 x ...