从小数学就不及格的我,竟然用极坐标系表白了我的女神!(附代码)
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~
在数学中,极坐标系(英语:Polar coordinate system)是一个二维坐标系统。该坐标系统中任意位置可由一个夹角和一段相对原点—极点的距离来表示。在两点间的关系用夹角和距离很容易表示时,极坐标系便显得尤为有用;而在平面直角坐标系中,这样的关系就只能使用三角函数来表示。对于很多类型的曲线,极坐标方程是最简单的表达形式,甚至对于某些曲线来说,只有极坐标方程能够表示。(来自维基百科)
通过转换,极坐标的(φ, r)可以变换为直角坐标系中的(x,y)坐标,转化公式如下
这样,许多用极坐标函数表示的曲线,都可以在js里面转成直角坐标系并画出来了。下面介绍一下以下几种曲线并用canvas绘制了曲线动画:
1. 心形线
函数:
参数意义:a表示从x轴上从原点到最远点的一半。
js动画:在js中实现时,只需将极坐标角度从0到360代入方程,求出(x,y)坐标
2. 伯努利双纽线
函数:
参数意义:a表示从中心点到两端最远处的距离。
js动画:绘制时,代入角度的区间是[-45,45],需要绘制(-x,-y)和(x,y)两部分的坐标。
3. 星形线
函数:
参数意义:a表示从中心点到最远处的距离。
js动画:在js中实现时,只需将角度从0到360代入方程,求解过程中不需要转换极坐标,直接代入x,y,求出(x,y)坐标
4. 玫瑰线
函数:
参数意义:k代表有“几朵花瓣”,如果k是奇数,则得到的花瓣数就是k,如果k为偶数,则得到的花瓣数为2k。a同上表示从中心点到最远处的距离。
js动画:当k为奇数时,角度区间在[0,180]即可闭合;当k为偶数时,区间在[0,360].
5. 阿基米德螺线
函数:
参数意义:相邻“臂”之间的距离为2180a
js动画:角度一般要设置大于360,才有螺线效果,例子中角度为弧度,所以相邻“臂”之间的距离为2PIa。
除此之外,还有这样以几何级数增大的螺线和从外往内描绘的螺线:
6. 对数螺线
函数:
js动画:
7. 双曲螺线
函数:
js动画:
以上七种曲线的demo:展示地址
总结
在简单的图形和动画轨迹上,我们可以换一种实现思维,例如通过函数来实现。最后,使用k=6的玫瑰线定义了(x,y)坐标,并设置z坐标为 (x,y)到z轴距离的3次方根,通过threejs,设置图片的顶点数,用曲线连接画了一个小demo。
问答
游戏体系结构
相关阅读
玩转flex布局
动感光波发射!Unity AR开发之 3d 物体识别小记
Three.js 粒子系统学习小记:礼花效果实现
【每日课程推荐】机器学习实战!快速入门在线广告业务及CTR相应知识
此文已由作者授权腾讯云+社区发布,更多原文请点击
搜索关注公众号「云加社区」,第一时间获取技术干货,关注后回复1024 送你一份技术课程大礼包!
海量技术实践经验,尽在云加社区!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2017-09-20 鸟瞰前端 , 再论性能优化