C++小游戏BrickHit实例代码
更新时间:2020年4月25日 17:28 点击:1380
打砖块小游戏。材料:EasyX图形库。
碰撞的处理,木板移动方法还需要优化。
//定义 Circle,Brick,Broad #include<cmath> #include<graphics.h> #ifndef _PROPERTY_H_ #define _PROPERTY_H_ struct Circle { int x0, y0, r; int mvX, mvY; COLORREF color; virtual ~Circle() {} Circle(int x0_, int y0_, int r_, int mvX_, int mvY_, COLORREF color_) :x0(x0_), y0(y0_), r(r_), mvX(mvX_), mvY(mvY_), color(color_) {} //小球起始位置 void prtCirl() { setfillcolor(color); solidcircle(x0, y0, r); } //小球的移动 void CirlMove() { setfillcolor(BLACK); solidcircle(x0, y0, r); x0 += mvX; y0 += mvY; setfillcolor(color); solidcircle(x0, y0, r); } //判断小球是否离开宽口内。 //参数:窗口左上坐标、宽、高。 //离开返回真。 bool IsCirlQuit(int x, int y, int width, int height) { if (x0 - x <= r && mvX < 0) { mvX = -mvX; return false; } else if (x + width - x0 <= r && mvX > 0) { mvX = -mvX; return false; } else if (y0 - y <= r && mvY < 0) { mvY = -mvY; return false; } else if (y + height - y0 <= r) return true; return false; } }; struct Brick { int x0, y0; COLORREF color; int height, width; virtual ~Brick() {} Brick(int x0_, int y0_, int width_, int height_, COLORREF color_) :x0(x0_), y0(y0_), width(width_), height(height_), color(color_) {} //砖块的绘制 void prtBrick() { setfillcolor(color); solidrectangle(x0, y0, x0 + width, y0 + height); } //判断砖块是否与小球发生碰撞 //参数:小球 //发生碰撞返回真 bool IsCrashCirl(Circle &arg) { if (arg.x0 + arg.r < x0 || x0 + width < arg.x0 - arg.r) return false; int disY = min(abs(y0 - arg.y0), abs(y0 + height - arg.y0)); if (disY <= arg.r) { arg.mvY = -arg.mvY; return true; } return false; } //砖块的清除 void BrickClr() { setfillcolor(BLACK); solidrectangle(x0, y0, x0 + width, y0 + height); } }; struct Broad :public Brick{ int mvX; int floor, ceiling; virtual ~Broad() {} Broad(int x0_, int y0_, int width_, int height_, int mvX_, int floor_, int ceiling_, COLORREF color_) :Brick(x0_, y0_, width_, height_, color_), mvX(mvX_), floor(floor_), ceiling(ceiling_) {} //重载,判断木板是否与小球发生碰撞 //参数:小球 //发生碰撞返回真 bool IsCrashCirl(Circle &arg) { if (arg.x0 + arg.r < x0 || x0 + width < arg.x0 - arg.r) return false; if (y0 - arg.y0 <= arg.r&&arg.mvY > 0) { arg.mvY = -arg.mvY; return true; } return false; } //木板移动 void BroadMove() { POINT point; GetCursorPos(&point); if (x0 <= point.x&&point.x <= x0) return; BrickClr(); if (point.x < x0) x0 = max(x0 - mvX, floor); else x0 = min(x0 + mvX, ceiling - width); setfillcolor(color); solidrectangle(x0, y0, x0 + width, y0 + height); } }; #endif // _PROPERTY_H_
//Main.cpp #include<list> #include<algorithm> #include"property.cpp" using namespace std; const int WndW = 400, WndH = 400; //窗口大小 list<Brick> CreatBricks(); bool theGame(list<Brick> &MyBrks, Broad &MyBrd, Circle&MyCirl); int main() { //brick布局 list<Brick> MyBrks = move(CreatBricks()); //broad:60*20,移速5,WHITE Broad MyBrd(WndW/2 - 30, WndH - 20, 60, 20, 5, 0, WndW, WHITE); //circle:半径5,移速5,DARKGRAY Circle MyCirl(WndW/2 - 10, WndH - 20 - 10, 10, 5, 5, DARKGRAY); HWND Hwnd = initgraph(WndW, WndH); bool GameOver = theGame(MyBrks, MyBrd, MyCirl); if (GameOver) MessageBox(Hwnd, L"u Win!", L"BrickHit",MB_OK); else MessageBox(Hwnd, L"default!", L"BrickHit", MB_OK); closegraph(); return 0; } //bricks的实现 list<Brick> CreatBricks() { //brick信息:5行10列,40*10 int Row = 5, Col = 10; int BrickW = WndW / Col; int BrickH = 10; list<Brick> MyBrks; bool ColChoice = true; for (int i = Row - 1; i >= 0; i--) { ColChoice = !ColChoice; for (int j = 0; j < Col; j++) switch (ColChoice) { case true: MyBrks.push_back({ BrickW*j,BrickH*i,BrickW,BrickH,LIGHTGREEN }); ColChoice = !ColChoice; break; case false: MyBrks.push_back({ BrickW*j,BrickH*i,BrickW,BrickH,LIGHTCYAN }); ColChoice = !ColChoice; break; } } return MyBrks; } //游戏的实现 bool theGame(list<Brick> &MyBrks, Broad &MyBrd, Circle&MyCirl) { //游戏起始界面 for_each(MyBrks.begin(), MyBrks.end(), [](Brick it) { it.prtBrick(); }); MyBrd.prtBrick(); MyCirl.prtCirl(); //游戏循环 while (!MyBrks.empty()) { MyCirl.CirlMove(); MyBrd.BroadMove(); if (MyCirl.IsCirlQuit(0, 0, WndW, WndH)) return false; MyBrd.IsCrashCirl(MyCirl); auto theBrick = find_if(MyBrks.begin(), MyBrks.end(), [&MyCirl](Brick it) { return it.IsCrashCirl(MyCirl); }); if (theBrick != MyBrks.end()) { theBrick->BrickClr(); MyBrks.erase(theBrick); } Sleep(30); } return true; }
总结
以上所述是小编给大家介绍的C++小游戏BrickHit实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对猪先飞网站的支持!
下一篇: OpenCV实现马赛克功能
相关文章
- vector是表示可以改变大小的数组的序列容器,本文主要介绍了C++STL标准库std::vector的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2022-03-06
- 这篇文章主要介绍了C++中取余运算的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
- 这篇文章主要介绍了C++ string常用截取字符串方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 本文通过例子,讲述了C++调用C#的DLL程序的方法,作出了以下总结,下面就让我们一起来学习吧。...2020-06-25
- 本篇文章主要介绍了C++中四种加密算法之AES源代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...2020-04-25
- 整数拆分,指把一个整数分解成若干个整数的和。本文重点给大家介绍C++ 整数拆分方法详解,非常不错,感兴趣的朋友一起学习吧...2020-04-25
- 这篇文章主要介绍了C++中Sort函数详细解析,sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变...2022-08-18
- 这篇文章主要介绍了C++万能库头文件在vs中的安装步骤(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
- 这篇文章主要介绍了C++ bitset用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 本篇文章小编并不是为大家讲解string类型的用法,而是讲解我个人比较好奇的问题,就是string 类型占几个字节...2020-04-25
- 这篇文章主要为大家详细介绍了C++ Eigen库计算矩阵特征值及特征向量,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
- 这篇文章主要介绍了C++ pair的用法实例详解的相关资料,需要的朋友可以参考下...2020-04-25
- 这篇文章主要介绍了VSCode C++多文件编译的简单使用方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-03-29
- 虽然C++11引入了智能指针的,但是开发人员在与内存的斗争问题上并没有解放,如果我门实用不当仍然有内存泄漏问题,其中智能指针的循环引用缺陷是最大的问题。下面通过实例代码给大家介绍c++中的循环引用,一起看看吧...2020-04-25
- 这篇文章主要给大家介绍了关于C++随机点名生成器的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- map容器是C++ STL中的重要一员,删除map容器中value为指定元素的问题是我们经常与遇到的一个问题,下面这篇文章主要给大家介绍了关于利用C++如何删除map容器中指定值的元素的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。...2020-04-25
- 这篇文章主要介绍了C++ 约瑟夫环问题案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...2021-08-15
- 这篇文章主要介绍了C++中cin的用法详细,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 本篇文章是对C++中的常见编译错误进行了详细的分析介绍,需要的朋友参考下...2020-04-25
- 这篇文章主要介绍了c++优先队列(priority_queue)用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25