189 8069 5689

C++实现拼图游戏代码(graphics图形库)-创新互联

本文实例为大家分享了C++实现拼图游戏的具体代码,供大家参考,具体内容如下

创新互联公司网站建设公司一直秉承“诚信做人,踏实做事”的原则,不欺瞒客户,是我们最起码的底线! 以服务为基础,以质量求生存,以技术求发展,成交一个客户多一个朋友!专注中小微企业官网定制,网站建设、成都网站制作,塑造企业网络形象打造互联网企业效应。
#include 
#include 
#include 
#include 
#include 
#include 
int map[4][3]; 
int num = 0; 
IMAGE image1, image2, image3, image4, image5, image6, image7, image8, image9, image10, image11, image12, image13; 
void Initmap()//初始化数组 
{ 
 for (int i = 0; i < 4; i++) 
 { 
 for (int j = 0; j < 3; j++) 
 { 
 map[i][j] = rand() % 100; 
 } 
 } 
 map[2][3] = 100; 
 
} 
void PaintInit()//获取图片地址内容 
{ 
 loadimage(&image1, L"./image/1.jpg", 100, 100); 
 loadimage(&image2, L"./image/2.jpg", 100, 100); 
 loadimage(&image3, L"./image/3.jpg", 100, 100); 
 loadimage(&image4, L"./image/4.jpg", 100, 100); 
 loadimage(&image5, L"./image/5.jpg", 100, 100); 
 loadimage(&image6, L"./image/6.jpg", 100, 100); 
 loadimage(&image7, L"./image/7.jpg", 100, 100); 
 loadimage(&image8, L"./image/8.jpg", 100, 100); 
 loadimage(&image9, L"./image/9.jpg", 100, 100); 
 loadimage(&image10, L"./image/10.jpg", 100, 100); 
 loadimage(&image11, L"./image/11.jpg", 100, 100); 
 loadimage(&image12, L"./image/back.jpg", 400, 200); 
 loadimage(&image13, L"./image/border.jpg", 50, 300); 
 
} 
int finMin(int a)//找到数组里面最小的数,然后将设定的图片给对应的数; 
{ 
 int flag=1; 
 
 for (int i = 0; i < 4; i++) 
 { 
 for (int j = 0; j < 3; j++) 
 { 
 if (a > map[i][j]) 
 { 
 flag++;//如过flag 不加上去不变表示没有比他大的数 
 } 
 } 
 } 
 return flag; 
} 
void GameInit()//游戏初始化 
{ 
 
 int min=map[0][0]; 
 putimage(450, 0, &image12); 
 putimage(400, 0, &image13); 
 for (int i = 0; i < 4; i++) 
 { 
 for (int j = 0; j < 3; j++) 
 { 
 if (finMin(map[i][j]) == 1) 
 { 
  putimage(i * 100, j * 100, &image1); 
 } 
 if (finMin(map[i][j]) == 2) 
 { 
  putimage(i * 100, j * 100, &image2); 
 } 
 if (finMin(map[i][j]) == 3) 
 { 
  putimage(i * 100, j * 100, &image3); 
 } 
 if (finMin(map[i][j]) == 4) 
 { 
  putimage(i * 100, j * 100, &image4); 
 } 
 if (finMin(map[i][j]) == 5) 
 { 
  putimage(i * 100, j * 100, &image5); 
 } 
 if (finMin(map[i][j]) == 6) 
 { 
  putimage(i * 100, j * 100, &image6); 
 } 
 if (finMin(map[i][j]) == 7) 
 { 
  putimage(i * 100, j * 100, &image7); 
 } 
 if (finMin(map[i][j]) == 8) 
 { 
  putimage(i * 100, j * 100, &image8); 
 } 
 if (finMin(map[i][j]) == 9) 
 { 
  putimage(i * 100, j * 100, &image9); 
 } 
 if (finMin(map[i][j]) == 10) 
 { 
  putimage(i * 100, j * 100, &image10); 
 } 
 if (finMin(map[i][j]) == 11) 
 { 
  putimage(i * 100, j * 100, &image11); 
 } 
  
 } 
 } 
 
} 
void PlayGame() 
{ 
 int x, y; 
 MOUSEMSG m; 
 int newA; 
 char ch; 
 int r, c; //找到当前空白块的下标 // 
 for (int i = 0; i < 4; i++) 
 { 
 for (int j = 0; j < 3; j++) 
 { 
 if (map[i][j] == 100) 
 { 
 r = i; 
 c = j; 
 } 
 } 
 } 
 
 
 ch = getch(); 
 switch (ch) 
 { 
 
 case 'W':case 'w' : 
 { 
 
 if (c - 1<0)return; 
 newA = map[r][c]; 
 map[r][c] = map[r][c-1]; 
 map[r][c-1] = newA; 
 num++; 
 break; 
 } 
 case 'S':case 's': 
 { 
 if (c + 1>2)return; 
 newA = map[r][c]; 
 map[r][c] = map[r][c+1]; 
 map[r][c+1] = newA; 
 num++; 
 break; 
 } 
 case 'A':case 'a': 
 { 
 if (r - 1<0)return; 
 newA = map[r][c]; 
 map[r][c] = map[r-1][c]; 
 map[r-1][c] = newA; 
 num++; 
 break; 
 } 
 case 'd':case 'D': 
 { 
 if(r+1>3)return; 
 newA = map[r][c]; 
 map[r][c] = map[r+1][c]; 
 map[r+1][c] = newA; 
 num++; 
 break; 
 } 
 } 
} 
int main()//最后如果图像游戏如果拼完整后,数组的数会是从小到大的,以此来判别是否拼图完整 
{ 
 TCHAR sql[200]; 
 initgraph(850, 300); 
 Initmap(); 
 PaintInit(); 
 
 while (1) 
 { 
 cleardevice(); 
 BeginBatchDraw(); 
 GameInit(); 
 outtextxy(650, 210, _T("原图")); 
 _stprintf(sql, _T("走了:%d"), num); 
 outtextxy(500, 250, sql); 
 EndBatchDraw(); 
 PlayGame(); 
 } 
 getch(); 
 closegraph(); 
 system("pause"); 
 return 
}

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文标题:C++实现拼图游戏代码(graphics图形库)-创新互联
文章分享:http://gzruizhi.cn/article/iejee.html

其他资讯