H5游戏-Canvas绘制与JS基础

一、Promise 与 async await

Promise和async await是一个东西,async await是Promise的语法糖。

async await类似UnityC#的async await。

async修饰的function中,需要返回一个new Promise((resoleve)=>{})。

async await用同步的写法写异步,避免回调地域,是推荐写法,不用.then。

二、ctx.save与ctx.restore

一个典型使用:

复制代码
ctx.save();
ctx.xxxx();例如ctx.translate(x,y); 改变了ctx的状态
ctx.restore();

ctx很明显是content上下文缩写,ctx保存了canvans绘制的状态。

关键问题在于为什么要ctx.save,并且在更改了某些状态后要restore。

ctx.save():把当前「画布设置」拍一张快照存起来。

ctx.restore():把画布恢复到最近一次 save 时的快照。

比如:

复制代码
ctx.fillStyle = 'red';
drawCircle(100, 100);   // 红圆

ctx.fillStyle = 'blue';
drawCircle(200, 200);   // 蓝圆

drawCircle(300, 300);   // 还是蓝圆!因为没改回去

如果 drawCircle 内部想「暂时用红色画完再恢复」,不用 save/restore 就得自己记下原来的 fillStyle 再设回去,很麻烦。

用 save/restore 就可以:

复制代码
ctx.save();              // 存档:当前是默认状态
ctx.fillStyle = 'red';
ctx.translate(50, 50);
drawSomething();         // 在「临时状态」下画
ctx.restore();           // 读档:fillStyle、坐标等都恢复
// 这里又回到存档时的状态,不影响后面的绘制

所以:save/restore 的作用 = 把一段代码里的「设置改动」限制在这段代码内部,不污染外面。

通常会被save/restore的东西

复制代码
样式:fillStyle、strokeStyle、lineWidth、globalAlpha、font 等
变换:translate()、rotate()、scale() 等
裁剪区域:clip()
其他绘图状态(合成方式等)

三、如何驱动Canvas的帧循环

利用requestAnimationFrame(方法名如Update或者GameLoop)。

requestAnimationFrame 是浏览器/JS 运行环境自带的"系统函数"。

参数方法比如GameLoop会在绘制下一帧的时候调用,然后在GameLoop中再调用requestAnimationFrame,形成帧循环。

四、一个典型的一帧的过程

  1. 计算这一帧的时间
  2. 一个方法计算数值
  3. 一个方法负责利用计算后的数值进行绘制
  4. 调用requestAnimationFrame(自己)形成帧循环。

五、简单的分离UI和游戏Canvas,让UI粗暴的展示在Canvas前。

复制代码
    <canvas id="gameCanvas"></canvas>
     <!-- 没有z-index,会盖在canvas上面。 -->
    <div id="uiOverlay" class="ui-overlay"></div>
相关推荐
Moment6 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
爱敲代码的小鱼6 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
子春一8 小时前
Flutter for OpenHarmony:构建一个 Flutter 四色猜谜游戏,深入解析密码逻辑、反馈算法与经典益智游戏重构
算法·flutter·游戏
铅笔侠_小龙虾8 小时前
Flutter 实战: 计算器
开发语言·javascript·flutter
前端不太难8 小时前
HarmonyOS 游戏上线前必做的 7 类极端场景测试
游戏·状态模式·harmonyos
大模型玩家七七9 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_944711439 小时前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜9 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
微祎_10 小时前
Flutter for OpenHarmony:构建一个 Flutter 重力弹球游戏,2D 物理引擎、手势交互与关卡设计的工程实现
flutter·游戏·交互
阔皮大师10 小时前
INote轻量文本编辑器
java·javascript·python·c#