用C中的allegro库制作射弹射击

时间:2014-12-17 13:50:45

标签: c allegro

我正在尝试使用C.中的allegro库进行射弹射击。我无法做到这一点。我的所有代码都在下面。我的圆圈上升然后消失。即使不是我也可以'把它带到地上。我不善于体力,所以如果我的平等是错的,请原谅我。

#include <allegro.h>
#include < math.h >


void StartAlleg(); // my start program function
void EndAlleg();



int main() {
    StartAlleg();

    BITMAP *buffer = create_bitmap(640, 480);

    int   g = 10, Vo = 0 , Vx = 5, Vy = 475, angle= 0;
    double time = 0, tUp = 0,hmax=0; //g is gravity

    show_mouse(screen);
    while (!key[KEY_ESC])
    {
        circle(buffer,  Vx, Vy, 5, makecol(255, 0, 0));

        if (key[KEY_UP]&&angle<360) angle++;
        if (key[KEY_RIGHT]) Vo++;
        if (key[KEY_DOWN] && angle>0) angle--;
        if (key[KEY_LEFT] && Vo>0) Vo--;

        textout_ex(buffer, font, "Player 1 : ", 0, 0, makecol(255, 255, 13), -1);
        textprintf(buffer, font, 0, 25, makecol(255, 255, 13), "Angle = %d  ",angle);
        textprintf(buffer, font, 0, 15, makecol(255, 255, 13), "Speed = %d  ", Vo);




        if (key[KEY_Z]  ){


            Vx = Vo*cos(double(angle));
            Vy = Vo*sin(double(angle));
            if (angle== 180 || angle == 360) Vy = 0;
            if (angle== 90 || angle== 270) Vx = 0;
            if (Vx < 0) Vx *= (-1);
            if (Vy < 0) Vy *= (-1);

            tUp = Vy / g;
            time = tUp * 2;

            hmax = (Vy*Vy) / (2*g);


                }

        textprintf(buffer, font, 0, 35, makecol(255, 255, 13), "tUp Value = %.2f  ", tUp);

        for (int i = 1; i <= time; i++)
        {
            if (i<tUp){ Vx = Vx + g; Vy += g; }

            else{ Vy -= g; Vx = Vx + g; }


        }


            blit(buffer, screen, 0, 0, 0, 0, 640, 480);
            rest(60);
            clear_bitmap(buffer);

    }

    EndAlleg(); // my end program function
    return 0;
}
END_OF_MAIN()



void StartAlleg() {
    int depth, res;
    allegro_init();
    depth = desktop_color_depth();
    if (depth == 0) depth = 32;
    set_color_depth(depth);
    res = set_gfx_mode(GFX_AUTODETECT_WINDOWED, 640, 480, 0, 0);
    if (res != 0) {
        allegro_message(allegro_error);
        exit(-1);
    }
    install_timer();
    install_keyboard();
    install_mouse();
    install_sound(DIGI_AUTODETECT, MIDI_AUTODETECT, "A");
}
void EndAlleg() {
    clear_keybuf();

}

我认为,主要问题在于:

 for (int i = 1; i <= time; i++)
            {
                if (i<tUp){ Vx = Vx + g; Vy += g; }

                else{ Vy -= g; Vx = Vx + g; }


            }

1 个答案:

答案 0 :(得分:1)

我没有尝试理解您的所有代码,但似乎您的计算错误。

以下是重力的实施方式:

首先,您需要使用Px Py等变量跟踪您的射弹位置。该位置将为您提供绘图坐标。 然后,您需要使用Vx Vy等变量跟踪其速度,通常是水平和垂直速度。如果您的初始速度是带角度的单个矢量,请将其转换一次。

游戏的每个刻度(在您的情况下每个循环迭代),您将速度添加到位置。然后为了增加重力,你可以减去10到垂直速度,也可以在每个刻度处减去(它实现-10的加速度)。

这就是全部。负速度和加速度是正常的,您不需要检查,但您可以检查位置的边界。此外,您应该注意,您通常将速度和加速度除以刻度的频率,否则循环越快,射弹的移动速度就越快。

您应该注意,这不是实现重力的最佳方式,因为这只是近似物理(每秒更多的滴答将为您提供更准确的模拟)。你应该谷歌“游戏工具重力正确”的准确算法,我不是专家。