JavaScript Canvas实现可等分旋转圆盘及频闪效应模拟

javascript canvas实现可等分旋转圆盘及频闪效应模拟

本教程详细指导如何在HTML5 Canvas上绘制一个可等分、旋转的圆盘,并模拟频闪效应。文章通过优化现有JavaScript代码,展示了如何将圆盘精确划分为多个等份,并为其中特定部分着色。此外,教程还探讨了频闪效应中采样频率与旋转频率之间的关系,特别是可能导致180度相位变化的特殊情况,并提供了完整的实现代码。

引言

在可视化和动画领域,使用HTML5 Canvas绘制动态图形是常见的需求。本教程将深入探讨如何利用Canvas 2D上下文,实现一个可自定义等分数量并持续旋转的圆盘。在此基础上,我们将结合频闪效应(Stroboscopic Effect)的原理,通过模拟采样视角来展示物体在不同采样频率下的视觉表现。我们将从一个现有的频闪效果代码出发,对其进行功能扩展和优化,以满足将圆盘划分为三份或更多等份,并对其中特定“分隔线”进行着色的需求。

Canvas绘图基础与频闪效应原理

HTML5 Canvas提供了一个强大的2D绘图API,允许开发者通过JavaScript在网页上绘制图形。核心概念包括:

canvas元素: HTML中的画布容器。context对象: 通过canvas.getContext(‘2d’)获取,提供了一系列绘图方法。路径绘制: 使用beginPath()开始新路径,moveTo(x, y)移动到指定点,lineTo(x, y)从当前点画线到指定点,arc(x, y, radius, startAngle, endAngle)绘制圆弧,stroke()描边路径,fill()填充路径。样式设置: strokeStyle设置描边颜色,fillStyle设置填充颜色,lineWidth设置线宽等。

频闪效应是一种光学现象,当观察者以周期性闪光(或采样)观察一个周期性运动的物体时,物体的运动状态会发生视觉上的改变。在代码模拟中,这通常通过两个角度来体现:

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

wheel_angle: 代表圆盘的实际旋转角度,它会随时间连续更新。camera_angle: 代表“相机”或“观察者”的采样角度,它以较低的、离散的频率从wheel_angle中获取值。

当wheel_angle的更新频率(即圆盘的实际转速)与camera_angle的采样频率(由frames_skip和fps决定)之间存在特定关系时,我们便能观察到圆盘静止、慢速旋转或反向旋转的频闪效果。

实现圆盘等分与旋转

原始代码通过绘制一条贯穿圆心的直径线来将圆盘一分为二。为了实现将圆盘划分为N个等份,我们需要调整绘图逻辑,使其能够绘制从圆心到圆周上等分点的多条径向线。

多等分圆盘的数学逻辑

要将一个圆盘等分为N份,每份之间的角度间隔为 360 / N 度。绘制这些等分线时,每一条线都应从圆心出发,延伸到圆周上对应的角度位置。

例如,对于三等分圆盘(N=3),角度间隔为 360 / 3 = 120 度。如果第一条径向线位于wheel_angle,那么接下来的两条线将分别位于wheel_angle + 120度和wheel_angle + 240度。

修改render函数

核心修改集中在render()函数中,该函数负责绘制Canvas上的所有图形。我们将重构绘制径向线的逻辑,以支持任意数量的等分。

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();    // 定义等分数    const divisions = 3; // 可以根据需求修改为更多等分,例如4, 5, 6等    const angleStep = 360 / divisions; // 计算每份的角度步长    // 绘制左侧圆盘 (实际旋转)    const x1 = canvas_width / 4, y1 = canvas_height / 2 + y_offset; // 左侧圆心    // 绘制圆盘的径向分隔线    for (let i = 0; i < divisions; i++) {        const currentAngle = wheel_angle + i * angleStep;        context.strokeStyle = "#ff51ff"; // 默认分隔线颜色        // 如果需要为特定分隔线着色,可以在这里添加条件判断        // if (i === 0) { // 例如,让第一条径向线变为红色        //     context.strokeStyle = "#ff0000";        // }        context.beginPath(); // 每绘制一条线重新开始路径,确保独立样式        context.moveTo(x1, y1); // 移到圆心        context.lineTo(x1 + wheel_radius * Math.cos(toRadian(currentAngle)), y1 - wheel_radius * Math.sin(toRadian(currentAngle)));        context.stroke(); // 描边当前路径    }    // 绘制左侧圆盘的外圆    context.beginPath();    context.arc(canvas_width / 4, canvas_height / 2 + y_offset, wheel_radius, 0, 2 * Math.PI);    context.strokeStyle = "#ff51ff"; // 确保外圆颜色正确    context.stroke();    // 绘制右侧圆盘 (采样视角)    const x2 = 3 * canvas_width / 4, y2 = y1; // 右侧圆心    for (let i = 0; i < divisions; i++) {        const currentAngle = camera_angle + i * angleStep;        context.strokeStyle = "#00ff00"; // 默认分隔线颜色        context.beginPath();        context.moveTo(x2, y2); // 移到圆心        context.lineTo(x2 + wheel_radius * Math.cos(toRadian(currentAngle)), y2 - wheel_radius * Math.sin(toRadian(currentAngle)));        context.stroke();    }    // 绘制右侧圆盘的外圆    context.beginPath();    context.arc(3 * canvas_width / 4, canvas_height / 2 + y_offset, wheel_radius, 0, 2 * Math.PI);    context.strokeStyle = "#00ff00"; // 确保外圆颜色正确    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);}

关键修改点解释:

divisions常量: 定义了圆盘的等分数,便于修改和扩展。angleStep: 根据divisions计算出每份的度数。循环绘制: 使用for循环迭代divisions次,每次计算一个径向线的角度(currentAngle)。context.beginPath()和context.stroke(): 为了使每条径向线能够独立设置样式(例如颜色),每次绘制一条线时,都应该调用beginPath()开始新路径,绘制完后立即调用stroke()描边,然后再次beginPath()为下一条线做准备。恢复strokeStyle: 在绘制完径向线后,确保将strokeStyle恢复到绘制外圆的颜色,以避免外圆被意外着色。

为特定部分着色

根据需求,我们可能希望“半个分隔线”或“某个分隔线”呈现不同的颜色。由于分隔线是径向线,将其“半个”着色不同颜色会使代码复杂化且视觉效果不明显。更常见的做法是使某一条完整的径向线某个扇形区域呈现不同颜色。在此,我们演示如何使其中一条径向线颜色不同。

在上述render函数的径向线绘制循环中,我们可以通过条件判断来改变特定线条的颜色:

// ... (在render函数中,左侧圆盘的径向线绘制循环内)for (let i = 0; i < divisions; i++) {    const currentAngle = wheel_angle + i * angleStep;    // 为第一条径向线设置不同的颜色    if (i === 0) {         context.strokeStyle = "#ff0000"; // 红色    } else {        context.strokeStyle = "#ff51ff"; // 其他线保持原色    }    context.beginPath();     context.moveTo(x1, y1);     context.lineTo(x1 + wheel_radius * Math.cos(toRadian(currentAngle)), y1

以上就是JavaScript Canvas实现可等分旋转圆盘及频闪效应模拟的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1596157.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 10:56:00
下一篇 2025年12月23日 10:56:12

相关推荐

  • 旋转长方形后,如何计算其相对于画布左上角的轴距?

    绘制长方形并旋转,计算旋转后轴距 在拥有 1920×1080 画布中,放置一个宽高为 200×20 的长方形,其坐标位于 (100, 100)。当以任意角度旋转长方形时,如何计算它相对于画布左上角的 x、y 轴距? 以下代码提供了一个计算旋转后长方形轴距的解决方案: const x = 200;co…

    2025年12月24日
    000
  • 旋转长方形后,如何计算它与画布左上角的xy轴距?

    旋转后长方形在画布上的xy轴距计算 在画布中添加一个长方形,并将其旋转任意角度,如何计算旋转后的长方形与画布左上角之间的xy轴距? 问题分解: 要计算旋转后长方形的xy轴距,需要考虑旋转对长方形宽高和位置的影响。首先,旋转会改变长方形的长和宽,其次,旋转会改变长方形的中心点位置。 求解方法: 计算旋…

    2025年12月24日
    000
  • 旋转长方形后如何计算其在画布上的轴距?

    旋转长方形后计算轴距 假设长方形的宽、高分别为 200 和 20,初始坐标为 (100, 100),我们将它旋转一个任意角度。根据旋转矩阵公式,旋转后的新坐标 (x’, y’) 可以通过以下公式计算: x’ = x * cos(θ) – y * sin(θ)y’ = x * …

    2025年12月24日
    000
  • 如何计算旋转后长方形在画布上的轴距?

    旋转后长方形与画布轴距计算 在给定的画布中,有一个长方形,在随机旋转一定角度后,如何计算其在画布上的轴距,即距离左上角的距离? 以下提供一种计算长方形相对于画布左上角的新轴距的方法: const x = 200; // 初始 x 坐标const y = 90; // 初始 y 坐标const w =…

    2025年12月24日
    200
  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 如何计算旋转后的长方形在画布上的 XY 轴距?

    旋转长方形后计算其画布xy轴距 在创建的画布上添加了一个长方形,并提供其宽、高和初始坐标。为了视觉化旋转效果,还提供了一些旋转特定角度后的图片。 问题是如何计算任意角度旋转后,这个长方形的xy轴距。这涉及到使用三角学来计算旋转后的坐标。 以下是一个 javascript 代码示例,用于计算旋转后长方…

    2025年12月24日
    000
  • 如何在 VS Code 中解决折叠代码复制问题?

    解决 VS Code 折叠代码复制问题 在 VS Code 中使用折叠功能可以帮助组织长代码,但使用复制功能时,可能会遇到只复制可见部分的问题。以下是如何解决此问题: 当代码被折叠时,可以使用以下简单操作复制整个折叠代码: 按下 Ctrl + C (Windows/Linux) 或 Cmd + C …

    2025年12月24日
    000
  • 如何相对定位使用 z-index 在小程序中将文字压在图片上?

    如何在小程序中不使用绝对定位压住上面的图片? 在小程序开发中,有时候需要将文字内容压在图片上,但是又不想使用绝对定位来实现。这种情况可以使用相对定位和 z-index 属性来解决。 问题示例: 小程序中的代码如下: 顶顶顶顶 .index{ width: 100%; height: 100vh;}.…

    2025年12月24日
    000
  • 学会从头开始学习CSS,掌握制作基本网页框架的技巧

    从零开始学习CSS,掌握网页基本框架制作技巧 前言: 在现今互联网时代,网页设计和开发是一个非常重要的技能。而学习CSS(层叠样式表)是掌握网页设计的关键之一。CSS不仅可以为网页添加样式和布局,还可以为用户呈现独特且具有吸引力的页面效果。在本文中,我将为您介绍一些基本的CSS知识,以及一些常用的代…

    2025年12月24日
    200
  • 揭秘Web标准涵盖的语言:了解网页开发必备的语言范围

    在当今数字时代,互联网成为了人们生活中不可或缺的一部分。作为互联网的基本构成单位,网页承载着我们获取和分享信息的重要任务。而网页开发作为一门独特的技术,离不开一些必备的语言。本文将揭秘Web标准涵盖的语言,让我们一起了解网页开发所需的语言范围。 首先,HTML(HyperText Markup La…

    2025年12月24日
    000
  • 揭开Web开发的语言之谜:了解构建网页所需的语言有哪些?

    Web标准中的语言大揭秘:掌握网页开发所需的语言有哪些? 随着互联网的快速发展,网页开发已经成为人们重要的职业之一。而要成为一名优秀的网页开发者,掌握网页开发所需的语言是必不可少的。本文将为大家揭示Web标准中的语言大揭秘,介绍网页开发所需的主要语言。 HTML(超文本标记语言)HTML是网页开发的…

    2025年12月24日
    400
  • 常用的网页开发语言:了解Web标准的要点

    了解Web标准的语言要点:常见的哪些语言应用在网页开发中? 随着互联网的不断发展,网页已经成为人们获取信息和交流的重要途径。而要实现一个高质量、易用的网页,离不开一种被广泛接受的Web标准。Web标准的制定和应用,涉及到多种语言和技术,本文将介绍常见的几种语言在网页开发中的应用。 首先,HTML(H…

    2025年12月24日
    000
  • 网页开发中常见的Web标准语言有哪些?

    探索Web标准语言的世界:网页开发中常用的语言有哪些? 在现代社会中,互联网的普及程度越来越高,网页已成为人们获取资讯、娱乐、交流的重要途径。而网页的开发离不开各种编程语言的应用和支持。在这个虚拟世界的网络,有许多被广泛应用的标准化语言,用于为用户提供优质的网页体验。本文将探索网页开发中常用的语言,…

    2025年12月24日
    000
  • 深入探究Web标准语言的范围,涵盖了哪些语言?

    Web标准是指互联网上的各个网页所需遵循的一系列规范,确保网页在不同的浏览器和设备上能够正确地显示和运行。这些标准包括HTML、CSS和JavaScript等语言。本文将深入解析Web标准涵盖的语言范围。 首先,HTML(HyperText Markup Language)是构建网页的基础语言。它使…

    2025年12月24日
    000
  • 项目实践:如何结合CSS和JavaScript打造优秀网页的经验总结

    项目实践:如何结合CSS和JavaScript打造优秀网页的经验总结 随着互联网的快速发展,网页设计已经成为了各行各业都离不开的一项技能。优秀的网页设计可以给用户留下深刻的印象,提升用户体验,增加用户的黏性和转化率。而要做出优秀的网页设计,除了对美学的理解和创意的运用外,还需要掌握一些基本的技能,如…

    2025年12月24日
    200
  • CSS 超链接属性解析:text-decoration 和 color

    CSS 超链接属性解析:text-decoration 和 color 超链接是网页中常用的元素之一,它能够在不同页面之间建立连接。为了使超链接在页面中有明显的标识和吸引力,CSS 提供了一些属性来调整超链接的样式。本文将重点介绍 text-decoration 和 color 这两个与超链接相关的…

    2025年12月24日
    000
  • 学完HTML和CSS之后我应该做什么?

    网页开发是一段漫长的旅程,但是掌握了HTML和CSS技能意味着你已经赢得了一半的战斗。这两种语言对于学习网页开发技能来说非常重要和基础。现在不可或缺的是下一个问题,学完HTML和CSS之后我该做什么呢? 对这些问题的答案可以分为2-3个部分,你可以继续练习你的HTML和CSS编码,然后了解在学习完H…

    2025年12月24日
    000
  • 聊聊怎么利用CSS实现波浪进度条效果

    本篇文章给大家分享css 高阶技巧,介绍一下如何使用css实现波浪进度条效果,希望对大家有所帮助! 本文是 CSS Houdini 之 CSS Painting API 系列第三篇。 现代 CSS 之高阶图片渐隐消失术现代 CSS 高阶技巧,像 Canvas 一样自由绘图构建样式! 在上两篇中,我们…

    2025年12月24日 好文分享
    200
  • 巧用距离、角度及光影制作炫酷的 3D 文字特效

    如何利用 css 实现3d立体的数字?下面本篇文章就带大家巧用视觉障眼法,构建不一样的 3d 文字特效,希望对大家有所帮助! 最近群里有这样一个有意思的问题,大家在讨论,使用 CSS 3D 能否实现如下所示的效果: 这里的核心难点在于,如何利用 CSS 实现一个立体的数字?CSS 能做到吗? 不是特…

    2025年12月24日 好文分享
    000
  • CSS高阶技巧:实现图片渐隐消的多种方法

    将专注于实现复杂布局,兼容设备差异,制作酷炫动画,制作复杂交互,提升可访问性及构建奇思妙想效果等方面的内容。 在兼顾基础概述的同时,注重对技巧的挖掘,结合实际进行运用,欢迎大家关注。 正文从这里开始。 在过往,我们想要实现一个图片的渐隐消失。最常见的莫过于整体透明度的变化,像是这样: 立即学习“前端…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信