首页 > 其他分享 >基于EasyX和Raylib的别碰方块

基于EasyX和Raylib的别碰方块

时间:2023-01-25 20:44:28浏览次数:58  
标签:ball Raylib float EasyX height 别碰 radius vy rect

基于 EasyX

// 根据《C和C++游戏趣味编程》第三章 别碰方块 写出

#include <graphics.h>
#include <conio.h> // _kbhit()
#include <stdio.h>

// 检测按下了空格键
void demo_3_1_3()
{
    while (1)
    {
        if (kbhit()) // 当按键时
        {
            char input = getchar(); // 获得输入字符
            if (input == ' ')
            {
                printf("按下了空格!\n");
            }
        }
    }
}

// 按空格键控制小球起跳
void demo_3_2()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        Sleep(10);
    }

    closegraph();
}

// 在绘制小球的同时,绘制静态方块
void demo_3_3_1()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        fillrectangle(rect_left_x, height - rect_height, rect_left_x + rect_width, height);
        Sleep(10);
    }

    closegraph();
}

// 绘制小球的同时, 绘制向左匀速移动的方块: 在 3_3_1 基础上增加 rect_vx
void demo_3_3_2()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
        }

        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        fillrectangle(rect_left_x, height - rect_height, rect_left_x + rect_width, height);
        Sleep(10);
    }

    closegraph();
}

// 基于demo_3_3_2(), 检测到小球和方块碰撞时,Sleep()一段时间实现类似慢动作的效果
void demo_3_4_2()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
        }

        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            Sleep(100); // 慢动作效果
        }

        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        fillrectangle(rect_left_x, height - rect_height, rect_left_x + rect_width, height);
        Sleep(10);
    }

    closegraph();
}

// 当方块重新出现时, 随机方块的速度和高度. 基于 demo_3_4_2
void demo_3_5_4()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100;
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
            rect_height = rand() % int(height / 4) + height / 4; // 方块高度, 设置为随机的高度
            rect_vx = rand() / float(RAND_MAX) * 4 - 7; // [0, 4] - 7 = [-7, -3]
        }

        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            Sleep(100); // 慢动作效果
        }

        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        fillrectangle(rect_left_x, height - rect_height, rect_left_x + rect_width, height);
        Sleep(10);
    }

    closegraph();
}

// 加入得分机制,并显示得分
// 在书上代码基础上, 增加得分的时机从“方块到达左边边界”改为:当前方块没有和小球发生碰撞,并且小球刚刚跳过方块时,得分增加
void demo_3_6()
{
    float width = 600;
    float height = 400;
    initgraph(width, height);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100;
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    int score = 0;
    bool first_time_being_left = false;
    bool collision = false;

    while (1)
    {
        if (kbhit())
        {
            //char input = getchar(); // getchar() 会等待按下回车
            char input = _getch();  // 要想获得实时响应,用 _getch()
            if (input == ' ')
            {
                ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
            }
            else if (input == 'q')
            {
                break;
            }
        }

        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        rect_left_x = rect_left_x + rect_vx;
        // 如果方块跑到最左边
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
            first_time_being_left = false;
            collision = false;

            rect_height = rand() % int(height / 4) + height / 4; // 方块高度, 设置为随机的高度
            rect_vx = rand() / float(RAND_MAX) * 4 - 7; // [0, 4] - 7 = [-7, -3]
        }

        // 如果小球碰到方块
        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            Sleep(100); // 慢动作效果
            score = 0; // 得分清零
            collision = true;
        }

        // 如果方块没有和小球碰撞,那么方块刚刚处于小球左边时,增加得分
        if (rect_left_x + rect_width < ball_x - radius && first_time_being_left == false && collision == false)
        {
            first_time_being_left = true;
            score++; // 增加得分
        }
        
        cleardevice();
        fillcircle(ball_x, ball_y, radius);
        fillrectangle(rect_left_x, height - rect_height, rect_left_x + rect_width, height);

        char s[20] = { 0 };
        sprintf(s, "score: %d", score);

        const int fontsize = 40;
        settextstyle(fontsize, 0, _T("Consolas"));

        settextcolor(LIGHTGRAY);
        outtextxy(50, 30, s);

        Sleep(10);
    }

    closegraph();
}

int main()
{
    //demo_3_1_3();
    //demo_3_2();
    //demo_3_3_1();
    //demo_3_3_2();
    //demo_3_4_2();
    //demo_3_5_4();
    demo_3_6();

    return 0;
}

基于 Raylib

// 根据《C和C++游戏趣味编程》第三章 别碰方块 写出

#include "raylib.h"
#include <stdio.h>
#include <stdlib.h>

// 检测按下了空格键
void demo_3_1_3()
{
    InitWindow(600, 600, "don't touch the square");
    SetTargetFPS(60);

    while (!WindowShouldClose())
    {
        // 这种写法, 会在每一帧都输出。感觉不够灵敏。
        // char input = getchar();
        // if (input == ' ')
        // if (IsKeyDown(KEY_SPACE))
        // {
        //     printf("按下了空格!\n");
        // }
        // else
        // {
        //     printf("不知道啥\n");
        // }

        // 只在检测到按键按下,并且按键为空格的情况下,才输出内容。符合预期。
        if (GetKeyPressed() == ' ')
        {
            printf("按下了空格!\n");
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
        }
        EndDrawing();
    }

    CloseWindow();
}

// 按空格键控制小球起跳
void demo_3_2()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    while (!WindowShouldClose())
    {
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
        }
        EndDrawing();
    }

    CloseWindow();
}


// 在绘制小球的同时,绘制静态方块
void demo_3_3_1()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标

    while (!WindowShouldClose())
    {
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
            DrawRectangle(rect_left_x, height - rect_height, rect_width, rect_height, WHITE);
        }
        EndDrawing();
    }

    CloseWindow();
}

// 绘制小球的同时, 绘制向左匀速移动的方块: 在 3_3_1 基础上增加 rect_vx
void demo_3_3_2()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    while (!WindowShouldClose())
    {
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
            DrawRectangle(rect_left_x, height - rect_height, rect_width, rect_height, WHITE);
        }
        EndDrawing();
    }

    CloseWindow();
}

// 基于demo_3_3_2(), 检测到小球和方块碰撞时,Sleep()一段时间实现类似慢动作的效果
void demo_3_4_2()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;

    while (!WindowShouldClose())
    {
        rect_vx = -3;
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        // 由于 raylib 是一开始生成窗口时就指定了 FPS, 这里碰撞的效果不能像 easyx 一样直接调用 Sleep()
        // 解决办法是,在更新 rect_left_x 之前判断和减小 rect_vx 的绝对值。
        // 并且在每一帧的最初处理部分, 恢复 rect_vx = -3
        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            rect_vx = -1;
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
            DrawRectangle(rect_left_x, height - rect_height, rect_width, rect_height, WHITE);
        }
        EndDrawing();
    }

    CloseWindow();
}

// 当方块重新出现时, 随机方块的速度和高度. 基于 demo_3_4_2
void demo_3_5_4()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;
    float old_rect_vx = -3; // 之前用于碰撞减速的trick,更新为使用变量记录前一次的速度

    while (!WindowShouldClose())
    {
        rect_vx = old_rect_vx;
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        // 由于 raylib 是一开始生成窗口时就指定了 FPS, 这里碰撞的效果不能像 easyx 一样直接调用 Sleep()
        // 解决办法是,在更新 rect_left_x 之前判断和减小 rect_vx 的绝对值。
        // 并且在每一帧的最初处理部分, 恢复 rect_vx = -3
        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            old_rect_vx = rect_vx;
            rect_vx = rect_vx + 2;
        }

        rect_left_x = rect_left_x + rect_vx;
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
            rect_height = rand() % int(height / 4) + height / 4; // 方块高度, 设置为随机的高度
            rect_vx = rand() / float(RAND_MAX) * 4 - 7; // [0, 4] - 7 = [-7, -3]
            old_rect_vx = rect_vx;
        }

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
            DrawRectangle(rect_left_x, height - rect_height, rect_width, rect_height, WHITE);
        }
        EndDrawing();
    }

    CloseWindow();
}

// 加入得分机制,并显示得分
// 在书上代码基础上, 增加得分的时机从“方块到达左边边界”改为:当前方块没有和小球发生碰撞,并且小球刚刚跳过方块时,得分增加
void demo_3_6()
{
    float width = 600;
    float height = 400;
    InitWindow(width, height, "don't touch the square");
    SetTargetFPS(60);

    float gravity = 0.6;
    float radius = 20;
    float ball_x = width / 4;
    float ball_y = height - radius;
    float ball_vy = 0;

    float rect_height = 100; // 方块高度
    float rect_width = 20; // 方块宽度
    float rect_left_x = width * 3 / 4; // 方块左边 x 坐标
    float rect_top_y = height - rect_height; // 方块顶部 y 坐标
    float rect_vx = -3;
    float old_rect_vx = -3; // 之前用于碰撞减速的trick,更新为使用变量记录前一次的速度

    int score = 0;
    bool first_time_being_left = false;
    bool collision = false;

    while (!WindowShouldClose())
    {
        rect_vx = old_rect_vx;
        // Update
        if (GetKeyPressed() == ' ')
        {
            ball_vy = -16; // 当按下空格键时, 给小球一个向上的初速度
        }
        else if (GetKeyPressed() == 'q') // 对应到 ESC 键而不是q键,很奇怪
        {
            break;
        }
        ball_vy = ball_vy + gravity; // 根据重力加速度,更新小球y方向速度
        ball_y = ball_y + ball_vy; // 根据小球y方向速度更新其y坐标
        if (ball_y >= height - radius) // 如果小球落到地面上
        {
            ball_vy = 0; // y 速度为0
            ball_y = height - radius; // 规范其y坐标,避免落到地面下
        }

        // 如果小球碰到方块
        // 由于 raylib 是一开始生成窗口时就指定了 FPS, 这里碰撞的效果不能像 easyx 一样直接调用 Sleep()
        // 解决办法是,在更新 rect_left_x 之前判断和减小 rect_vx 的绝对值。
        // 并且在每一帧的最初处理部分, 恢复 rect_vx = -3
        if ( (rect_left_x <= ball_x + radius)
            && (rect_left_x + rect_width >= ball_x - radius)
            && (height - rect_height <= ball_y + radius))
        {
            score = 0;
            collision = true;
            old_rect_vx = rect_vx;
            rect_vx = rect_vx + 2;
        }

        // 如果方块没有和小球碰撞,那么方块刚刚处于小球左边时,增加得分
        if (rect_left_x + rect_width < ball_x - radius && first_time_being_left == false && collision == false)
        {
            first_time_being_left = true;
            score++; // 增加得分
        }

        rect_left_x = rect_left_x + rect_vx;
        // 如果方块跑到最左边
        if (rect_left_x <= 0)
        {
            rect_left_x = width; // 在最右边重新出现
            first_time_being_left = false;
            collision = false;

            rect_height = rand() % int(height / 4) + height / 4; // 方块高度, 设置为随机的高度
            rect_vx = rand() / float(RAND_MAX) * 4 - 7; // [0, 4] - 7 = [-7, -3]
            old_rect_vx = rect_vx;
        }

        char s[20] = { 0 };
        sprintf(s, "score: %d", score);

        // Draw
        BeginDrawing();
        {
            ClearBackground(BLACK);
            DrawCircle(ball_x, ball_y, 20, WHITE);
            DrawRectangle(rect_left_x, height - rect_height, rect_width, rect_height, WHITE);

            const int pos_x = 50;
            const int pos_y = 30;
            const int font_size = 40;
            DrawText(s, pos_x, pos_y, font_size, LIGHTGRAY);
        }
        EndDrawing();
    }

    CloseWindow();
}

int main()
{
    //demo_3_1_3();
    //demo_3_2();
    //demo_3_3_1();
    //demo_3_3_2();
    //demo_3_4_2();
    //demo_3_5_4();
    demo_3_6();

    return 0;
}

标签:ball,Raylib,float,EasyX,height,别碰,radius,vy,rect
From: https://www.cnblogs.com/zjutzz/p/17067265.html

相关文章

  • 基于EasyX和Raylib的推箱子
    基于EasyX//根据《C和C++游戏趣味编程》第九章推箱子写出#include<graphics.h>#include<conio.h>//_kbhit()#include<stdio.h>#include<stdlib.h>//玩......
  • 基于EasyX和Raylib的坚持100秒
    EasyX//根据《C和C++游戏趣味编程》第12章坚持100秒写出#include<graphics.h>#include<conio.h>//_kbhit()#include<stdio.h>#include<stdlib.h>#include......
  • 基于EasyX和Raylib的字符雨
    思路按如下顺序尝试:绘制一个字符下落绘制4个字符(一列)的下落绘制20个字符(一列)的下落,并封装其位置更新、绘制的过程为Rain类的成员函数绘制多个雨滴每个雨滴在更新......
  • 基于EasyX和Raylib的贪吃蛇
    基于EasyX//根据《C和C++游戏趣味编程》第七章贪吃蛇写出#include<graphics.h>#include<conio.h>//_kbhit()#include<stdio.h>#include<stdlib.h>//全......
  • EasyX——概要
    EasyX之绘图(配置与显示图片)EasyX之鼠标   ......
  • C++利用easyX实现一个简单图形化窗口
    在实现这个图形化窗口过程中遇到了一些琐碎的问题,不过还是解决了首先easyX下载地址https://easyx.cn/download下载之后安装到VS上或者自己想使用的软件上就行1#incl......
  • EasyX入门笔记
    基于EasyX的C++图形化界面实现什么是EasyX?EasyX是针对C++的图形库,可以帮助C/C++初学者快速上手图形和游戏编程。比如,可以基于EasyX图形库很快的用几何图形画一......
  • EasyX绘制多边形
    引言:在Easyx中,专门给了一个函数绘制多边形——polygon函数一、打印较简单的多边形像长方形、正方形、三角形、梯形这些多边形较容易打印,因为他们的顶点坐标较容易求出。比如......
  • Easyx绘制基本图形
    前言:本文旨在利用Easyx函数绘制一些基本图形,例如圆、扇形、矩形、椭圆、半角矩形等等,且含有函数具体使用方法。#include<easyx.h>#include<stdio.h>#definePI3.14intmain......
  • # VS2022手动引入easyX绘制工具
    1.下载EasyX_20220901.exe安装包,手动修改后缀名为7z,解压2、找到vs的安装目录\MicrosoftVisualStudio\2022\Professional\VC\Auxiliary\VS3、把前面解压出来的include......