CSS动画篇之炫酷时钟之时钟墙

简介: CSS动画篇之炫酷时钟之时钟墙

本文已参与[新人创作礼]活动,一起开启掘金创作之路

通过CSS制作的时钟大家肯定看到的多了,但是像下面这样的时钟是不是很少见,整个时钟是有很多个小的时钟组合而成,每秒通过多个时钟的动画来切换时间,不得不说这个设计是非常的炫酷且有特色。

前言

看到这个动画效果你有什么思路,你会怎么实现呢?可以先想一下你的答案,看看与本文的思路是否一致。本文既然是探讨的CSS动画,那么界面上这么多的时钟是尽可能的不是真的多个时钟,那样操作DOM及JS的逻辑就太复杂了,也没有和此设计理念一样,简洁且优美。

实现过程

HTML

当你仔细看这个动图的时候可以看出我们可以把这整个时钟分为5块内容,即 2 1 : 5 8,小时和分钟的个位数和十位数,再加中间的冒号。那么我们的HTML代码可以按如下所示分为5块区域:

<div class="display">
  <div class="digit">
  </div>
  <div class="digit">
  </div>
  <div class="digit separator">
  </div>
  <div class="digit">
  </div>
  <div class="digit">
  </div>
</div>

每个区域里面都是由多个小块组成,只需要在该区域内加上固定的元素数量。比如上面的第一个区域的数量就是24(4 * 6)个。

<div class="digit">
    <div class="clock"></div>
    <div class="clock"></div>
    <div class="clock"></div>
    ...省略
    <div class="clock"></div>
    <div class="clock"></div>
    <div class="clock"></div>
  </div>

CSS

每个时钟的两个指针将有“before” 和“after”伪元素实现,CSS代码如下所示:

.clock {
  border-radius: 50%;
  width: 60px;
  height: 60px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  position: relative;
  background-color: #fff;
}
.clock:before, 
.clock:after {
  content: '';
  display: inline-block;
  height: 45%;
  width: 4px;
  background-color: #444;
  position: absolute;
  left: 50%;
  top: 8%;
  margin-left: -2px;
  transform-origin: 2px 100%;
  transition: all 10s cubic-bezier(0.5, 0, 0.5, 1);
}

最终的结果是这样的:

其实仔细看我们的时钟只绘制了简单的形状,它们只需要能够将指针定位如下在6个位置即可:

通过增加不同的类来实现,这些类改变了伪元素围绕其各自的旋转角度。

.clock.pos2:before {
  transform: rotate(180deg);
}
.clock.pos2:after {
  transform: rotate(90deg);
}

JS

现在一切都准备好了,就差怎么显示正确的数字,需要显示的数字就0-9,那么只需定义一个长度为10的数组,数组的每一项则对应上时钟的位置,以此类推,子数组的长度则是24位,对应上面提到的24个子时钟,子数组的内容基于上面提到的,只会有1-6的情况,0是默认的显示样式。整体设置数字的代码如下:

function setNumber(group, number) {
    var clocks = group.children;
    var numbers = [
        '266352355555555551451664',
        '263013500550055024131664',
        '266316352645526451631664',
        '266316352645163526451664',
        '232355555145163500550014',
        '266352645163163526451664',
        '266352645163523551451664',
        '266316350055005500550014',
        '266352355145523551451664',
        '266352355145163500550014'
    ]
    for(var i = 0; i < 24; i++) {
        clocks[i].classList.value = 'clock pos' + numbers[number][i]
    }
}

在程序初始化的时候获取当前时间,四个位置分别调用四次setNumber方法即可显示当前的时间。

function writeTime() {
  var now = new Date();
  var hour = now.getHours().toString();
  var minute = now.getMinutes().toString();
  var number = pad(hour,2) + pad(minute, 2);
  setNumber(groups[0], number[0]);
  setNumber(groups[1], number[1]);
  setNumber(groups[3], number[2]);
  setNumber(groups[4], number[3]);
}

再加上每一分钟的定时更新数据的逻辑,我们的时钟动画就运动起来啦。

function runEveryMinute(f) {
  var now = new Date();
  var timeUntilNextMinute = 60000 - (now.getSeconds() * 1000 + now.getMilliseconds());
  setTimeout(function(){
    f();
    setInterval(f, 60000);
  }, timeUntilNextMinute);
}

里面还有对于个位数补0的情况,以及中间冒号的初始化没有详细说明,有兴趣的可以看源码了解。

总结

到此整体的动画就实现完了,和你最开始的想法有什么区别呢,你是否有更好的想法可以评论区留言讨论。如果觉得有用,如果觉得有用,点赞,关注,收藏起来,说不定哪天就用上啦~

链接

the-making-of-cooper-hewitt-clock-wall

目录
相关文章
|
3月前
|
机器学习/深度学习 前端开发 JavaScript
|
9天前
jQuery+CSS3实现404背景游戏动画源码
jQuery+CSS3实现404背景游戏动画源码
42 22
|
17天前
一个好看的小时钟html+js+css源码
一个好看的小时钟html+js+css源码
87 24
|
2月前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
62 31
|
3月前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
123 58
|
1月前
|
JavaScript
jQuery和CSS3精美翻页式电子时钟特效
jQuery和CSS3精美翻页式电子时钟特效
|
1月前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
47 6
|
2月前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
79 7
|
2月前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
36 6
|
2月前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
77 5