前言

本来是想打一个小游戏的……

可是打到一半思路断了……

只打出了模板……先把模板拿出来放着

Code

//head
#include <iostream>
#include <cstdio>
#include <cstring>
#include <windows.h>
#include <conio.h>
using namespace std;
//*head

//define
#define KEY_DOWN(VK_NONAME) ((GetAsyncKeyState(VK_NONAME) & 0x8000) ? 1:0)
#define Row_down KEY_DOWN(VK_MBUTTON)
#define Left_down KEY_DOWN(VK_LBUTTON)
#define fup(a,b) for(int i = (a); i < (b); i++)
#define sup(a,b) for(int j = (a); j < (b); j++)
//*define

//struct
struct player{
    int x;
    int y;
    int money;
}pl;
struct jump{
    int time;
    int hel;
    void helfresh()
    {

    }
}jup;
//*struct

//char
char map[16][31] = {
"                              ",
"                              ",
"  ...                    ...  ",
"           .......            ",
"                              ",
"   ...                  ...   ",
"                              ",
"       ..          ..         ",
" ...       ..   ..        ... ",
"           .     .            ",
"         ..  ...  ..          ",
"                              ",
"      ..................      ",
"                              ",
"                              "
};
char index[30][30];
//*char

//int
//*int

//bool
bool run_ch = true;
//*bool

//function
void gotoxy(int y, int x)
{
    COORD pos = {x,y};
    HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE);
    SetConsoleCursorPosition(hOut, pos);
}

void init()
{
    pl.x = 0;
    pl.y = 0;
    int i, j = 30;
    for(i = 0; i <= 15; i++)
    {
        gotoxy(i, j);
        cout<<"*";
    }
    i = 15;
    for(j = 0; j <= 30; j++)
    {
        gotoxy(i, j);
        cout<<"*";
    }
    for(i = 0; i < 15; i ++)
    {
        for(j = 0; j < 30; j++)
        {
            gotoxy(i, j);
            cout<<map[i][j];
        }
    }
}

void shop()
{

}

bool arv(int a, int b)
{
    if(map[a][b]=='*'||map[a][b]=='.'||map[a][b]=='|'||a<0||b<0||a>=15||b>=30)
        return false;
    return true;
}

char cnt_char;int cnt = 0;
void run_read(char ch)
{
    if(ch == 'a')
    {
        int nx = pl.x;
        int ny = pl.y - 1;
        if(!arv(nx, ny))
            return;

        gotoxy(pl.x, pl.y);
        cout<<" ";
        pl.x = nx;
        pl.y = ny;
        gotoxy(pl.x, pl.y);
        cout<<"A";
    }

    if(ch == 'd')
    {
        int nx = pl.x;
        int ny = pl.y + 1;
        if(!arv(nx, ny))
            return;

        gotoxy(pl.x, pl.y);
        cout<<" ";
        pl.x = nx;
        pl.y = ny;
        gotoxy(pl.x, pl.y);
        cout<<"A";
    }
    if(ch == 's')
    {
        int nx = pl.x + 1;
        int ny = pl.y;
        if(!arv(nx, ny))
            return;

        gotoxy(pl.x, pl.y);
        cout<<" ";
        pl.x = nx;
        pl.y = ny;
        gotoxy(pl.x, pl.y);
        cout<<"A";
    }
    if(ch == 'k')
    {
        if(jup.hel > 0 && map[pl.x + 1][pl.y] != '.' && pl.x != 14)
        {
            jup.hel--;
            goto next2;
        }
        if(map[pl.x + 1][pl.y] != '.' && pl.x != 14)
            return;

        next2:
        jup.time = 3;
        if(cnt_char == 'd')
            run_read('d');
        if(cnt_char == 'a')
            run_read('a');
    }
    if(ch == 'w')
    {
        int nx = pl.x - 1;
        int ny = pl.y;
        if(!arv(nx, ny))
            return;

        gotoxy(pl.x, pl.y);
        cout<<" ";
        pl.x = nx;
        pl.y = ny;
        gotoxy(pl.x, pl.y);
        cout<<"A";
    }
    if(ch == 'n')
    {
        jup.time = 0;
        cnt_char = ' ';
        cnt = 0;
    }
    if(ch == 'f')
    {
        shop();
    }
}

void run()
{
    char ch;
    while(run_ch)
    {
        if(map[pl.x + 1][pl.y] == '.' || pl.x == 14)
        {
            jup.hel = 0;
            jup.helfresh();
        }
        if(!kbhit())
        {
            cnt++;
            if(cnt > 3)
                cnt_char = ' ', cnt = 0, ch = ' ';
            goto run_next;
        }

        ch = getch();
        if(ch == 'w')
            goto run_next;
        run_read(ch);

        run_next:

        gotoxy(16,0);
        cout<<pl.x<<"  "<<pl.y<"   ";
        if(ch == 'k')
            ch = cnt_char;
        else
            cnt_char = ch;

        if(jup.time == 0)
        {
            run_read('s');
            run_read(cnt_char);
            Sleep(100);
        }
        else
        {
            run_read('w');
            run_read(cnt_char);
            jup.time--;
            Sleep(100);
        }
        Sleep(20);
    }
}
//*function

//main
int main()
{
    init();
    run();
    return 0;
}
//*main

效果图:

(图片有可能烂掉,因为我的图片放在博客园,我会尽快换到聚合图床)

后面我会将代码贴上注释,这样你萌就可以改了(其实自己也是看得懂的)。

不得不说我的效果做的垃圾的一批,可是我不会其他开发啊,不知道在哪学,只能自己慢慢找一些开发实例看一些代码。

[C++]Game模板-正面视角的更多相关文章

  1. 快速完成网页设计,10个顶尖响应式HTML5网页模板助你一臂之力

    为了寻找一个优质的网页模板,网页设计师和开发者往往可能会花上大半天的时间.不过幸运的是,现在的网页设计师和开发人员已经开始共享HTML5,Bootstrap和CSS3中的免费网页模板资源.鉴于网站模板 ...

  2. Unity入门教程(上)

    一.介绍 目的:通过尝试制作一款使用玩家角色把小球弹飞的简单小游戏,熟悉使用Unity进行游戏开发的基本流程. 软件环境:Unity 2017.3.0f3,Visual Studio 2013 二.创 ...

  3. ECCV 2018 | 旷视科技提出GridFace:通过学习局部单应变换实现人脸校正

    全球计算机视觉三大顶会之一 ECCV 2018(European Conference on Computer Vision)即将于 9 月 8 -14 日在德国慕尼黑拉开帷幕,旷视科技有多篇论文被此 ...

  4. HTML5 + CSS3 实现地球绕太阳公转

    使用的是正面视角,主要是用 HTML5 + CSS3 来实现,JS只是用来画图. test.html: <!DOCTYPE html> <html> <head> ...

  5. WPF Viewport3D 解决透视模式时窗体模糊

    最近折腾Viewport3D玩,遇到了一些诡异的问题,研究一下略有心得,特此和大家分享~ 三维图形概述: https://msdn.microsoft.com/zh-cn/library/ms7474 ...

  6. thinkphp5杂谈--项目架构和模板搭建(view视角)

    nginx网站配置 项目架构 项目文件夹 视图模板 一种出幺蛾子的访问办法 访问相关特色模块并渲染视图

  7. 6款程序员不得不爱的bootstrap模板

    Bootstrap是基于jQuery框架开发的,它在jQuery框架的基础上进行了更为个性化和人性化的完善,形成一套自己独有的网站风格,并兼容大 部分jQuery插件.Bootstrap中包含了丰富的 ...

  8. 50款免费 PSD 名片设计模板源文件下载《下篇》

    名片是陌生人之间建立联系的最便捷.最有效的工具.名片它可能是给你的客户留下正面的印象第一步,另一方面,名片是一个企业最重要和最符合成本效益的营销工具之一,尤其是对于刚刚起步的企业.这里收集了50款免费 ...

  9. 13. 星际争霸之php设计模式--正面模式

    题记==============================================================================本php设计模式专辑来源于博客(jymo ...

随机推荐

  1. Java堆的结构是什么样子的?什么是堆中的永久代(Perm Gen space)?

    JVM的堆是运行时数据区,所有类的实例和数组都是在堆上分配内存.它在JVM启动的时候被创建.对象所占的堆内存是由自动内存管理系统也就是垃圾收集器回收. 堆内存是由存活和死亡的对象组成的.存活的对象是应 ...

  2. NodeJS2-6环境&调试----debug

    13_debug.js //测试的脚本 function test1() { const a = parseInt(Math.random() * 10); const b = parseInt(Ma ...

  3. android开发针对小米、三星、华为8.0+系统个别型号打开应用闪退

    最近开发中有个别客户反馈新换的三星.小米或者华为手机打开应用就闪退,而且是个别型号.针对这种情况特别查阅了一些资料,原因是8.0+系统的手机不允许后台创建服务,那么怎么修改呢,请看代码: 1.修改启动 ...

  4. JS中原始值和引用值分析

    JS中变量中两种类型的值:原始值,引用值 原始值是存储在栈(stack)中的简单数据段,也就是说,它们的值直接存储在变量访问的位置. var x = 1; //1就是一个原始值,变量x中存放的就是原始 ...

  5. 防止 window.open 被拦截

    window.open('/app/dashbuilder.html?' + group.id, '_blank'); // 一般_self不会被拦截 // 改为 let newTab = windo ...

  6. 微信小程序视图层介绍及用法

    一. 视图层 WXML(WeiXin Markup Language)是框架设计的一套标签语言,结合基础组件.事件系统,可以构建出页面的结构. 1.1. 数据绑定 1.1.1. 普通写法 <vi ...

  7. Android 基于ksoap2的webservice请求的学习

    [学习阶段] WebService网络请求? 其实我也是第一次遇到,之所以有这个需要是因为一些与 ERP 相关的业务,需要用到这样的一个请求方式. 开始学习WebService ①当然是百度搜索,这里 ...

  8. Android 进度对话框 ProgressDialog

    protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentV ...

  9. MPV源码探究:源码结构和调用层次

    源码结构和调用层次 源码结构 从 Github 上拉取最新的源码,目录结构大致如下: H:\MPV ├─.github ├─audio │ ├─decode │ ├─filter │ └─out ├─ ...

  10. [洛谷P1967][题解]货车运输

    题目 这道题让我们求最小限重的最大值 显然可以先求出最大生成树,然后在树上进行操作 因为如果两点之间有多条路径的话一定会走最大的,而其他小的路径是不会被走的 然后考虑求最小权值 可以采用倍增求LCA, ...