MarsCode 助力烟花绽放

完整代码

前言

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

构建思路,逻辑梳理

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

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

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

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

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

3.离子怎么炸开好看

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

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

如图:

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

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

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

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

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

相关推荐
下雪了 ~6 分钟前
HTTP和HTTPS的区别有哪些?
服务器·前端·笔记·网络协议·计算机网络
Krorainas42 分钟前
将PDF流使用 canvas 绘制然后转为图片展示在页面上(二)
前端·javascript·pdf·react
吉吉安1 小时前
使用echarts实现3d柱状图+折线图
前端·javascript·echarts
yanlele1 小时前
企业级 AI Coding 已经来临, 目前其发展可能已经超越想象,对此我的一些思考
前端·后端·openai
m0_748244831 小时前
WebSpoon9.0(KETTLE的WEB版本)编译 + tomcatdocker部署 + 远程调试教程
前端
大饼酥1 小时前
使用Nexus3搭建npm私有仓库
前端·npm·node.js
苦逼的猿宝1 小时前
React+Antd修改Table组件滚动条样式
前端·javascript·react.js
yqcoder2 小时前
event 用 ts 类型声明
前端·javascript·react.js
芝芝葡萄2 小时前
react-dnd 拖拽事件与输入框的文本选中冲突
前端·react.js·前端框架
搜狐技术产品小编20232 小时前
Flutter Navigator2.0的原理和Web端实践
前端·flutter