0

0

JavaScript Canvas实现等分旋转圆盘及频闪效应可视化教程

碧海醫心

碧海醫心

发布时间:2025-11-17 13:00:21

|

467人浏览过

|

来源于php中文网

原创

JavaScript Canvas实现等分旋转圆盘及频闪效应可视化教程

本教程详细介绍了如何使用javascripthtml canvas api实现一个可等分并旋转的圆盘,以模拟频闪效应。文章将指导读者修改现有代码,实现将圆盘划分为三等份或更多份,并通过从圆心绘制线段而非直径的方式,确保各等分线正确显示。重点在于render函数的优化,使其能够灵活处理多等分情况。

1. 理解原始代码与需求分析

原始代码旨在通过HTML Canvas展示频闪效应,其中包含一个旋转的“基础”圆盘和一个“采样”圆盘。最初的绘制逻辑是将圆盘一分为二,通过从圆周上一点绘制一条线到其对面的点来形成一条直径。然而,实际需求是将圆盘划分为三等份或更多等份,并可能对其中部分分割线进行特殊着色。

核心挑战在于:

  • 多等分绘制: 如何将一个圆盘均匀地分成N份。
  • 绘制方式: 当等分数量大于2时,不能再简单地绘制直径,而需要从圆心向圆周绘制每条分割线。
  • 颜色定制: 如何为特定的分割线应用不同的颜色(此部分将在进阶章节讨论)。

2. 实现圆盘多等分绘制的核心原理

要将一个圆盘均匀地分成N份,我们需要计算出每条分割线在圆周上的终点坐标。一个完整的圆是360度(或2π弧度)。因此,每份之间的角度间隔为 360 / N 度。

绘制每条分割线的步骤如下:

立即学习Java免费学习笔记(深入)”;

  1. 确定圆心坐标 (cx, cy)。
  2. 确定圆的半径 r。
  3. 对于每一份,计算其在圆周上的终点角度 angle_i = current_rotation_angle + i * (360 / N)。这里的 current_rotation_angle 是圆盘当前的旋转角度,i 是当前分割线的索引(从0到N-1)。
  4. 使用三角函数计算该终点在Canvas上的坐标:
    • x = cx + r * cos(angle_i_in_radians)
    • y = cy - r * sin(angle_i_in_radians) (注意Canvas的Y轴方向向下为正,与数学坐标系相反,因此Y坐标需要用减法)
  5. 从圆心 (cx, cy) 绘制一条线到 (x, y)。

关键在于,每次绘制一条分割线时,都需要先将绘图笔移动回圆心 context.moveTo(cx, cy),然后再绘制到新的圆周点。这样可以确保所有分割线都从圆心发出。

QIMI奇觅
QIMI奇觅

美图推出的游戏行业广告AI制作与投放一体化平台

下载

3. 修改render函数实现多等分

以下是针对原始JavaScript代码中render函数进行的修改,以实现将圆盘划分为三等份。此修改主要集中在绘制左侧和右侧圆盘分割线的部分。

function render() {
    context.fillStyle = "#000000";
    context.fillRect(0, 0, canvas_width, canvas_height);

    context.strokeStyle = "#ffffff";
    context.beginPath();
    context.moveTo(canvas_width / 2, 0);
    context.lineTo(canvas_width / 2, canvas_height);
    context.stroke();

    context.strokeStyle = "#ff51ff";
    context.beginPath();

    /* 左侧圆盘绘制修改开始 */
    const x1 = canvas_width / 4, y1 = canvas_height / 2 + y_offset; // 左侧圆盘中心
    const numberOfDivisions = 3; // 设置等分数,可根据需求调整为更多
    const angleIncrement = 360 / numberOfDivisions; // 计算每份的角度增量

    for (let i = 0; i < numberOfDivisions; i++) {
        const currentSegmentAngle = wheel_angle + i * angleIncrement;
        context.moveTo(x1, y1); // 移动到圆心
        context.lineTo(x1 + wheel_radius * Math.cos(toRadian(currentSegmentAngle)), 
                       y1 - wheel_radius * Math.sin(toRadian(currentSegmentAngle))); // 绘制从圆心到圆周的线
    }
    context.stroke(); // 统一绘制所有线段

    context.beginPath();
    context.arc(canvas_width / 4, canvas_height / 2 + y_offset, wheel_radius, 0, 2 * Math.PI);
    context.stroke();
    /* 左侧圆盘绘制修改结束 */

    /* 右侧圆盘绘制修改开始 */
    context.strokeStyle = "#00ff00";
    context.beginPath();
    const x2 = 3 * canvas_width / 4, y2 = y1; // 右侧圆盘中心

    for (let i = 0; i < numberOfDivisions; i++) {
        const currentSegmentAngle = camera_angle + i * angleIncrement;
        context.moveTo(x2, y2); // 移动到圆心
        context.lineTo(x2 + wheel_radius * Math.cos(toRadian(currentSegmentAngle)), 
                       y2 - wheel_radius * Math.sin(toRadian(currentSegmentAngle))); // 绘制从圆心到圆周的线
    }
    context.stroke(); // 统一绘制所有线段
    /* 右侧圆盘绘制修改结束 */

    context.beginPath();
    context.arc(3 * canvas_width / 4, canvas_height / 2 + y_offset, wheel_radius, 0, 2 * Math.PI);
    context.stroke();

    // ... (其余代码保持不变,例如文本绘制部分) ...
    if (mobile) {
        context.font = "15px Arial";
    }
    else {
        context.font = "30px Arial";
    }
    context.textAlign = "center";
    context.fillStyle = "#ffffff";
    context.fillText("Base", canvas_width / 4, 30);
    context.fillText("Teste Aliasing", 3 * canvas_width / 4, 30);
}

// 确保toRadian函数可用,它负责将度数转换为弧度
function toRadian(degree) {
    return (Math.PI * degree / 180);
}

代码解析:

  1. numberOfDivisions: 引入一个常量来定义圆盘的等分数。您可以根据需求将其更改为任何大于或等于3的整数。
  2. angleIncrement: 根据 numberOfDivisions 计算出每条分割线之间的角度增量。
  3. for 循环: 遍历 numberOfDivisions 次,每次循环绘制一条分割线。
  4. currentSegmentAngle: 计算当前分割线在圆周上的角度,它是当前圆盘旋转角度 wheel_angle(或 camera_angle)加上 i 倍的角度增量。
  5. context.moveTo(x, y): 在绘制每条线段之前,将绘图笔移动到圆心 (x1, y1) 或 (x2, y2)。这是实现从圆心向外辐射状绘制的关键。
  6. context.lineTo(...): 从圆心绘制一条线到计算出的圆周上的点。
  7. context.stroke(): 在循环结束后统一调用 context.stroke(),一次性描边所有路径。如果所有分割线颜色相同,这种方式效率更高。

4. 实现部分分割线不同颜色(进阶)

如果需要让某条或某几条分割线呈现不同的颜色,可以在绘制循环内部根据条件判断来改变 context.strokeStyle。

例如,让左侧圆盘的第一条分割线显示为蓝色,其余为默认颜色:

    // ... 左侧圆盘绘制部分
    // context.strokeStyle = "#ff51ff"; // 默认颜色可以放在循环外或每次重设
    context.beginPath();

    const x1 = canvas_width / 4, y1 = canvas_height / 2 + y_offset;
    const numberOfDivisions = 3;
    const angleIncrement = 360 / numberOfDivisions;

    for (let i = 0; i < numberOfDivisions; i++) {
        const currentSegmentAngle = wheel_angle + i * angleIncrement;

        // 根据条件设置不同的颜色
        if (i === 0) { // 如果是第一条分割线
            context.strokeStyle = "#0000ff"; // 设置为蓝色
        } else {
            context.strokeStyle = "#ff51ff"; // 恢复为默认的粉色
        }

        context.moveTo(x1, y1);
        context.lineTo(x1 + wheel_radius * Math.cos(toRadian(currentSegmentAngle)), 
                       y1 - wheel_radius * Math.sin(toRadian(currentSegmentAngle)));
        context.stroke(); // 每绘制一条线就调用一次stroke,因为颜色可能变化
    }
    // 注意:如果颜色在循环内变化,context.stroke() 必须在循环内调用
    // 如果所有线段都使用相同的颜色,则可以在循环外部统一调用一次 stroke()
    // ...

重要提示: 当 strokeStyle 在循环内部变化时,为了使每条线段应用其对应的颜色,context.stroke() 必须移动到循环内部,每次绘制一条线就立即描边。如果将 context.stroke() 放在循环外部,所有 lineTo 操作将形成一个单一路径,并最终应用循环结束时 `

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1501

2023.10.24

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

512

2023.10.23

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

13

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

5

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

7

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

540

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

190

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

323

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

11

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号