Bounce off the walls
io error: No such file or directory (os error 2) (/home/runner/work/yari/yari/mdn/content/files/en-us/games/workflows/2d_breakout_game_phaser/physics/index.md)
这是Gamedev Phaser 教程的第 6 步。在Gamedev-Phaser-Content-Kit / demos / lesson06.html完成本课后,你可以找到源代码。
现在已经介绍了物理引擎,我们可以开始在游戏中实现碰撞检测 - 首先我们来看看墙壁。
反弹边界
让我们的球从墙壁上弹起的最简单的方法是告诉框架,我们想要将 <canvas>
元素的边界视为墙壁,而不是让球移过它们。在 Phaser 中,可以使用该 collideWorldsBound
属性轻松实现。在现有 game.physics.enable()
方法调用之后添加此行:
ball.body.collideWorldBounds = true;
现在球将停在屏幕的边缘,而不是消失,但它不会弹起。为了使这种情况发生,我们必须设置它的 bounciness。在上一行下面添加以下行:
ball.body.bounce.set(1);
再次尝试重新加载 index.html - 现在你应该看到球从墙壁上弹起并在画布区域内移动。
比较你的代码
你可以在下面的现场演示中查看本课程的完成代码,并使用它来更好地了解它的工作原理:
下一步
现在开始看起来更像是一个游戏,但是我们无法以任何方式控制它 - 现在是介绍玩家挡板和控制的时候了。
io error: No such file or directory (os error 2) (/home/runner/work/yari/yari/mdn/content/files/en-us/games/workflows/2d_breakout_game_phaser/physics/index.md)