算法超简单:趣味游戏带你轻松入门与实践
上QQ阅读APP看书,第一时间看更新

2.2 小球的自由落体

本节讲解如何实现小球的自由落体运动效果,完整代码参见配套资源中的2-2.cpp,扫描右侧二维码观看视频效果“2.2 小球的自由落体”。下面对2-2.cpp中的一些关键内容进行讲解,代码对应的行号是它们在2-2.cpp中的行号。

2.2 小球的自由落体

首先用一个小球表示游戏中的小鸟,定义结构体记录小球圆心的横、纵坐标xy,纵轴方向的速度vy,半径radius,代码如下。

2-2.cpp

 8    struct Bird // 小鸟结构体
 9    {  
10        float x, y, vy, radius; // 小球圆心坐标(x,y)、y轴方向的速度vy、半径
    radius  
11    };  

在程序开头,使用宏定义的形式设定画面的宽度WIDTH、高度HEIGHT、重力加速度G,代码如下。

2-2.cpp

 4    #define WIDTH 800  // 游戏画面宽度
 5    #define HEIGHT 600 // 游戏画面高度  
 6    #define G  0.3  // 重力加速度  

在while循环语句中,首先根据重力加速度G计算速度vy,然后利用vy更新小球圆心的纵坐标y,从而实现小球加速下落的效果,代码如下。

2-2.cpp

24        while (1) // 一直循环
25        {  
26            bird.vy = bird.vy + G;  // 根据重力加速度更新小球在y方向的速度  
27            bird.y = bird.y + bird.vy;  // 根据小球在y方向的速度更新其圆心
    的纵坐标  

当小球碰到画面的下边界时,重新设置小球圆心的纵坐标y,代码如下。

2-2.cpp

29            if (bird.y >= HEIGHT - bird.radius)  // 如果小球碰到画面的下边界
30            {  
31                bird.y = HEIGHT / 6;  // 重新设置小球圆心的纵坐标  
32                bird.vy = 0;  // 小球在y方向的初始速度设为0  
33            }  

更新小球的速度和位置后,依次执行清空画面、绘制新位置的小球、暂停10毫秒,即可实现小球重复加速下落的动画效果,代码如下。

2-2.cpp

35            cleardevice();  // 清空画面
36            fillcircle(bird.x, bird.y, bird.radius);  // 绘制小球  
37            Sleep(10);  // 暂停10毫秒