欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

老程序員教你一天時間完成C++俄羅斯方塊游戲

 更新時間:2021年08月13日 08:56:18   作者:Linux猿  
俄羅斯方塊游戲大家應該非常熟悉,非常經典的一款游戲,本文來詳細講解下俄羅斯方塊游戲的制作過程,趕緊來看下吧!希望能給你帶來幫助

首先,看下效果圖:

圖1 游戲運行過程

下面詳細講解下制作過程。

一、主要文件

文件包含三個:tetris.cpp、tetris.h、main.cpp,各個文件的用途如下:

tetris.cpp 文件:函數實現;

tetris.h : 類和函數聲明;

main.cpp : 主函數;

二、界面設計

bool vis[100][100]; // 用于標記坐標
int Co[100][100]; // 坐標的顏色

其中:

vis[100][100] 用于標記界面坐標,true表示有內容,false 表示空;

Co[100][100] 用于標記界面坐標的顏色;

設置框架函數,如下所示:

//設置框架
void setFrame()
{
   color(5);
   getCoord(30 ,1);
   cout<<"    < 俄羅斯方塊游戲 >"<<endl<<endl;
   color(10);

   // 主要框架
   int x = LF_up_x ,y = 3; 
   //橫向邊上下兩條邊
   for(int i = 0; i < 30; ++i) {
       getCoord(x ,2);  vis[x][2] = true;  cout<<"□";
       getCoord(x ,23); vis[x][23] = true; cout<<"□";
       x += 2;
   }

   //豎向兩條邊和小框左邊豎線
   for(int i = 0; i < 21; ++i) {
       getCoord(LF_up_x ,y) ; vis[LF_up_x][y] = true ; cout<<"□" ;
       getCoord(71 ,y) ;      vis[71][y] = true ; cout<<"□" ;
       getCoord(51 ,y) ;      vis[51][y] = true ; cout<<"□" ;
       y += 1 ;
   }

   //小框架中間橫線
   for(int i = 53 ;i <= 69 ; i += 2) {
       getCoord(i ,11);
       vis[i][11] = true;
       cout<<"□";
   }

   //小框內容
   color(10);
   getCoord(53 ,3);  cout<<" Next Block : " ;
   color(11) ;
   getCoord(54 ,13) ; cout<<"開始 :  Enter 鍵" ;
   getCoord(54 ,15) ; cout<<"暫停 :  T 鍵" ;
   getCoord(54 ,17) ; cout<<"退出 :  Q 鍵" ;
   getCoord(54 ,19) ;  cout<<"Score:" ;
   getCoord(54 ,21) ; cout<<"Rank :" ;
   T_Box::staticNum(0) ;
}

設置整體的界面,如下圖所示:

圖2 界面圖

三、方塊設計

表示方塊的類,如下所示:

class T_Box
{
    static int Score ;
    static int Rank ;
    private :
             int x ,y ; // 坐標
             int type ; // 類型
             int fg ; // 某個圖形的第 fg 個變化的圖形
    public :
             T_Box(int sx = 31 ,int sy = 3 ,int st = 0 ,int f = 0);
             static void staticNum(int num);
             void setValue(int sx = 31 ,int sy = 3 ,int st = 0 ,int f = 0) ;
             void Move(int stepA ,int stepB);
             bool Stop();
             void printBox();
             void eraseBox();
             void Mark();
             void Pause();
             void nextBox(T_Box temp);
             void Transform();
             bool Judge();
};

各種方塊的設計函數如下所示:

class Coord
{
    public :
            int x;
            int y;
            int Col;
}G[10][10][10];

其中:

x,y 是相對坐標;

Col 是方塊顏色;

G[10][10][10] :一維表示方塊類型,二維表示方塊內的方格,三維表示方塊的第幾種表示形式;

來看下各個方塊的設計,如下所示:

// 設置各種圖形
void setBox()
{
    // 1 正方形
    for(int i = 0 ;i < 4 ; ++i)
    {
       G[0][0][i].x = 0 ;  G[0][0][i].y = 0 ;  G[0][0][i].Col = 14 ;
       G[0][1][i].x = 0 ;  G[0][1][i].y = 1 ;  G[0][1][i].Col = 14 ;
       G[0][2][i].x = 2 ;  G[0][2][i].y = 0 ;  G[0][2][i].Col = 14 ;
       G[0][3][i].x = 2 ;  G[0][3][i].y = 1 ;  G[0][3][i].Col = 14 ;
    }

    // 2  豎條
    G[1][0][0].x = 0 ; G[1][0][0].y = 0 ; G[1][0][0].Col = 3 ;
    G[1][1][0].x = 0 ; G[1][1][0].y = 1 ; G[1][1][0].Col = 3 ;
    G[1][2][0].x = 0 ; G[1][2][0].y = 2 ; G[1][2][0].Col = 3 ;
    G[1][3][0].x = 0 ; G[1][3][0].y = 3 ; G[1][3][0].Col = 3 ;

    G[1][0][1].x = 0 ; G[1][0][1].y = 0 ; G[1][0][1].Col = 3 ;
    G[1][1][1].x = 2 ; G[1][1][1].y = 0 ; G[1][1][1].Col = 3 ;
    G[1][2][1].x = 4 ; G[1][2][1].y = 0 ; G[1][2][1].Col = 3 ;
    G[1][3][1].x = 6 ; G[1][3][1].y = 0 ; G[1][3][1].Col = 3 ;

    G[1][0][2].x = 0 ; G[1][0][2].y = 0 ; G[1][0][2].Col = 3 ;
    G[1][1][2].x = 0 ; G[1][1][2].y = 1 ; G[1][1][2].Col = 3 ;
    G[1][2][2].x = 0 ; G[1][2][2].y = 2 ; G[1][2][2].Col = 3 ;
    G[1][3][2].x = 0 ; G[1][3][2].y = 3 ; G[1][3][2].Col = 3 ;

    G[1][0][3].x = 0 ; G[1][0][3].y = 0 ; G[1][0][3].Col = 3 ;
    G[1][1][3].x = 2 ; G[1][1][3].y = 0 ; G[1][1][3].Col = 3 ;
    G[1][2][3].x = 4 ; G[1][2][3].y = 0 ; G[1][2][3].Col = 3 ;
    G[1][3][3].x = 6 ; G[1][3][3].y = 0 ; G[1][3][3].Col = 3 ;

    // 3
    G[2][0][0].x = 0 ; G[2][0][0].y = 0 ; G[2][0][0].Col = 4 ;
    G[2][1][0].x = 0 ; G[2][1][0].y = 1 ; G[2][1][0].Col = 4 ;
    G[2][2][0].x = 2 ; G[2][2][0].y = 1 ; G[2][2][0].Col = 4 ;
    G[2][3][0].x = 2 ; G[2][3][0].y = 2 ; G[2][3][0].Col = 4 ;
    G[2][0][1].x = 0 ; G[2][0][1].y = 0 ; G[2][0][1].Col = 4 ;
    G[2][1][1].x = 2 ; G[2][1][1].y = 0 ; G[2][1][1].Col = 4 ;
    G[2][2][1].x = 0 ; G[2][2][1].y = 1 ; G[2][2][1].Col = 4 ;
    G[2][3][1].x = -2 ; G[2][3][1].y = 1 ; G[2][3][1].Col = 4 ;
    G[2][0][2].x = 0 ; G[2][0][2].y = 0 ; G[2][0][2].Col = 4 ;
    G[2][1][2].x = 0 ; G[2][1][2].y = 1 ; G[2][1][2].Col = 4 ;
    G[2][2][2].x = 2 ; G[2][2][2].y = 1 ; G[2][2][2].Col = 4 ;
    G[2][3][2].x = 2 ; G[2][3][2].y = 2 ; G[2][3][2].Col = 4 ;
    G[2][0][3].x = 0 ; G[2][0][3].y = 0 ; G[2][0][3].Col = 4 ;
    G[2][1][3].x = 2 ; G[2][1][3].y = 0 ; G[2][1][3].Col = 4 ;
    G[2][2][3].x = 0 ; G[2][2][3].y = 1 ; G[2][2][3].Col = 4 ;
    G[2][3][3].x = -2 ; G[2][3][3].y = 1 ; G[2][3][3].Col = 4 ;
    // 4
    G[3][0][0].x = 0 ; G[3][0][0].y = 0 ; G[3][0][0].Col = 5 ;
    G[3][1][0].x = 0 ; G[3][1][0].y = 1 ; G[3][1][0].Col = 5 ;
    G[3][2][0].x = -2 ; G[3][2][0].y = 1 ; G[3][2][0].Col = 5 ;
    G[3][3][0].x = 2 ; G[3][3][0].y = 1 ; G[3][3][0].Col = 5 ;
    G[3][0][1].x = 0 ; G[3][0][1].y = 0 ; G[3][0][1].Col = 5 ;
    G[3][1][1].x = 0 ; G[3][1][1].y = 1 ; G[3][1][1].Col = 5 ;
    G[3][2][1].x = 2 ; G[3][2][1].y = 1 ; G[3][2][1].Col = 5 ;
    G[3][3][1].x = 0 ; G[3][3][1].y = 2 ; G[3][3][1].Col = 5 ;
    G[3][0][2].x = 0 ; G[3][0][2].y = 0 ; G[3][0][2].Col = 5 ;
    G[3][1][2].x = 2 ; G[3][1][2].y = 0 ; G[3][1][2].Col = 5 ;
    G[3][2][2].x = 2 ; G[3][2][2].y = 1 ; G[3][2][2].Col = 5 ;
    G[3][3][2].x = 4 ; G[3][3][2].y = 0 ; G[3][3][2].Col = 5 ;
    G[3][0][3].x = 0 ; G[3][0][3].y = 0 ; G[3][0][3].Col = 5 ;
    G[3][1][3].x = 0 ; G[3][1][3].y = 1 ; G[3][1][3].Col = 5 ;
    G[3][2][3].x = -2 ; G[3][2][3].y = 1 ; G[3][2][3].Col = 5 ;
    G[3][3][3].x = 0 ; G[3][3][3].y = 2 ; G[3][3][3].Col = 5 ;

    // 5
    G[4][0][0].x = 0 ; G[4][0][0].y = 0 ; G[4][0][0].Col = 6 ;
    G[4][1][0].x = 0 ; G[4][1][0].y = 1 ; G[4][1][0].Col = 6 ;
    G[4][2][0].x = 0 ; G[4][2][0].y = 2 ; G[4][2][0].Col = 6 ;
    G[4][3][0].x = 2 ; G[4][3][0].y = 2 ; G[4][3][0].Col = 6 ;
    G[4][0][1].x = 0 ; G[4][0][1].y = 0; G[4][0][1].Col = 6 ;
    G[4][1][1].x = 0 ; G[4][1][1].y = 1 ; G[4][1][1].Col = 6 ;
    G[4][2][1].x = 2 ; G[4][2][1].y = 0 ; G[4][2][1].Col = 6 ;
    G[4][3][1].x = 4 ; G[4][3][1].y = 0 ; G[4][3][1].Col = 6 ;
    G[4][0][2].x = 0 ; G[4][0][2].y = 0 ; G[4][0][2].Col = 6 ;
    G[4][1][2].x = 2 ; G[4][1][2].y = 0 ; G[4][1][2].Col = 6 ;
    G[4][2][2].x = 2 ; G[4][2][2].y = 1 ; G[4][2][2].Col = 6 ;
    G[4][3][2].x = 2 ; G[4][3][2].y = 2 ; G[4][3][2].Col = 6 ;
    G[4][0][3].x = 0 ; G[4][0][3].y = 0; G[4][0][3].Col = 6 ;
    G[4][1][3].x = 0 ; G[4][1][3].y = 1 ; G[4][1][3].Col = 6 ;
    G[4][2][3].x = -2 ; G[4][2][3].y = 1 ; G[4][2][3].Col = 6 ;
    G[4][3][3].x = -4 ; G[4][3][3].y = 1 ; G[4][3][3].Col = 6 ;

    // 6
    G[5][0][0].x = 0 ; G[5][0][0].y = 0 ; G[5][0][0].Col = 9 ;
    G[5][1][0].x = 0 ; G[5][1][0].y = 1 ; G[5][1][0].Col = 9 ;
    G[5][2][0].x = 0 ; G[5][2][0].y = 2 ; G[5][2][0].Col = 9 ;
    G[5][3][0].x = -2 ; G[5][3][0].y = 2 ; G[5][3][0].Col = 9 ;
    G[5][0][1].x = 0 ; G[5][0][1].y = 0 ; G[5][0][1].Col = 9 ;
    G[5][1][1].x = 0 ; G[5][1][1].y = 1 ; G[5][1][1].Col = 9 ;
    G[5][2][1].x = 2 ; G[5][2][1].y = 1 ; G[5][2][1].Col = 9 ;
    G[5][3][1].x = 4 ; G[5][3][1].y = 1 ; G[5][3][1].Col = 9 ;
    G[5][0][2].x = 0 ; G[5][0][2].y = 0 ; G[5][0][2].Col = 9 ;
    G[5][1][2].x = 2 ; G[5][1][2].y = 0 ; G[5][1][2].Col = 9 ;
    G[5][2][2].x = 0 ; G[5][2][2].y = 1 ; G[5][2][2].Col = 9 ;
    G[5][3][2].x = 0 ; G[5][3][2].y = 2 ; G[5][3][2].Col = 9 ;
    G[5][0][3].x = 0 ; G[5][0][3].y = 0 ; G[5][0][3].Col = 9 ;
    G[5][1][3].x = 2 ; G[5][1][3].y = 0 ; G[5][1][3].Col = 9 ;
    G[5][2][3].x = 4 ; G[5][2][3].y = 0 ; G[5][2][3].Col = 9 ;
    G[5][3][3].x = 4 ; G[5][3][3].y = 1 ; G[5][3][3].Col = 9 ;
}

上面設置的是各個方塊的相對坐標以及方塊的顏色。

四、設計思路

先來看下方塊的主要類,如下所示:

class T_Box
{
    static int Score ;
    static int Rank ;
    private :
             int x ,y ; // 坐標
             int type ; // 類型
             int fg ; // 某個圖形的第 fg 個變化的圖形
    public :
             T_Box(int sx = 31 ,int sy = 3 ,int st = 0 ,int f = 0) ;
             static void staticNum(int num) ;
             void setValue(int sx = 31 ,int sy = 3 ,int st = 0 ,int f = 0) ;
             void Move(int stepA ,int stepB) ;
             bool Stop() ;
             void printBox() ;
             void eraseBox() ;
             void Mark() ;
             void Pause() ;
             void nextBox(T_Box temp) ;
             void Transform() ;
             bool Judge() ;
};

其中:

Score : 表示游戲分數;

Rank : 表示游戲等級,等級是根據分數計算的;

各個函數的用途如下:

T_Box :構造函數,初始化坐標類型;

staticNum : 更新分數和等級,顯示在右下側小框內;

setValue : 設置方塊的初始坐標、類型以及第幾種變化,其中類型和變化是隨機值;

Move : 將下落的方塊向左、右、下移動;

Stop : 計算游戲是否已結束;

printBox : 輸出方塊圖形到界面;

eraseBox : 擦除界面上的方塊;

Mark : 標記當前位置已有內容了;

Pause : 游戲暫停,等待開始;

nextBox : 在右上側方格內顯示下一個將要降落的方格;

Transform :在方格下落過程中變換方格樣式;

Judge : 判斷方格是否可以變換樣式;

接下來就說下主程序的設計邏輯,代碼如下所示:

// 主程序
void Tetris()
{
   srand(time(0)); // 取系統(tǒng)時間
   setBox();    // 設置各種圖形
   T_Box  cd ,tempA ,tempB;   // 每個下降的方塊的初始值
   tempB.setValue(); // 設置方塊初始值
   tempB.nextBox(tempA);
   for(int i = 0;   ; ++i)
   {
       if(!(i%2))   tempA.setValue();
       else         tempB.setValue();
       if(i%2)      tempB.nextBox(tempA) ,cd = tempA;
       else         tempA.nextBox(tempB) ,cd = tempB;
       while(1) {
          cd.printBox(); // 輸出圖形
          if(cd.Stop())
          {
              color(6);
              getCoord(20 ,10);
              cout<<"   T_T    游戲結束    T_T";
              Exit();
          }
          Sleep(350);
          cd.eraseBox(); //擦除圖形
          cd.Move(0 ,1);
          if(kbhit()) // 判斷是否有按鍵按下,如果有則可能是旋轉或者加速按鍵
          {
            char ch = getch();
            switch(ch)
            {
                case 'a' :   cd.Move(-2 ,0) ; break;    //  向左移動一格
                case 'd' :   cd.Move(2 ,0) ;  break;    //  向右移動一格
                case 'w' :   cd.Transform() ; break;                   //  變換方格
                case 's' :   cd.Move(0 ,2) ; break;  //  急降方格
                case 'T' :   cd.Pause() ; break;
                case 'Q' :   Exit();  break;
                default :    break; // 如果都不是則不執(zhí)行
             }
          }
          if(cd.Stop())  break;
       }
       cd.printBox();
       cd.Mark();
       Check(); // 檢查是否可以消除
    }
}

設計思路如下:

1. 首先,設置各種圖形以及界面圖形;

2. 產生當前方格和下一個方格,下一個方格顯示到右上側方框內;

3. 輸出當前下落方格到界面;

4. 判斷游戲是否結束;

5. 向下移動方格;

6. 監(jiān)聽用戶輸入,執(zhí)行用戶輸入的操作,包括:移動、急降方格、變換方格樣式、退出、暫停等。

7. 檢測方格是否降落到底部,循環(huán)操作,一直到方格降落到底部;

8. 循環(huán) 2 ~ 7,一直到游戲結束;

五、總結

C++俄羅斯方塊設計的重點在于界面的設計以及游戲的整體邏輯,其中,界面設計主要是獲取對應坐標,在對應坐標處輸出對應圖形,整體邏輯是不斷循環(huán)產生下落的方格,方格移動是通過擦除當前位置的方格,將方格坐標整體移動一個再次顯示來實現的。

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • OpenCV實現圖像的直線檢測

    OpenCV實現圖像的直線檢測

    這篇文章主要為大家詳細介紹了OpenCV實現圖像直線檢測的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 正確理解C++的構造函數和析構函數

    正確理解C++的構造函數和析構函數

    在C++的學習中,可以把類當作一個模具,類實例化出來的對象就是根據這個模具所產生的實體,對象看作是自己創(chuàng)建的一個新的數據類型。本文主要介紹了類對象通過拷貝函數進行初始化,分析類對象的內存模型,以及通過this指針實現更復雜的功能。最后介紹了析構函數的基礎知識
    2021-06-06
  • 深入淺出理解C語言初識結構體

    深入淺出理解C語言初識結構體

    C?數組允許定義可存儲相同類型數據項的變量,結構是?C?編程中另一種用戶自定義的可用的數據類型,它允許你存儲不同類型的數據項,本篇讓我們來了解C?的結構體
    2022-02-02
  • c++ 對數器實現示例

    c++ 對數器實現示例

    對數器用于在自己的本地平臺驗證算法正確性,本文詳細的介紹了c++ 對數器實現,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • C語言實現學生成績等級劃分的方法實例

    C語言實現學生成績等級劃分的方法實例

    這篇文章主要給大家介紹了關于C語言實現學生成績等級劃分的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • C語言類型轉換與常量的細節(jié)深入理解探究

    C語言類型轉換與常量的細節(jié)深入理解探究

    這篇文章主要為大家介紹了C?語言類型轉換與常量的細節(jié)深入理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • C++多線程編程詳解

    C++多線程編程詳解

    這篇文章主要介紹了c語言多線程編程使用示例,小編覺得這篇文章寫的還不錯,需要的朋友可以參考下,希望能夠給你帶來幫助
    2021-09-09
  • C++ const和指針詳情

    C++ const和指針詳情

    這篇文章主要介紹了C++ const和指針,關于使用const來修飾指針,有兩種不同的方式。第一種是讓指針指向一個常量對象,這樣可以防止使用該指針進行修改指向的值。第二種則是將指針本身聲明為常量,可以防止改變指針指向的位置,下面來看看文章的詳細內容
    2021-11-11
  • 詳解如何從Matlab中導出清晰的結果圖片

    詳解如何從Matlab中導出清晰的結果圖片

    寫文章的時候有時需要matlab導出清晰的圖片,如果直接用figure里面的保存的話不夠清晰,下面這篇文章主要給大家介紹了關于如何從Matlab中導出清晰的結果圖片的相關資料,需要的朋友可以參考下
    2022-06-06
  • JetBrains?CLion永久激活超詳細教程(最新激活方法)

    JetBrains?CLion永久激活超詳細教程(最新激活方法)

    JetBrains?Clion?是一款專為?C/C++?開發(fā)所設計的跨平臺?IDE,本文適用?JetBrains?CLion?v2019.3/3.1/3.2/3.3?永久激活,附破解補丁和激活碼,可以永久激活?Windows、MAC、Linux?下的?CLion,下面給大家分享JetBrains?CLion永久激活超詳細教程,感興趣的朋友一起看看吧
    2023-01-01

最新評論