C++用easyx图形库实现障碍跑酷小游戏

用easyx图形库做一个简单的c++小游戏—障碍跑酷

开发环境:visual c++6.0

库:easyx图形库 下载地址

EasyX(c++图形库) v20200806 官方安装免费版

当时我原本是想模仿做一个Flappy Bird的小游戏,在想如何写的时候突然有了新的想法,就有了这个障碍跑酷的小游戏。(这是我之前写的代码,没有很注重规范,看上去有点乱,但我很尽力的都标上了注释。)

游戏介绍:

1.操控小球,小球一开始只具有左a,右d与跳跃w的功能
2.可根据按1,2,3,4调节小球的跳跃高度
3.在一定时间段内会持续出现障碍,障碍高度不一,需要调节跳跃高度来跳跃通过
4.在1000,2500,4000分数位加大难度(实际就是缩短障碍间的距离),并获取技能点数,可用于增加小球能力
5.触发商店,消耗节能点数可增加血量,减少半径,加快速度,开启下降s功能(四选一)
6.每次死亡后比较现在分数与最高分数,高则替换

游戏界面:

第一难度:分数小于1000

第二难度:分数1300-2500

第三难度:分数2800-4000

第四难度:分数大于4300(有点考验手速)

商店触发界面:(图片是我从百度随便下载的,也不知道出自哪里的)

附上代码: (设置的变量有点多,当时也没规范命名,但我逐个标上了注释)
图片随便用4个就行,记得要修改图片地址

//操作介绍:a左,d右,w上。1,2,3,4调节跳跃高度
#include <iostream>
#include <graphics.h>
#include <conio.h>
#include <time.h>
#include <fstream>
using namespace std;
int nowscore(0),highscore(0),hp(3),radius(10),speed(3),skill(0);
bool under=false;
/*
nowscore代表现在分数
highscore代表最高分数
hp=代表玩家的血量
speed=玩家的速度
skill代表玩家的技能点数
under为玩家是否拥有的下落能力
*/
IMAGE img1,img2,img3,img4;

void death(){//死亡记录分数
 if(nowscore>highscore){//如果现在分数高于最高分数则替换文件中的分数记录
 ofstream out;
 out.open(".\\最高得分.txt");//打开文件
 out<<nowscore;
 out.close();
 }//if
}
void shopshop(){//商店界面
 while(1){
 settextcolor(DARKGRAY);
 settextstyle(15,0,"宋体");
 setfillcolor(BLACK);
 //图片加载(图片地址写上自己的图片地址)
 loadimage(&img1,".\\血量增加.jpg",30,30);
 loadimage(&img2,".\\半径变小.jpg",30,30);
 loadimage(&img3,".\\速度加快.jpg",30,30);
 loadimage(&img4,".\\下降技能.jpg",30,30);
 putimage(50,50,&img1);
 putimage(50,100,&img2);
 putimage(50,150,&img3);
 putimage(50,200,&img4);
 outtextxy(90,55,"血量加一(1)");
 outtextxy(90,105,"半径变小(2)");
 outtextxy(90,155,"速度加快(3)");
 outtextxy(90,205,"获得下降(按s)加快能力(4)");
 FlushBatchDraw();
 if(GetKeyState(49)<0&&skill>0){
 hp++;//血量加一
 skill--;//技能点数减一
 break;
 }
 if(GetKeyState(50)<0&&skill>0){
 radius-=2;//半径减二
 skill--;//技能点数减一
 break;
 }
 if(GetKeyState(51)<0&&skill>0){
 speed++;//速度加二
 skill--;//技能点数减一
 break;
 }
 if(GetKeyState(52)<0&&skill>0){
 under=true;//开启下降能力
 skill--;//技能点数减一
 break;
 }
 }
}

int main(){//主函数
 int x=250,y=400,jumpspeed=0,id(0),tim(0),way(0),v=10,hphs(-1),shhs(-1),space(0),shopx(510),shopy(390);
 /*
 x,y为小球初始坐标
 jumpspeed为加速度
 id为障碍的记号
 tim控制障碍出现间隔时间
 way为障碍出现的种类
 v为小球初始设置弹跳力高度
 hphs为控制小球扣血的间隔时间(刷新间隔快,避免持续扣血)
 shhs为控制小球触碰商店的间隔时间(刷新间隔快,避免持续触发商店)
 space为障碍与障碍的间隔距离
 shopx,shopy为商店的初始坐标
 */
 int obstacle[50],obstaclex[50]={-999},obstacley[50]={-999};//设置障碍的变量数组
 bool jump=true,hph=true,ob=true,shh=true;
 /*
 jump判断小球是否可以跳跃
 hph判断小球是否可以扣血,与hphs联系
 ob判断是否出现障碍
 shh判断商店是否可以触发
 */
 char c[10];
 ifstream in;//读取历史最高分数
 in.open(".\\最高得分.txt");
 in>>highscore;
 in.close;
 initgraph(500,500);//作图
 BeginBatchDraw();//开始绘图
 while(1){
 Sleep(50);//每次刷新时间间隔
 if(ob==true)tim++;
 nowscore++;
 setfillcolor(WHITE);
 solidrectangle(0,0,500,500);
 setbkmode(TRANSPARENT);
 if(hphs==nowscore)hph=true;//间隔时间达到,则开始可触发扣血
 if(shhs==nowscore)shh=true;//间隔时间达到,则开始可触发商店
 if(nowscore<1000)space=60;
 if(nowscore==1000){//若分数大于1000,则停止障碍出现,开始出现商店并调整难度,技能点数加一
 ob=false;
 skill+=1;
 }
 if(nowscore==1300)ob=true;//难度增加
 if(nowscore>=1000&&nowscore<2500){
 space=50;
 if(nowscore<=1050){
 settextcolor(RED);
 settextstyle(50,0,"宋体");
 outtextxy(150,175,"加大难度");
 }//if
 if(nowscore>=1150){//第一次商店出现
 setfillcolor(CYAN);
 settextcolor(BLUE);
 settextstyle(20,0,"宋体");
 outtextxy(shopx-10,shopy-20,"商店");
 solidrectangle(shopx,shopy,shopx+20,shopy+20);
 shopx-=2;//商店移动
 }
 }//if
 if(nowscore==2500){//若分数大于2500,则停止障碍出现,开始出现商店并调整难度,技能点数加一
 ob=false;
 skill+=1;
 }
 if(nowscore==2650){//重新设置商店坐标
 shopx=490;
 shopy=390;
 }
 if(nowscore==2800)ob=true;//难度增加
 if(nowscore>=2500&&nowscore<4000){//难度增加
 space=42;
 if(nowscore<=2550){
 settextcolor(RED);
 settextstyle(50,0,"宋体");
 outtextxy(150,175,"加大难度");
 }//if
 if(nowscore>=2650){//第二次商店出现
 setfillcolor(CYAN);
 settextcolor(BLUE);
 settextstyle(20,0,"宋体");
 outtextxy(shopx-10,shopy-20,"商店");
 solidrectangle(shopx,shopy,shopx+20,shopy+20);
 shopx-=2;//商店移动
 }//if
 }
 if(nowscore==4000){//若分数大于4000,则停止障碍出现,开始出现商店并调整难度,技能点数加一
 ob=false;
 skill+=1;
 }
 if(nowscore==4150){//重新设置商店坐标
 shopx=490;
 shopy=390;
 }
 if(nowscore==4300)ob=true;
 if(nowscore>=4000){
 space=35;
 if(nowscore<=4050){
 settextcolor(RED);
 settextstyle(50,0,"宋体");
 outtextxy(150,175,"加大难度");
 }//if
 if(nowscore>=4150&&nowscore<=4400){//第三次商店出现
 setfillcolor(CYAN);
 settextcolor(BLUE);
 settextstyle(20,0,"宋体");
 outtextxy(shopx-10,shopy-20,"商店");
 solidrectangle(shopx,shopy,shopx+20,shopy+20);
 shopx-=2;//商店移动
 }//if
 }
 settextcolor(BLUE);
 settextstyle(15,0,"宋体");
 outtextxy(10,10,"当前分数:"); //分数显示
 itoa(nowscore,c,10);
 outtextxy(80,10,c);
 outtextxy(10,30,"最高分数:");
 itoa(highscore,c,10);
 outtextxy(80,30,c);
 if(GetKeyState(49)<0)v=10;//一档弹跳力高度
 if(GetKeyState(50)<0)v=15;//二挡弹跳力高度
 if(GetKeyState(51)<0)v=20;//三挡弹跳力高度
 if(GetKeyState(52)<0)v=25;//四档弹跳力高度
 if(y>=410-radius){//跳
 jump=true;
 jumpspeed=0;
 }
 if(y<410-radius){
 jump=false;
 jumpspeed+=1;
 }
 if(GetKeyState(87)<0&&jump==true){
 jump=false;
 jumpspeed=-v;
 }
 if(GetKeyState(65)<0&&x>0/*&&left==true*/)x-=speed;//左
 if(GetKeyState(68)<0&&x<500)x+=speed;//右
 if(GetKeyState(83)<0&&under==true&&y<=360)y+=4;
 if(y>410-radius)y=410-radius;//位置归位
 y+=jumpspeed;
 setfillcolor(CYAN);//小球描绘
 solidcircle(x,y+10-radius,radius);
 setfillcolor(RED);//血量描绘
 solidrectangle(x-7,y-10-radius,(x-7)+(hp*5),y-5-radius);
 setfillcolor(BLACK);//地面描绘
 solidrectangle(0,410,500,420);
 if(tim>space){//出现障碍(我根据id是奇数的障碍为上面的障碍,id是偶数的为下面的障碍)
 if(id>=49)id=0;//障碍记号循环
 srand((int)time(0));
 way=rand()%4;
 tim=0;//重置
 if(way==0){
 obstaclex[id]=490;//偶
 obstacley[id]=380;
 id++;
 obstaclex[id]=490;//奇
 obstacley[id]=320;
 id++;
 }//if
 if(way==1){
 obstaclex[id]=490;//偶
 obstacley[id]=315;
 id++;
 obstaclex[id]=490;//奇
 obstacley[id]=255;
 id++;
 }//if
 if(way==2){
 obstaclex[id]=490;//偶
 obstacley[id]=220;
 id++;
 obstaclex[id]=490;//奇
 obstacley[id]=160;
 id++;
 }//if
 if(way==3){
 obstaclex[id]=490;//偶
 obstacley[id]=110;
 id++;
 obstaclex[id]=490;//奇
 obstacley[id]=50;
 id++;
 }//if
 }//if
 for(int i(0);i<50;i++){
 obstaclex[i]-=2;//障碍移动
 if(i%2==0){//偶下
 solidrectangle(obstaclex[i],obstacley[i],obstaclex[i]+10,410);//障碍描绘
 if((x+radius)>obstaclex[i]&&(x-radius)<obstaclex[i]+10&&(y+radius)>obstacley[i]&&hph==true){//扣血机制
 hp--;
 hph=false;
 hphs=nowscore+20;
 }//if
 }//if
 if(i%2==1){//奇上
 solidrectangle(obstaclex[i],0,obstaclex[i]+10,obstacley[i]);//障碍描绘
 if((x+radius)>obstaclex[i]&&(x-radius)<obstaclex[i]+10&&(y-radius)<obstacley[i]&&hph==true){//扣血机制
 hp--;
 hph=false;
 hphs=nowscore+20;
 }//if
 }//if
 }//for
 if(hp<=0){//死亡判定
 death();
 return 0;
 }//if
 if((x+radius)>shopx&&(x-radius)<shopx+20&&(y+radius)>shopy&&shh==true&&skill>0){//商店触发机制
 shh=false;
 shhs=nowscore+20;
 shopshop();
 }
 FlushBatchDraw();//结束绘图
 }//while
}

感谢你的观看!!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 利用c++和easyx图形库做一个低配版扫雷游戏

    游戏界面 由于这个游戏是我抱着玩一玩的心态做出来的,所以没有过多的去设计界面,也没有去找游戏的资源(图片.游戏音效等).仅使用了不同颜色的方块来表示游戏中方块的状态和种类.(绿色为初始状态(未翻转的状态),黄色为翻转后的背景颜色,蓝色表示已插旗的方块,红色代表地雷) 图1 游戏主菜单界面 图二 模式一的游戏界面(20*20 40个雷) 图三 模式二的游戏界面(10*10 20个雷) 图四 游戏成功界面 图五 游戏失败界面 2.全部代码 #include<graphics.h> #include

  • C++实现扫雷经典小游戏

    用C++复现经典扫雷,供大家参考,具体内容如下 主要是dfs实现打开一片的操作,数字带有颜色,很真实. windows扫雷中鼠标左右键同时按也实现了,即试探. 先上图,详见下面代码: 代码中有详细注释,编译无任何错误警告. Ps.有bug请评论指出,谢谢啦~ 另外我觉得代码比较臃肿,有什么可以优化的也请提出~ #include<cstdio> #include<cstring> #include<algorithm> #include<conio.h> #i

  • C++实现一个扫雷小游戏

    本文实例为大家分享了C++实现扫雷小游戏的具体代码,供大家参考,具体内容如下 目前的版本是0.98版本,可以提出增加新功能意见哦 代码如下: #include<bits/stdc++.h> #include<windows.h> using namespace std; long long int c,dev,m,k,cnt,d,e,jie=10,z,abc,n,b[1000][1000],a[1000][1000],cc,cd,ce,def; //c是随机行,k是随机列 bool

  • C++基于EasyX实现简单扫雷游戏

    本文实例为大家分享了C++ EasyX实现简单扫雷游戏的具体代码,供大家参考,具体内容如下 [实现代码] #include <cmath> #include <time.h> #include <easyx.h> #include <conio.h> using namespace std; #define Size 500 //定义窗口大小 #define SquareSize 50 //定义格子大小 #define BackGroundColor LIG

  • C++实现简单扫雷游戏

    扫雷是一个经典的电脑小游戏,用C++来编一下,效果自己试一下 #include<stdio.h> #include<Windows.h> #define YELLOW FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_INTENSITY #define CYAN FOREGROUND_BLUE | FOREGROUND_GREEN | FOREGROUND_INTENSITY #define ORANGE FOREGROUND_RED |

  • C++扫雷游戏的简单制作

    本文实例为大家分享了C++实现扫雷游戏的具体代码,供大家参考,具体内容如下 #ifndef SAOLEI_H #define SAOLEI_H class Block { friend class Saoleigame; public: Block(); bool isShown(); void setnum(int); int getnum(); bool isbomb(); protected: int num; bool flag_show; int x; int y; }; class

  • C++实现简单的扫雷游戏(控制台版)

    C++新手的代码,请各位多包涵. 用C++写的一个简单的控制台版扫雷游戏.玩家通过输入方块的坐标来翻开方块. 只是一个雏形,能够让玩家执行翻开方块的操作并且判断输赢,还未添加标记方块.游戏菜单.记录游戏时间.重新开一局等等的功能. 玩家输入坐标的方式来翻开方块只适用于小型的"雷区",若"雷区"大了,用坐标会变得很不方便. 代码片段扫雷V1.1 #include<stdio.h> #include<Windows.h> #define YELL

  • C++实现扫雷小游戏(控制台版)

    本文为大家分享了C++实现扫雷小游戏的具体代码,供大家参考,具体内容如下 程序功能: 提供三种模式:初级.中级.高级 操作模式:wsad控制光标移动,空格键打开方块 提供扫雷地图的类 map.h #ifndef MAP_H_ #define MAP_H_ #define MAX_LENGTH 32 //可以提供的地图最大长度 #define MAX_WIDTH 18 //可以提供的地图最大宽度 #define UP_EDGE 1 //上边界 #define DOWN_EDGE _wid //下边

  • C++学习心得之扫雷游戏

    本文实例为大家分享了C++实现扫雷游戏的具体代码,供大家参考,具体内容如下 一.序言 创建一个9*9有10个雷的扫雷游戏 文章的顺序是按照我当时的编程顺序写的,顺便写下我当初的一点思路,总的代码在文章最后,前面的都是分散的函数,有需要的朋友直接复制最后的 二.创建 创建一个头文件,一个放游戏的程序,一个放运行测试的程序 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdlib.h>//生成随机数 #include<stdio.h> #inc

  • C++实现扫雷游戏(控制台不闪屏版)

    之前写了一个C++ 的控制台扫雷小游戏,但由于过度使用system("cls")刷屏,导致闪屏,因此重写了一个改善的不闪屏版本,并把逻辑重新捋了一遍. map.h #ifndef MAP_H_ #define MAP_H_ #define MAX_WID 18 #define MAX_LEN 32 #define UP_EDGE 1 //上边界 #define LEFT_EDGE 1 //左边界 #define RIGHT_EDGE _len //右边界 #define DOWN_ED

随机推荐