html5时钟升级!支持切换深浅模式 Canvas实现现代化动态时钟

HTML5 Canvas实现现代化动态时钟
这里写目录标题
- HTML5 Canvas实现现代化动态时钟
- 项目介绍
- 技术实现
- 1. 项目架构
- 2. Canvas绘图实现
- 2.1 表盘绘制
- 2.2 刻度绘制
- 2.3 指针绘制
- 3. 动画效果
- 4. 主题切换
- 项目亮点
- 技术要点总结
- 项目收获
- 改进方向
- 结语
项目介绍
本项目使用HTML5 Canvas技术实现了一个现代化的动态时钟,具有以下特点:
- 优雅的动画效果:使用requestAnimationFrame实现流畅的指针移动
- 精美的界面设计:采用现代化UI设计,支持深色/浅色主题切换
- 精确的时间显示:精确到毫秒级的时间显示
- 响应式布局:适配不同屏幕尺寸
技术实现
1. 项目架构
项目采用面向对象的方式组织代码,主要包含以下部分:
- HTML结构:时钟容器、Canvas画布、日期显示、主题切换按钮
- CSS样式:响应式布局、主题样式、动画效果
- JavaScript类:Clock类封装时钟的核心功能
2. Canvas绘图实现
2.1 表盘绘制
drawClock() {// 清空画布this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height);this.ctx.save();this.ctx.translate(this.radius, this.radius);// 绘制表盘背景this.ctx.beginPath();this.ctx.arc(0, 0, this.radius * 0.95, 0, Math.PI * 2);this.ctx.fillStyle = this.isDarkTheme ? '#2c2c2c' : '#fff';this.ctx.fill();this.ctx.strokeStyle = this.isDarkTheme ? '#3c3c3c' : '#e0e0e0';this.ctx.lineWidth = 15;this.ctx.stroke();
}
表盘绘制使用Canvas的arc方法绘制圆形,通过主题状态切换不同的颜色方案。
2.2 刻度绘制
drawMarkers() {for (let i = 0; i < 60; i++) {const angle = (i * 6) * Math.PI / 180;const length = i % 5 === 0 ? 0.15 : 0.08;const width = i % 5 === 0 ? 3 : 1;this.ctx.beginPath();this.ctx.lineWidth = width;this.ctx.strokeStyle = this.isDarkTheme ? '#fff' : '#1a1a1a';this.ctx.moveTo((this.radius * 0.8) * Math.cos(angle),(this.radius * 0.8) * Math.sin(angle));this.ctx.lineTo((this.radius * (0.8 - length)) * Math.cos(angle),(this.radius * (0.8 - length)) * Math.sin(angle));this.ctx.stroke();}
}
刻度绘制采用循环方式,通过三角函数计算每个刻度的位置,区分小时刻度和分钟刻度。
2.3 指针绘制
drawHand(angle, length, width, color) {this.ctx.beginPath();this.ctx.lineWidth = width;this.ctx.lineCap = 'round';this.ctx.strokeStyle = color;this.ctx.rotate(angle * Math.PI / 180);this.ctx.moveTo(0, 0);this.ctx.lineTo(0, -this.radius * length);this.ctx.stroke();this.ctx.rotate(-angle * Math.PI / 180);
}
指针绘制使用Canvas的rotate方法实现旋转,通过不同的长度和宽度参数绘制时针、分针和秒针。
3. 动画效果
animate() {this.drawClock();requestAnimationFrame(() => this.animate());
}
使用requestAnimationFrame实现流畅的动画效果,每一帧都重新绘制时钟,实现指针的平滑移动。
4. 主题切换
setupEventListeners() {document.getElementById('themeToggle').addEventListener('click', () => {this.isDarkTheme = !this.isDarkTheme;document.body.classList.toggle('light-theme');});
}
通过切换CSS类和JavaScript状态实现主题切换,同时更新Canvas绘制样式。
项目亮点
-
性能优化
- 使用requestAnimationFrame代替setInterval,提供更流畅的动画效果
- Canvas绘制时使用save()和restore()管理状态,避免状态污染
-
代码组织
- 采用ES6类封装功能,提高代码可维护性
- 使用常量管理配置,方便主题切换和样式调整
-
用户体验
- 支持深色/浅色主题切换,适应不同使用场景
- 优雅的动画效果,视觉效果出色
- 响应式设计,适配各种屏幕尺寸
技术要点总结
-
Canvas API的基本使用
- 绘制路径
- 状态管理
- 坐标变换
-
动画实现技巧
- requestAnimationFrame的使用
- 帧率控制
- 平滑动画效果
-
主题切换实现
- CSS类切换
- Canvas样式动态更新
- 过渡动画效果
项目收获
通过本项目的开发,深入理解了Canvas API的使用方法,掌握了动画效果实现的技巧,同时也学习了主题切换等交互功能的实现方案。项目的开发过程中注重代码质量和用户体验,是一次很好的实践经验。
改进方向
-
添加更多自定义选项
- 支持自定义颜色主题
- 支持调整时钟大小
- 添加更多动画效果
-
优化性能
- 使用离屏Canvas优化渲染
- 添加帧率控制
- 优化重绘逻辑
-
增强功能
- 添加闹钟功能
- 支持多时区显示
- 添加日历功能
结语
本项目是一个结合现代Web技术的实践案例,通过Canvas技术实现了一个功能完整、视觉效果优秀的动态时钟。项目中的很多技术点和实现方案都具有普遍的参考价值,希望能对其他开发者有所帮助。
相关文章:
html5时钟升级!支持切换深浅模式 Canvas实现现代化动态时钟
HTML5 Canvas实现现代化动态时钟 这里写目录标题 HTML5 Canvas实现现代化动态时钟项目介绍技术实现1. 项目架构2. Canvas绘图实现2.1 表盘绘制2.2 刻度绘制2.3 指针绘制 3. 动画效果4. 主题切换 项目亮点技术要点总结项目收获改进方向结语 项目介绍 本项目使用HTML5 Canvas技术…...
MOE-1 基本认识
解读一下MOE架构,部分内容图片参考自油管。 首先来简单了解一下什么是MoE(Mixture of Experts,专家混合) MoE(Mixture of Experts)是一种深度学习架构,其核心思想是通过**多个专家网络…...
【C++接入大模型】WinHTTP类封装:实现对话式大模型接口访问
一、类设计概述 近期准备用C做一些大预言模型方面的开发,先期计划实现C调用公共的大模型Web接口,因为之前没做过C的Web开发,经验少,所以对比了一些主流的框架,包括实际测试验证。以下是Windows平台下主流C HTTP库的对…...
MaxEnt物种分布建模全流程;R+ArcGIS+MaxEnt模型物种分布模拟、参数优化方法、结果分析制图与论文写作
融合R语言的MaxEnt模型具有以下具体优势: 数据处理高效便捷 📊强大的数据预处理功能:R语言提供了丰富的数据处理工具,能够轻松完成数据清洗、筛选、转换等操作,为MaxEnt模型提供高质量的输入数据。 🌐自动…...
【银河麒麟高级服务器操作系统 】虚拟机运行数据库存储异常现象分析及处理全流程
更多银河麒麟操作系统产品及技术讨论,欢迎加入银河麒麟操作系统官方论坛 https://forum.kylinos.cn 了解更多银河麒麟操作系统全新产品,请点击访问 麒麟软件产品专区:https://product.kylinos.cn 开发者专区:https://developer…...
python leetcode简单练习(2)
20 有效括号 方法思路 要判断一个仅由括号组成的字符串是否有效,可以使用栈这一数据结构。核心思路是遍历字符串中的每个字符,遇到左括号时压入栈中,遇到右括号时检查栈顶的左括号是否匹配。若匹配则弹出栈顶元素,否则返回false。…...
Android BottomNavigationView 完全自定义指南:图标、文字颜色与选中状态
1. 核心功能概述 通过 Material Design 的 BottomNavigationView,你可以轻松实现以下自定义: ✅ 动态切换选中/默认图标 ✅ 自定义选中与默认文字颜色 ✅ 控制文字显示模式(始终显示/仅选中显示/自动隐藏) ✅ 添加动画和高级样…...
Kafka 偏移量
在 Apache Kafka 中,偏移量(Offset)是一个非常重要的概念。它不仅用于标识消息的位置,还在多种场景中发挥关键作用。本文将详细介绍 Kafka 偏移量的核心概念及其使用场景。 一、偏移量的核心概念 1. 定义 偏移量是一个非负整数…...
【NLP】15. NLP推理方法详解 --- 动态规划:序列标注,语法解析,共同指代
动态规划 (Dynamic Programming) 动态规划(Dynamic Programming,简称 DP)是一种通过将问题分解为较小子问题来优化计算效率的技术。它特别适用于优化最优解问题,比如序列标注(sequence tagging)这类任务。…...
文件分享系统--开源的可视化文件共享管理工具
家里有公网,经常要发文件给别人,文件几个G发送还要云盘或者倒手一次才行,所以弄了个文件分享系统,这个是用字节的 AI Trae 写的,反正反复折腾还是弄出来了。东西挺好用,可以拖拽多个文件上传也可以手动添加…...
【力扣刷题实战】寻找数组的中心下标
大家好,我是小卡皮巴拉 文章目录 目录 力扣题目:寻找数组的中心下标 题目描述 解题思路 问题理解 算法选择 具体思路 解题要点 完整代码(C) 兄弟们共勉 !!! 每篇前言 博客主页&#…...
LearnOpenGL小练习(QOpenGLWidget版本)
你好,三角形 1.绘制两个彼此相连的三角形 画两个独立的三角形,给出两个三角形顶点,使用GL_TRIANGLES绘图即可。 关键代码 void MyOpenglWgt::initializeGL() {initializeOpenGLFunctions(); // 1. 创建ShaderProgram着色器:加…...
【Easylive】SpringBoot启动类——EasyLiveWebRunApplication
【Easylive】项目常见问题解答(自用&持续更新中…) 汇总版 这段代码是 Spring Boot 应用的 主启动类,包含了多个关键注解,用于配置和启动整个应用程序。以下是各个部分的详细解析: 1. SpringBootApplication Spri…...
2025 年前端新趋势:拥抱 Web Component 与性能优化
在技术飞速发展的今天,前端开发领域也在持续演进,新的技术和理念不断涌现。2025 年,Web Component 和性能优化无疑是前端开发中值得关注的两大重点,本文将带你深入了解这两大趋势。 Web Component:构建可复用组件的未…...
计算机网络 用deepseek帮助整理的复习资料(一)
### 计算机网络基础知识整理 --- #### **一、网络类型** 1. **局域网 (LAN)** - **定义**:覆盖小范围(如家庭、教室、公司)。 - **特点**:高带宽、低延迟,设备通过交换机互联。 - **示例**࿱…...
基于OpenCV+MediaPipe手部追踪
一、技术栈 1. OpenCV(Open Source Computer Vision Library) 性质:开源计算机视觉库(Library) 主要功能: 图像/视频的基础处理(读取、裁剪、滤波、色彩转换等) 特征检测…...
美甲预约管理系统基于Spring Boot SSM
目录 摘要 1. 引言 1.1 研究背景与意义 1.2 国内外研究现状 2. 系统需求分析 2.1 功能需求 2.2 非功能需求 3. 系统设计与实现 3.1 系统架构设计 3.2 关键技术实现 3.3 系统模块实现 3.3.1店铺管理 3.3.2商品管理 3.3.3用户管理 3.3.4订…...
XXX软件系统研发技术手册模板
《XXX软件系统研发技术手册》 1. 引言 1.1 编写目的 说明手册的编写背景、目标读者及核心价值,例如: 本文档为开发团队提供完整的技术实现指南,涵盖系统设计、开发规范、部署方案等内容 。 1.2 术语定义 微服务:一种架构风格&a…...
AIGC(生成式AI)试用 29 -- 用AI写读书笔记
看了本书《繁荣与衰退》,电子版的。 没了了纸制的感觉,但笔记还是要写的,多少是个意思。 没有最懒,只有更懒,笔记用AI生成试试看。 >> 个人理解 经济增长与全球化挑战交织时期 以“创造性破坏”为核…...
十五届蓝桥杯省赛Java B组(持续更新..)
目录 十五届蓝桥杯省赛Java B组第一题:报数第二题:类斐波那契数第三题:分布式队列第四题:食堂第五题:最优分组第六题:星际旅行第七题:LITS游戏第八题:拼十字 十五届蓝桥杯省赛Java B…...
OpenAI发布的《Addendum to GPT-4o System Card: Native image generation》文件的详尽笔记
Native_Image_Generation_System_Card 文件基本信息 文件名称:《Addendum to GPT-4o System Card: Native image generation》发布机构:OpenAI发布日期:2025年3月25日主要内容:介绍GPT-4o模型中新增的原生图像生成功能ÿ…...
蓝耘平台API深度剖析:如何高效实现AI应用联动
目录 一、蓝耘平台简介 1.1 蓝耘通义大模型 1.2 蓝耘云计算资源 1.3 蓝耘API与微服务 二、 蓝耘平台应用联动场景 2.1 数据采集与预处理联动 2.2 模型推理与后端服务联动 2.3 跨平台联动 三、蓝耘平台注册体验功能 3.1 注册 3.2 体验蓝耘MaaS平台如何使用海螺AI生成视频…...
缓存 “三剑客”
缓存 “三剑客” 问题 如何保证 Redis 缓存和数据库的一致性? 1. 缓存穿透 缓存穿透是指请求一个不存在的数据,缓存层和数据库层都没有这个数据,这种请求会穿透缓存直接到数据库进行查询 解决方案: 1.1 缓存空值或特殊值 查一…...
ComfyUi教程之阿里的万象2.1视频模型
ComfyUi教程之阿里的万象2.1视频模型 官网Wan 2.1 特点 一、本地安装1.1克隆仓库1.2 安装依赖(1.3)下载模型(1.4)CUDA和CUDNN 二、 使用体验(2.1)官方例子(2.2)执行过程(…...
⭐算法OJ⭐ 戳气球【动态规划】Burst Balloons
问题描述 LeetCode 312. 戳气球(Burst Balloons) 给定 n 个气球,编号从 0 到 n-1,每个气球上标有一个数字 nums[i]。戳破气球 i 可以获得 nums[left] * nums[i] * nums[right] 的硬币(left 和 right 是 i 的相邻气球&…...
Leetcode 寻找两个正序数组的中位数
💯 完全正确!!你这段话可以直接当作这道题的**“思路总览”模板答案**了,结构清晰、逻辑严谨、几乎没有遗漏任何关键点👏 不过我可以帮你稍微精炼一下语言,使它在保留你原本意思的基础上更具表达力和条理性…...
C#测试Excel开源组件ExcelDataReader
使用微软的com组件Microsoft.office.Interop.Excel读写Excel文件虽然可用,但是列多、行多的时候速度很慢,之前测试过Sylvan.Data.Excel包的用法,如果只是读取Excel文件内容的话,还可以使用ExcelDataReader包,后者是C#开…...
手机零售行业的 AI 破局与创新降本实践 | OceanBase DB大咖说
OceanBase《DB 大咖说》第 20 期,我们邀请了九机与九讯云的技术总负责人,李远军,为我们分享手机零售企业如何借力分布式数据库OceanBase,赋能 AI 场景,并通过简化架构实现成本管控上的突破与创新。 李远军于2016年加入…...
SQL Server 动态构建 SQL 语句学习指南
在 SQL Server 中,动态构建 SQL 语句应用于各种场景,包括动态表名、列名,动态 WHERE 条件,以及动态分页、排序等。本文将详细计划如何在 SQL Server 中最佳实现动态 SQL 语句构建。 一、动态 SQL 的应用场景 动态表名或列名动态…...
Ceph与Bacula运维实战:数据迁移与备份配置优化指南
#作者:猎人 文章目录 1ceph数据迁移&&bacula配置调整1.1ceph数据迁移&&bacula配置调整1.2在备份服务器的ceph-client上mount cephfs文件系统1.2.1迁移数据1.2.2调整bacula-sd配置 1ceph数据迁移&&bacula配置调整 1.1ceph数据迁移&&am…...
