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

MFC實現(xiàn)連連看游戲之地圖顯示

 更新時間:2019年01月03日 16:43:08   作者:StriverLi  
這篇文章主要為大家詳細(xì)介紹了MFC實現(xiàn)連連看游戲之地圖顯示,具有一定的參考價值,感興趣的小伙伴們可以參考一下

MFC實現(xiàn)連連看游戲前期過程中遇到的一大問題是如何將地圖顯示出來,最后還是看了其他人的源碼才搞定。

首先是地圖數(shù)組的生成,這個網(wǎng)上找有很多,我用的是隨機生成地圖的種類,然后將其放在兩個連續(xù)的位置,最后再進行兩兩隨機交換位置,得到隨機地圖,具體如下:

void CGameDlg::InitMap() 
{
 for (int i = 0; i < MAX_X; i++) // 初始化map數(shù)組
 {
  for (int j = 0; j < MAX_Y; j++)
  {
   map[i][j] = 0;
  }
 }

 //隨機數(shù)種子
 srand((unsigned int)time(NULL));

 for (int i = 1; i < MAX_X - 1; i++)
 {
  for (int j = 1; j < MAX_Y - 1; j = j+2)
  {
   int type = rand() % m_typeNum + 1;// 隨機產(chǎn)生一個的圖片種類編號
   map[i][j] = type;
   map[i][j+1] = type; // 保證同種圖片連續(xù)出現(xiàn)兩次
  }
 }
 int k = 0;
 while (k < 100) // 隨機選中兩個位置交換100次
 {
  int x1 = 0, y1 = 0;
  int x2 = 0, y2 = 0;
  while (x1 == x2 && y1 == y2) // 確保兩個位置不同
  {
   x1 = rand() % (MAX_X - 2) + 1;
   y1 = rand() % (MAX_Y - 2) + 1;

   x2 = rand() % (MAX_X - 2) + 1;
   y2 = rand() % (MAX_Y - 2) + 1;
  }
  int temp = map[x1][y1];
  map[x1][y1] = map[x2][y2];
  map[x2][y2] = temp;
  k++;
 }
}

其中MAX_X和MAX_X是宏定義,需要注意的是地圖數(shù)組的最外一層不要放圖片,后面的消子算法會更加方便。

接下來就是地圖的顯示了:

void CGameDlg::ShowMap()
{
 int i, j;
 CPoint p; // 按鈕位置
 CString str = _T("");
 //清除原有按鈕
 for (i = 0; i<m_btnGroup.GetSize(); i++)
  delete (CLLKButton *)m_btnGroup.GetAt(i);
 m_btnGroup.RemoveAll();
 //添加新按鈕
 for (i = 1; i <= MAX_X - 2; i++)
  for (j = 1; j <= MAX_Y - 2; j++)
  {
   p.x = i;
   p.y = j;
   //arr[map[i][j] - 1]++;
   //將按鈕放入m_btnGroup指針數(shù)組中
   m_btnGroup.Add(new CLLKButton(map[i][j], p));
  }
 //顯示按鈕
 for (i = 0; i<(MAX_X - 2)*(MAX_Y - 2); i++)
 {
  CLLKButton *btn = (CLLKButton *)m_btnGroup.GetAt(i);
  if (btn->ID > 0)
  {
   str.Format(_T("res\\%d.png"), btn->ID);

   CImage image;
   image.Load(str);

   btn->Create(str, WS_CHILD | BS_BITMAP | WS_VISIBLE,
    CRect(70 + (i % (MAX_Y - 2)) * 50, 70 + (i / (MAX_Y - 2)) * 50,
    120 + (i % (MAX_Y - 2)) * 50, 120 + (i / (MAX_Y - 2)) * 50), this,
    IDC_BLOCK + i);
   btn->SetBitmap(image);
   btn->ShowWindow(SW_SHOW);
  }
 }

}

在生成地圖的過程中,我并沒有將圖片拼接起來,并用掩碼消去背景色,這里只是簡單的將圖片加載到按鈕上,不過因為.png的圖片能實現(xiàn)透明(.bmp圖片是無法實現(xiàn)透明的,會有白色背景),所以也算是實現(xiàn)了透明背景。
還有就是自己重寫了一個新的CLLKButton類繼承CButton類,就添加了兩個屬性:

int ID; // 圖片的種類
CPoint p; // 按鈕的位置

完整源碼已上傳至我的GitHub

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入理解Qt信號槽機制

    深入理解Qt信號槽機制

    信號槽是 Qt 框架引以為豪的機制之一。本文主要介紹了Qt信號槽機制,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 深入const int *p與int * const p的區(qū)別詳解(常量指針與指向常量的指針)

    深入const int *p與int * const p的區(qū)別詳解(常量指針與指向常量的指針)

    本篇文章是對const int *p與int * const p的區(qū)別進行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 求解旋轉(zhuǎn)數(shù)組的最小數(shù)字

    求解旋轉(zhuǎn)數(shù)組的最小數(shù)字

    這篇文章主要介紹了求解旋轉(zhuǎn)數(shù)組的最小數(shù)字的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言運算符的重載詳解

    C語言運算符的重載詳解

    這篇文章主要為大家詳細(xì)介紹C語言運算符的重載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • 如何用C++制作LeetCode刷題小技巧-錯題記錄本

    如何用C++制作LeetCode刷題小技巧-錯題記錄本

    這篇文章主要介紹了如何用C++制作LeetCode刷題小技巧-錯題記錄本的方法,需要的朋友可以參考下
    2021-04-04
  • C++?STL容器適配器使用指南

    C++?STL容器適配器使用指南

    C++?STL(標(biāo)準(zhǔn)模板庫)是一套功能強大的?C++?模板類,提供了通用的模板類和函數(shù),這些模板類和函數(shù)可以實現(xiàn)多種流行和常用的算法和數(shù)據(jù)結(jié)構(gòu),如向量、鏈表、隊列、棧,今天我們來探究一下stl容器適配器的使用吧
    2021-11-11
  • 一篇文章帶你了解C++ static的作用,全局變量和局部變量的區(qū)別

    一篇文章帶你了解C++ static的作用,全局變量和局部變量的區(qū)別

    這篇文章介紹了C++ static的作用,全局變量和局部變量的區(qū)別,需要的朋友可以過來參考下,希望能夠給你帶來幫助
    2021-09-09
  • C++實現(xiàn)LeetCode(769.可排序的最大塊數(shù))

    C++實現(xiàn)LeetCode(769.可排序的最大塊數(shù))

    這篇文章主要介紹了C++實現(xiàn)LeetCode(769.可排序的最大塊數(shù)),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語言接口與實現(xiàn)方法實例詳解

    C語言接口與實現(xiàn)方法實例詳解

    這篇文章主要介紹了C語言接口與實現(xiàn)方法,包括接口的概念、實現(xiàn)方法及抽象數(shù)據(jù)類型等,并配合實例予以說明,需要的朋友可以參考下
    2014-09-09
  • C++詳細(xì)講解圖論的基礎(chǔ)與圖的儲存

    C++詳細(xì)講解圖論的基礎(chǔ)與圖的儲存

    圖論〔Graph?Theory〕是數(shù)學(xué)的一個分支。它以圖為研究對象。圖論中的圖是由若干給定的點及連接兩點的線所構(gòu)成的圖形,這種圖形通常用來描述某些事物之間的某種特定關(guān)系,用點代表事物,用連接兩點的線表示相應(yīng)兩個事物間具有這種關(guān)系
    2022-05-05

最新評論