MarsCode 助力烟花绽放

完整代码

前言

"东风夜放花千树,更吹落,星如雨"是古人对烟花的形象描述,烟花之美历来为人称颂。小到家宴喜事,大到国宴国事,"火树银花"的身影总是无处不在,璀璨的光影寄寓了人们追求美好的愿景。虽然近年来由于预防火灾隐患,烟花燃放稍有式微,但人们心中仍有烟花的一席之地。线下的烟花虽被限制,但线上的烟花亦可异彩纷呈,今天我们就借助MarsCode来生产这簇簇烟花吧!

构建思路,逻辑梳理

烟花从产生到绽放大致分三个方面的问题:从起始位置到目标位置如何表现、目标位置动画如何凸显、离子怎么炸开好看

1.从起始位置到目标位置如何表现

  • 烟花产生的起点为幕布最下方且多个点同时产生,目标点在幕布上方随机位置。
  • 依据烟花坐标集合中最后的坐标与当前坐标绘制路径,到达位置后坐标不再更新,将该烟花移出。
  • 调用requestAnimationFrame改变烟花位置。

2.目标位置动画如何凸显

  • 烟花炸开之前的中心点为目标位置,如果只用一个固定圆点表示,显得呆板。
  • 在目标指示点位置变化指示点半径。

3.离子怎么炸开好看

  • 依据离子坐标集合中最后的坐标与当前坐标绘制路径,离子逐渐衰减至消失。
  • 效果使用globalCompositeOperation,将重叠部分先擦除再变亮。

依据已有思路与MarsCode交流,逐步得到代码雏形

如图:

此时并不能得到符合预期的代码,需要逐步告知MarsCode各个步骤详细的要求,并进行适当的修改。

拼接代码块后,烟花代码雏形大致有了,运行发现屏幕还是空空如也,但是没有报错。没办法只能自己开始捉虫了,发现MarsCode给出的loop函数中没有给出构造烟花时的所有坐标,并完善了烟花的色相、饱和度,完善了控制烟花和离子的移动速度的相关参数。在修改相关的内容时MarsCode辅助了我完成对代码的注释,和对参数的引用以及生成恰到好处的语句给予我相关提示。在一定程度上MarsCode为我节约了时间,在辅助完善代码方面是一个很好的助手。于是我先后得到了这两种效果:

关于第一次使用MarsCode的心得体会

还未使用MarsCode之前以为它的定位是取代编程人员编程,详细了解后发现想岔了。其实它更多的是为编程人员提供辅助,真正起作用的是人的思维和创造力,其会在实现这样的思维和创造力时提供有力帮助。

完善这些代码期间,它在预测我下一步会做什么的同时给予补全提示,我可以视情况采纳或修改,它所提示的内容大部分都是可以采用的。其次,它的知识面也很广,让我了解到了同一问题的更多解决方案。不过,对于我较为长篇的问题,比如要求200字左右且内容繁多时,它没有按照我的逻辑来,回答的内容和要求不太符合。以上就是本次使用MarsCode的大致情况,更多内容等待下一次探索。

相关推荐
不知几秋2 分钟前
Spring Boot
java·前端·spring boot
程序猿ZhangSir6 分钟前
Vue3 项目的基本架构解读
前端·javascript·vue.js
HarderCoder10 分钟前
ByAI: Redux的typescript简化实现
前端
90后的晨仔17 分钟前
RxSwift 框架解析
前端·ios
我命由我1234523 分钟前
VSCode - VSCode 放大与缩小代码
前端·ide·windows·vscode·前端框架·编辑器·软件工具
Mintopia31 分钟前
当数字橡皮泥遇上魔法:探秘计算机图形学的细分曲面
前端·javascript·计算机图形学
Mintopia39 分钟前
Three.js 物理引擎:给你的 3D 世界装上 “牛顿之魂”
前端·javascript·three.js
Jeremy_Lee12342 分钟前
grafana 批量视图备份及恢复(含数据源)
前端·网络·grafana
import_random1 小时前
[python]conda
前端
亲亲小宝宝鸭1 小时前
写了两个小需求,终于搞清楚了表格合并
前端·vue.js