【硬核教程】,如何摆脱黑白框编程,1小时学会用c++做一个飞机大战

简介: 【硬核教程】,如何摆脱黑白框编程,1小时学会用c++做一个飞机大战

老规矩,先上效果图:

在这里插入图片描述

最近很多同学加我好友后问我,c++是学完了,但是不知道能做什么。是否应该更加深入学习,更深入研究。其实,c++学完后,最重要的是实践能力,需要知道自己行不行,动手编写下代码就知道了。

我们可以做一些具体的项目,例如贪吃蛇,俄罗斯方块,或者我今天讲的这个飞机大战。然后小伙伴又说:c++的黑白框太low了,怎么可以整得高大上一点呢?其实,不难的,你们可以试着用一下easyx,这个是一个c++的图形库。我们可以用来写一些图形,从此告别黑白框。\

image.png

来,我们直接进入主题:\
这个打飞机小游戏素材都很一般,直接网上抠图下来的。子弹素材还是我自己随便一个截图。不过这些都不影响我们撸代码。我们应该学习一下怎么入门这一款经典小游戏。

image.png

首先游戏对象就这几个东西

// 全局画板
IMAGE bk;
IMAGE BK;
IMAGE Plane;
IMAGE Diren;
IMAGE Zidan;

这个游戏用到游戏插件easyX,我们想载入这几个图片。

//预加载资源,需要加载了之后才能用
void loadRes()
{
    loadimage(&bk, _T("res\\bg.png"));

    loadimage(&BK, _T("res\\bg.png"));
    loadimage(&Plane, _T("res\\plane.png"));

    loadimage(&Diren, _T("res\\diren.png"));
    loadimage(&Zidan, _T("res\\zidan.png"));
}

子弹和敌人的结构体先设计好,其实就是用来控制他们的位置的。

struct ZIDAN
{
    int x;
    int y;
};

struct DIREN
{
    int x;
    int y;
};

子弹和敌人是否碰撞,这里需要写碰撞检测,其实就是几点两点之间的距离就可以,这是最经典的碰撞算法。

bool isPeng(int x2,int y2,int x1,int y1)
{
    int result=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
    if(result<2500)
    {
        return true;
    }
    return false;
}

子弹与敌人碰撞之后,敌人就毁灭。这里面只需要把敌人移出屏幕就可以,因为子弹和敌人都是可以重复利用的,所以最好做一个对象池,可以重复用上。

    //判断子弹和飞机是否相撞
        for(i=0;i<8;i++)
        {
            for(int j=0;j<5;j++)
            {
                if(isPeng(zidans[j].x,zidans[j].y,direns[i].x+25,direns[i].y+15))
                {
                    direns[i].y = -100;
                }
            }
        }

需要wsad进行控制摇杆,飞机飞行

        if (_kbhit()) 
        {
            char ch = _getch();
            if (ch == 'w') 
            {
                planeY-=5;
            }
            if(ch == 's')
            {
                planeY+=5;
            }
            if(ch == 'a')
            {
                planeX-=5;
            }
            if(ch == 'd')
            {
                planeX+=5;
            }
        }

根据透明度绘图

// 根据透明度绘图
void drawAlpha(IMAGE* dstimg, int x, int y, IMAGE* srcimg)
{
    if (dstimg == NULL)
    {
        return;
    }
    // 变量初始化
    DWORD *dst = GetImageBuffer(dstimg);
    DWORD *src = GetImageBuffer(srcimg);
    int src_width = srcimg->getwidth();
    int src_height = srcimg->getheight();
    int dst_width = dstimg->getwidth();
    int dst_height = dstimg->getheight();

    // 实现透明贴图  可优化

}

…完整代码,请移步到公众号:诗一样的代码

相关文章
|
2月前
|
编译器 C++ 开发者
C++一分钟之-C++20新特性:模块化编程
【6月更文挑战第27天】C++20引入模块化编程,缓解`#include`带来的编译时间长和头文件管理难题。模块由接口(`.cppm`)和实现(`.cpp`)组成,使用`import`导入。常见问题包括兼容性、设计不当、暴露私有细节和编译器支持。避免这些问题需分阶段迁移、合理设计、明确接口和关注编译器更新。示例展示了模块定义和使用,提升代码组织和维护性。随着编译器支持加强,模块化将成为C++标准的关键特性。
102 3
|
20天前
|
人工智能 JavaScript 开发工具
C++中的AI编程助手添加
今天为大家推荐一款适配了 Viusal Studio(本文使用),VS Code(本文使用),JetBrains系列以及Vim等多种编译器环境的插件 Fitten Code,Fitten Code 是由非十大模型驱动的 AI 编程助手,它可以自动生成代码,提升开发效率,帮您调试 Bug,节省您的时间,另外还可以对话聊天,解决您编程碰到的问题。 Fitten Code免费且支持 80 多种语言:Python、C++、Javascript、Typescript、Java等。
67 8
|
2月前
|
存储 C++
【C++航海王:追寻罗杰的编程之路】一篇文章带你了解二叉搜索树
【C++航海王:追寻罗杰的编程之路】一篇文章带你了解二叉搜索树
27 1
|
2月前
|
算法 安全 编译器
【C++航海王:追寻罗杰的编程之路】C++11(四)
【C++航海王:追寻罗杰的编程之路】C++11(四)
24 0
|
2月前
|
存储 自然语言处理 C++
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
26 0
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
|
2月前
|
设计模式 编译器 C++
【C++航海王:追寻罗杰的编程之路】特殊类的设计方式你知道哪些?
【C++航海王:追寻罗杰的编程之路】特殊类的设计方式你知道哪些?
16 0
|
2月前
|
编译器 C++
【C++航海王:追寻罗杰的编程之路】多态你了解多少?
【C++航海王:追寻罗杰的编程之路】多态你了解多少?
19 0
|
6天前
|
C++ 容器
C++中自定义结构体或类作为关联容器的键
C++中自定义结构体或类作为关联容器的键
12 0
|
6天前
|
存储 算法 搜索推荐
【C++】类的默认成员函数
【C++】类的默认成员函数
|
5天前
|
存储 安全 编译器
【C++】类和对象(下)
【C++】类和对象(下)
【C++】类和对象(下)