亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

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;
  }
 }

 //隨機(jī)數(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;// 隨機(jī)產(chǎn)生一個(gè)的圖片種類(lèi)編號(hào)
   map[i][j] = type;
   map[i][j+1] = type; // 保證同種圖片連續(xù)出現(xiàn)兩次
  }
 }
 int k = 0;
 while (k < 100) // 隨機(jī)選中兩個(gè)位置交換100次
 {
  int x1 = 0, y1 = 0;
  int x2 = 0, y2 = 0;
  while (x1 == x2 && y1 == y2) // 確保兩個(gè)位置不同
  {
   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ù)組的最外一層不要放圖片,后面的消子算法會(huì)更加方便。

接下來(lái)就是地圖的顯示了:

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);
  }
 }

}

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

int ID; // 圖片的種類(lèi)
CPoint p; // 按鈕的位置

完整源碼已上傳至我的GitHub

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

相關(guān)文章

  • 深入理解Qt信號(hào)槽機(jī)制

    深入理解Qt信號(hào)槽機(jī)制

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

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

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

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

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

    C語(yǔ)言運(yùn)算符的重載詳解

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評(píng)論