C语言数组实现打砖块游戏

本文实例为大家分享了C语言数组实现打砖块游戏的具体代码,供大家参考,具体内容如下

这次我们使用数组来改进打砖块游戏。

反弹的球

首先我们实现一个可以在荧幕上反弹的小球。使用二维数组 int canvas[High][Width] ( 和js的canvas没有一毛钱关系)来储存画布上的所有元素,值为0时输出空格,值为1时输出小球。

设小球坐标为(ball_x, ball_y),则有canvas[ball_x][ball_y] = 1 ,且暂时将其他元素的值设为0。

每次更新小球位置时将原位置元素设为0,将新位置元素设为1即可。

注意:gotoxy函数用于清屏重画,很久以前讲过的。

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <cwindow.h>
// 画面尺寸设定
#define High 15
#define Width 20

//全局变量
int ball_x,ball_y;    //小球坐标
int ball_vx,ball_vy;//小球速度
int canvas[High][Width] = [0];

void gotoxy(int x, int y)    //移动光标便于清屏重画
{
    HANDLE handle = GetStdHandle(STD_UOTPUT_HANDLE);
    CROOD pos;
    pos.X = x;
    pos.Y = y;
    SetConsoleCursorPosition(handle, pos);
}

void startup()                //数据初始化
{
    ball_x = 0;
    ball_y = Width/2;
    ball_vx = 1;
    ball_vy = 1;
    canvas[ball_x][ball_y] = 1;
}

void show()
{
    gotoxy(0, 0);
    int i,j;
    for(i=0; i<High; i++)
    {
        for(j=0; j<Width; j++)
        {
            if (canvas[i][j] == 0)
                printf(" ");//输出空格
            else if (canvas[i][j] == 1)
                printf("O");//输出小球
        }
        printf("|\n");//每画完一行显示边界并换行
    }
    for(j=0; j<Width; j++)
        printf("-");//最后画下边界
}

void updateWithoutInput()    //无关输入的更新
{
    //小球移动
    canvas[ball_x][ball_y] = 0;
    ball_x = ball_x + ball_vx;
    ball_y = ball_y + ball_vy;
    //反弹判断
    if ((ball_x == 0)||(ball_x == High - 1))
        ball_vx = -ball_vx;
    if ((ball_y == 0)||(ball_y == Width - 1))
        ball_vy = -ball_vy;
            
    canvas[ball_x][ball_y] = 1;
    //休眠时间,避免刷新过快
    sleep(50);
}

void updateWithInput()
{}

int main()
{
    startup();
    while(1)
    {
        show();
        updateWithoutInput();
        updateWithInput();
    }
    return 0;
}

这里要注意的是:

  • updateWithInput留空,因为现在还没有用户操作的功能实现。
  • main是死循环,所以测试时要注意,当然也可以改进。

增加挡板

现在我们可以新定义,当数组中某一元素值为2时,输出挡板“ * ”。

并且为updateWithInput增加移动挡板的功能,每次移动一个单位作为其速度(当然可以改成别的数)。

挡板的刷新方式和小球一样,先将原位置清零然后把新位置元素改为2。

需要增加的内容如下:

//全局变量
int position_x,position_y; //挡板中心坐标
int ridus;    //挡板半径,就是延伸的长度
int left,right;    //挡板左右位置

//初始化
ridus = 5;
position_x = High - 1;
position_y = Width/2;
left = position_y - ridus;
right = position_x + ridus;

int k;
for(k=left; k<=right; k++)
    canvas[position_x][k] = 2;

//输出部分
...
else if (canvas[i][j] == 2)
    printf("*");
...

//更新部分(与输入无关)
if (ball_x == High - 2)
{
    //判断是否挡住
    if ((ball_y >= left)&&(ball_y <= right))
    {
        printf("\a");
    }
    else    //未挡住
    {
        printf("游戏失败\n");
        printf("pause");
        exit(0);
    }
}

//与输入有关的更新
void updateWithInput()
{
    char input;
    if (kbhit())    //判断是否有输入
        input = getch();
    if ((input == 'a')&&(left > 0))//左移
    {
        canvas[position_x][right] = 0;
        position_y --;
        left = position_y - ridus;
        right = position_x + ridus;
        canvas[position_x][left] = 2;
    }
    if ((input == 'd')&&(right < Width -1))//右移
    {
        canvas[position_x][left] = 0;
        position_y ++;
        left = position_y - ridus;
        right = position_x + ridus;
        canvas[position_x][right] = 2;    
    }
}

打砖块

这部分内容就和之前的内容一样了。

需要增加的内容有:

1. 初始砖块
2. 小球碰到砖块的判定
3. 碰到砖块后的更新(砖块消失、小球反弹)

具体代码如下:

//初始化
int k,i;

for(k=0; k<Width; k++)
    for(i=0; i<high/4; i++)    //这里是画砖块,可以根据修改 i 的范围改变砖块的排数
        canvas[i][k] = 3;
//输出
...
else if (canvas[i][j] == 3)
    printf("#");
...
//碰到砖块后
if (canvas[ball_x + ball_vx][ball_y + ball_vy] == 3)
{
    canvas[ball_x + ball_vx][ball_y + ball_vy] = 0;
    ball_vx = -ball_vx;
    ball_vy = -ball_vy;
    printf("\a");
}

最后

1. 坐标系是x轴向下,y 轴向右。
2. 实际对碰撞的判定是在斜方向上,当然可以改进判定内容。
3. 游戏胜利条件还没有完善。

全代码:

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <cwindow.h>
// 画面尺寸设定
#define High 15
#define Width 20

//全局变量
int ball_x,ball_y;    //小球坐标
int ball_vx,ball_vy;//小球速度
int canvas[High][Width] = [0];
int position_x,position_y; //挡板中心坐标
int ridus;    //挡板半径,就是延伸的长度
int left,right;    //挡板左右位置

void gotoxy(int x, int y)    //移动光标便于清屏重画
{
    HANDLE handle = GetStdHandle(STD_UOTPUT_HANDLE);
    CROOD pos;
    pos.X = x;
    pos.Y = y;
    SetConsoleCursorPosition(handle, pos);
}

void startup()                //数据初始化
{
    ball_x = 0;
    ball_y = Width/2;
    ball_vx = 1;
    ball_vy = 1;
    canvas[ball_x][ball_y] = 1;

    ridus = 5;
    position_x = High - 1;
    position_y = Width/2;
    left = position_y - ridus;
    right = position_x + ridus;

    int k,i;
    for(k=left; k<=right; k++)
    canvas[position_x][k] = 2;

    for(k=0; k<Width; k++)
        for(i=0; i<high/4; i++)    //这里是画砖块,可以根据修改 i 的范围改变砖块的排数
            canvas[i][k] = 3;
}

void show()
{
    gotoxy(0, 0);
    int i,j;
    for(i=0; i<High; i++)
    {
        for(j=0; j<Width; j++)
        {
            if (canvas[i][j] == 0)
                printf(" ");//输出空格
            else if (canvas[i][j] == 1)
                printf("O");//输出小球
            else if (canvas[i][j] == 2)
                printf("*");
            else if (canvas[i][j] == 3)
                printf("#");
        }
        printf("|\n");//每画完一行显示边界并换行
    }
    for(j=0; j<Width; j++)
        printf("-");//最后画下边界
}

void updateWithoutInput()    //无关输入的更新
{
    if (canvas[ball_x + ball_vx][ball_y + ball_vy] == 3)
    {
        canvas[ball_x + ball_vx][ball_y + ball_vy] = 0;
        ball_vx = -ball_vx;
        ball_vy = -ball_vy;
        printf("\a");
    }
    if (ball_x == High - 2)
    {
        //判断是否挡住
        if ((ball_y >= left)&&(ball_y <= right))
        {
            printf("\a");
        }
        else    //未挡住
        {
            printf("游戏失败\n");
            printf("pause");
            exit(0);
        }
    }
    //小球移动
    canvas[ball_x][ball_y] = 0;
    ball_x = ball_x + ball_vx;
    ball_y = ball_y + ball_vy;
    //反弹判断
    if ((ball_x == 0)||(ball_x == High - 1))
        ball_vx = -ball_vx;
    if ((ball_y == 0)||(ball_y == Width - 1))
        ball_vy = -ball_vy;
            
    canvas[ball_x][ball_y] = 1;
    //休眠时间,避免刷新过快
    sleep(50);
}

void updateWithInput()
{
    char input;
    if (kbhit())    //判断是否有输入
        input = getch();
    if ((input == 'a')&&(left > 0))//左移
    {
        canvas[position_x][right] = 0;
        position_y --;
        left = position_y - ridus;
        right = position_x + ridus;
        canvas[position_x][left] = 2;
    }
    if ((input == 'd')&&(right < Width -1))//右移
    {
        canvas[position_x][left] = 0;
        position_y ++;
        left = position_y - ridus;
        right = position_x + ridus;
        canvas[position_x][right] = 2;    
    }
}

int main()
{
    startup();
    while(1)
    {
        show();
        updateWithoutInput();
        updateWithInput();
    }
    return 0;
}

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

(0)

相关推荐

  • C语言实现弹跳小球项目

    目录 一.项目描述和最终项目展示 二.输出一个小球 三.下落的小球 四.来回弹跳的小球 五.最终项目实现 本文实例为大家分享了C语言实现弹跳小球项的具体代码,供大家参考,具体内容如下 一.项目描述和最终项目展示 项目描述:   使小球来回的跳动,跳动的路径是一个 "V "字型 效果展示图: 接下来让我们一步步的来实现上图效果. 二.输出一个小球 一开始就达到最终的目的是有点难度的,所以我们一步步的来先输出一个静态的小球 代码如下: #include<stdio.h> //静

  • C语言实现简单反弹球消砖块游戏

    反弹球消砖块,是一款很简单的打砖块游戏,控制你的挡板挡住弹球,打掉上面的砖块,本篇博客中,主要使用printf与scanf函数实现消砖块游戏 整体思路 主函数 int main() {     startup();//初始化     while (1)     {         show();//显示画面           updateWitoutIput();//与用户输入无关的更新  //更新数据         updateWithInput(); //与用户输入有关的更新  //输入

  • C语言用函数实现反弹球消砖块

    本文实例为大家分享了C语言用函数实现反弹球消砖块的具体代码,供大家参考,具体内容如下 一.项目描述和最终的成果展示 这是在上一次弹跳小项目上进行了一系列的优化和封装.项目: 弹跳的小球上次没有用函数进行的封装.这次在上次的基础上进行封装和一些功能的优化. 最终效果图如下: 二.封装后的弹跳小球 代码如下: #include<stdio.h> #include<string.h> #include<conio.h> #include<windows.h> //

  • C语言实现简单弹跳小球

    本文实例为大家分享了C语言实现简单弹跳小球的具体代码,供大家参考,具体内容如下 本节利用 printf 函数 实现一个在屏幕上弹跳的小球,内容简单容易入门,这也是以后我们在设计更多游戏中可能用到的东西. 绘制静止的小球 我们将以如图坐标系进行游戏,即以窗口左上角为原点. 我们希望在坐标(x , y)处显示静止的小球: #include <stdio.h> int main(){     int i,j; // 这两个量是循环中要使用的,一定先声明     int x = 5;     int

  • c语言小游戏程序之弹跳小球的实现代码

    现在说一下其中一个最简单的小程序:弹跳小球 ---------------LINE---------------- 首先我们知道,在窗口的坐标系原点是在窗口左上角的,如图所示 然后我们如果想在这个坐标系里面的某个点上画出一个小球,那么它的坐标系应该就是这样的 转换到c语言的思维的话:X0既是打印出X0个"\n",Y0既是打印出Y0个空格!!!! SO 代码如下 #include <stdio.h> #include <stdlib.h> int main() {

  • C语言实现打砖块小游戏

    本文实例为大家分享了C语言实现打砖块游戏的具体代码,供大家参考,具体内容如下 本节我们将沿用 上一节 所提到的函数式游戏框架来写一个弹球打砖块的游戏. 基本量.边框绘制 我们首先定义好可能需要的变量,比如小球坐标以及速度.游戏界面高度和宽度等等,然后再根据之前提到的弹跳小球重构代码,剩下的内容再分步添置即可. #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <cwindow.h&

  • C语言实现反弹球消砖块游戏

    本文实例为大家分享了C语言实现反弹球消砖块游戏的具体代码,供大家参考,具体内容如下 1.目标要求: 1.击中上方方块’H’,分数加12.下方控制线没有接到小球时,游戏结束 2.C语言代码: #include<stdio.h> #include<stdlib.h> #include<windows.h> #include<conio.h> /*         <反弹球消砖块>    by:你最珍贵                       --

  • C语言控制台打砖块小游戏

    本文为大家分享了C语言控制台小游戏,打砖块,供大家参考,具体内容如下 这个问题是我在领扣上面看到的一道困难问题,原题是这样的: #include "stdafx.h" #include<stdio.h> int a[10][10] = { { 0, 0, 1, 0, 0, 0, 0, 0, 1, 0 },                    { 0, 0, 1, 1, 1, 1, 0, 1, 1, 0 },                   { 0, 0, 0, 0,

  • C语言基于EasyX库实现有颜色弹跳小球

    本文实例为大家分享了基于EasyX库实现有颜色弹跳小球的具体代码,供大家参考,具体内容如下 1.目标要求 1.实现一个有颜色小球在窗口中弹跳2.遇到边界弹跳 2.C语言代码 #include<graphics.h>  #include<stdio.h> #include<stdlib.h> #include<windows.h> #include<conio.h> #define High 480 #define Width 640//画布尺寸

  • C语言数组实现打砖块游戏

    本文实例为大家分享了C语言数组实现打砖块游戏的具体代码,供大家参考,具体内容如下 这次我们使用数组来改进打砖块游戏. 反弹的球 首先我们实现一个可以在荧幕上反弹的小球.使用二维数组 int canvas[High][Width] ( 和js的canvas没有一毛钱关系)来储存画布上的所有元素,值为0时输出空格,值为1时输出小球. 设小球坐标为(ball_x, ball_y),则有canvas[ball_x][ball_y] = 1 ,且暂时将其他元素的值设为0. 每次更新小球位置时将原位置元素设

  • GO语言数组和切片实例详解

    本文实例讲述了GO语言数组和切片的用法.分享给大家供大家参考.具体分析如下: 一.数组 与其他大多数语言类似,Go语言的数组也是一个元素类型相同的定长的序列. (1)数组的创建. 数组有3种创建方式:[length]Type .[N]Type{value1, value2, ... , valueN}.[...]Type{value1, value2, ... , valueN} 如下: 复制代码 代码如下: func test5() {     var iarray1 [5]int32    

  • C语言 数组指针详解及示例代码

    数组(Array)是一系列具有相同类型的数据的集合,每一份数据叫做一个数组元素(Element).数组中的所有元素在内存中是连续排列的,整个数组占用的是一块内存.以int arr[] = { 99, 15, 100, 888, 252 };为例,该数组在内存中的分布如下图所示: 定义数组时,要给出数组名和数组长度,数组名可以认为是一个指针,它指向数组的第 0 个元素.在C语言中,我们将第 0 个元素的地址称为数组的首地址.以上面的数组为例,下图是 arr 的指向: 下面的例子演示了如何以指针的方

  • C语言数组入门之数组的声明与二维数组的模拟

    语言中指针与数组这两个概念之间的联系是密不可分的,以至于如果不能理解一个概念,就无法彻底理解另一个概念. C语言中的数组值得注意的地方有以下两点: C语言中只有一维数组,而且数组的大小必须在编译期就作为一个常数确定下来.然而,C语言中数组的元素可以是任何类型的对象,当然也可以是另外一个数组.这样,要"仿真"出一个多维数组就不是一件难事. 对于一个数组,我们只能够做两件事:确定该数组的大小,以及获得指向该数组下标为0的元素的指针.其他有关数组的操作,哪怕它们看上去是以数组下标进行运算的,

  • 深入理解c语言数组

    一 数组名是什么 数组就是一段连续可用的内存.比如声明一个 int数组 int array[]={1,2,3}; array代表什么?有的资料说:数组名是指向数组首地址的常量指针. 下面我们可以验证一下.我都知道sizeof操作符可以返回一个对象或者类型所占的内存字节数.如:int i=1:那么sizeof(i) 的结果就是4(64位机器下的部分编译器是8) 那我们打印sizeof(array) printf("%d\n",sizeof(array)); 结果是:12. 但是我们都知道

  • C语言 数组中重复的数字分析及方法

    C语言 数组中重复的数字解决方法: 题目:在一个长度为n的数组里的所有数字都在0-n-1的 范围内.数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复了几次.请找出数组中任意一个重复的数字.例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是重复的数字2或者3. 解法1:对于数组进行排序,之后对于已经排序的数组进行遍历便可知道数组中重复的数字. 时间复杂度;O(nlogn); 解法2:建立一个大小为O(N)的哈希表,遍历数组中的元素并判断是否存在于哈

  • C语言数组元素的循环移位方法

    如下所示: /*C语言数组元素的循环移位*/ #include <stdio.h> int main() { int num[5],num1[5]; int i, j,k=1; int t,n; printf("请输入5个数:"); for(i=0;i<5;i++) { scanf("%d",&num[i]); //将数读入数组num } printf("请输入循环次数:"); scanf("%d",

  • C语言数组栈实现模板

    本文实例为大家分享了C语言数组栈实现模板的具体代码,供大家参考,具体内容如下 SeqStack.h #pragma once #define MAX_SIZE 1024 typedef struct SEQSTACK { void* data[MAX_SIZE]; int size; }SeqStack; SeqStack* Init_SeqStack(); // 初始化栈 void Push_SeqStack(SeqStack* stack, void* data); // 入栈 void*

  • 解决C语言数组元素循环右移的问题

    如下所示: #include<stdio.h> #define N 100 int main() { int a[N]; int i,j,k,n,m,temp=0; scanf("%d %d",&n,&m); i=0; while(i<n) { scanf("%d",&a[i]); i++; } for(j=0;j<m;j++) //移动次数 { temp=a[n-1]; //保存最后一位数 for(k=n-1;k&g

  • 详解C语言数组中是以列优先吗

    如果我们按照C语言的方式存储它,也就是行优先存储的话,那么在内存中,它的形状是这样的: 这种存储方式又被称作C contiguous array. C语言数组结构列优先顺序存储的实现 (GCC编译). 从行优先转换为列优先存储方式,与行优先相比,不同之处在于改变了数组维界基址的先后顺序, 从而改变了映像函数常量基址. /** * @brief C语言 数组 列优先 实现 * @author wid * @date 2013-11-02 * * @note 若代码存在 bug 或程序缺陷, 请留言

随机推荐