贪吃蛇身匀速运动模型

通用运动模型

我们已知斜线为移动的距离 d d d, x x x轴总偏移量为 d x dx dx, y y y轴总偏移量为 d y dy dy,在一帧当中,我们也知道能走的距离为 m d md md。那么作为一般的运动模型,该如何确定我们进行移动的方向呢?需要向夹角 θ θ θ的方向移动,这样我们移动的所有点都在直角三角形的斜边上,这是一个正确的移动模式。

从上图我们可以看到,需要求的就是 m d x mdx mdx和 m d y mdy mdy了。也就是 m d md md在 x x x轴和 y y y轴上的投影。我们可以简单思考确定物体移动方向 的问题,夹角 θ θ θ决定了物体移动的方向。其中, s i n θ = d y / d sinθ=dy/d sinθ=dy/d, c o s θ = d x / d cosθ=dx/d cosθ=dx/d,若要沿相同角度出发,即两次的 θ θ θ相同,那么也应该有对应的 s i n θ 2 sinθ_2 sinθ2和 c o s θ 2 cosθ_2 cosθ2。

整个过程就是从结果反推过程:

  1. 一个点是如何移动到目标位置的呢?向 t h e t a theta theta方向移动 m d md md。
  2. 如何达到 m d md md呢?先朝 x x x轴走一点,再朝 y y y轴走一点。
  3. 朝 x 、 y x、y x、y走多少呢?具体计算...
简易版运动模型

当然,这是一个通用的运动模型,即在物体运动的动作空间为连续(360度随便走)时和离散时(如本项目:上右下左)都适用。我们可以想到,当我们的贪吃蛇向右走时,其实只有 y y y轴(标准坐标系,非canvas)有移动,因此我们要移动的总距离 d d d和每一帧移动距离 m d md md都只会分配到 y y y轴上 ,该公式理论上恒成立 d y / d = 1 dy/d=1 dy/d=1(具体计算中可能有浮点数精度问题)。

有了这个想法,我们就可以实现一个仅适用本项目的离散版本的。

js 复制代码
  update_move() {
    const distance = Math.sqrt(dx * dx + dy * dy);
    if (distance < this.eps) {
      this.cells[0] = this.next_cell;
      this.next_cell = null;
      this.status = "idle";
      this.direction = -1;

      if (!this.check_tail_increasing()) {
        this.cells.pop();
      }
    } else {
      const move_distance = this.speed * this.timedelta / 1000; 
      // 设置snake0
      if (this.id === 0) {
        if (this.direction === 0) this.cells[0].y -= move_distance;
        else if (this.direction === 1) this.cells[0].x += move_distance;
        else if (this.direction === 2) this.cells[0].y += move_distance;
        else if (this.direction === 3) this.cells[0].x -= move_distance;
      }
      // 设置snake1
      if (this.id === 1) {
        if (this.direction === 0) this.cells[0].y -= move_distance;
        else if (this.direction === 1) this.cells[0].x += move_distance;
        else if (this.direction === 2) this.cells[0].y += move_distance
        else if (this.direction === 3) this.cells[0].x -= move_distance;
      }
    }
  }

这段代码就是如果当前为移动状态,每一帧刷新时直接根据获取的direction添加固定方向的偏移量。注意上面是渲染cell,因此 ( x , y ) (x,y) (x,y)会变成 ( y , x ) (y,x) (y,x)因此当动作为 0 0 0(向上)时,我们要给 y y y减去偏移量而不是 x x x。

相关推荐
HY小海14 天前
【Unity游戏创作】常见的设计模式
unity·设计模式·c#·游戏程序
yRXTIugk19 天前
示例:创建一个5x5的栅格地图
游戏程序
不绝19121 天前
导入3D模型时相关参数设置/Model标签页/Rig标签页/Avatar相关参数/Animation标签页/Materia标签页
unity·游戏程序
m0_6410310524 天前
iOS签名是什么?为什么苹果APP需要签名
经验分享·科技·ios·游戏程序
玉梅小洋24 天前
Unity 2D游戏开发 Ruby‘s Adventure 2:主角和第一脚本
游戏·unity·游戏引擎·游戏程序·ruby·游戏开发
玉梅小洋1 个月前
Unity 2D游戏开发 Ruby‘s Adventure 1:课程介绍和资源导入
游戏·unity·游戏引擎·游戏程序·ruby
软件资深者1 个月前
植物大战僵尸1经典版(小游戏)+超强辅助工具 自动收取阳光
windows·游戏程序·windows11
孟无岐1 个月前
【Laya】Socket 使用指南
websocket·typescript·游戏引擎·游戏程序·laya
Watermelo6171 个月前
随机扣款实现赛博共产主义,《明日方舟:终末地》公测支付事故复盘
数据库·后端·游戏程序·技术美术·用户体验·游戏策划·游戏美术
晚霞的不甘1 个月前
Flutter 方块迷阵游戏开发全解析:构建可扩展的关卡式益智游戏
前端·flutter·游戏·游戏引擎·游戏程序·harmonyos