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

C++實(shí)現(xiàn)拼圖游戲代碼(graphics圖形庫)

 更新時(shí)間:2018年05月03日 14:14:06   作者:DB偉  
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)拼圖游戲代碼,帶有g(shù)raphics圖形庫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C++實(shí)現(xiàn)拼圖游戲的具體代碼,供大家參考,具體內(nèi)容如下

#include<stdio.h> 
#include<stdlib.h> 
#include<conio.h> 
#include<windows.h> 
#include<graphics.h> 
#include<string.h> 
int map[4][3]; 
int num = 0; 
IMAGE image1, image2, image3, image4, image5, image6, image7, image8, image9, image10, image11, image12, image13; 
void Initmap()//初始化數(shù)組 
{ 
 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()//獲取圖片地址內(nèi)容 
{ 
 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)//找到數(shù)組里面最小的數(shù),然后將設(shè)定的圖片給對(duì)應(yīng)的數(shù); 
{ 
 int flag=1; 
 
 for (int i = 0; i < 4; i++) 
 { 
 for (int j = 0; j < 3; j++) 
 { 
 if (a > map[i][j]) 
 { 
 flag++;//如過flag 不加上去不變表示沒有比他大的數(shù) 
 } 
 } 
 } 
 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; //找到當(dāng)前空白塊的下標(biāo) // 
 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()//最后如果圖像游戲如果拼完整后,數(shù)組的數(shù)會(huì)是從小到大的,以此來判別是否拼圖完整 
{ 
 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 
}

效果圖:

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

相關(guān)文章

  • C語言實(shí)現(xiàn)會(huì)員管理系統(tǒng)

    C語言實(shí)現(xiàn)會(huì)員管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)會(huì)員管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳談浮點(diǎn)精度(float、double)運(yùn)算不精確的原因

    詳談浮點(diǎn)精度(float、double)運(yùn)算不精確的原因

    這篇文章主要介紹了詳談浮點(diǎn)精度(float、double)運(yùn)算不精確的原因,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • C語言輪轉(zhuǎn)數(shù)組的三種實(shí)現(xiàn)

    C語言輪轉(zhuǎn)數(shù)組的三種實(shí)現(xiàn)

    輪轉(zhuǎn)數(shù)組是一種將數(shù)組元素循環(huán)移動(dòng)的處理方式,它通常用于解決一些需要對(duì)固定長度的數(shù)組進(jìn)行循環(huán)滾動(dòng)處理的問題,本文就介紹了C語言輪轉(zhuǎn)數(shù)組的三種實(shí)現(xiàn),感興趣的可以了解一下
    2023-08-08
  • 用32位int型變量表示單引號(hào)括起來的四個(gè)字符的深入探討

    用32位int型變量表示單引號(hào)括起來的四個(gè)字符的深入探討

    本篇文章是對(duì)用32位int型變量表示單引號(hào)括起來的四個(gè)字符進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言簡明講解歸并排序的應(yīng)用

    C語言簡明講解歸并排序的應(yīng)用

    這篇文章主要介紹了 c語言排序之歸并排序,歸并就是把兩個(gè)或多個(gè)序列合并,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • vscode配置遠(yuǎn)程開發(fā)環(huán)境并遠(yuǎn)程調(diào)試運(yùn)行C++代碼的教程

    vscode配置遠(yuǎn)程開發(fā)環(huán)境并遠(yuǎn)程調(diào)試運(yùn)行C++代碼的教程

    這篇文章主要介紹了vscode配置遠(yuǎn)程開發(fā)環(huán)境并遠(yuǎn)程調(diào)試運(yùn)行C++代碼的教程,本文通過截圖實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 如何在 C++ 中實(shí)現(xiàn)一個(gè)單例類模板

    如何在 C++ 中實(shí)現(xiàn)一個(gè)單例類模板

    這篇文章主要介紹了如何在 C++ 中實(shí)現(xiàn)一個(gè)單例類模板,幫助大家更好的理解和學(xué)習(xí)c++編程,感興趣的朋友可以了解下
    2020-10-10
  • C語言中使用fopen()打開和操作文件的詳細(xì)方法指南

    C語言中使用fopen()打開和操作文件的詳細(xì)方法指南

    fopen是C語言庫函數(shù),open是系統(tǒng)調(diào)用,mmap是將大文件映射到內(nèi)存中使用,這篇文章主要給大家介紹了關(guān)于C語言中使用fopen()打開和操作文件的詳細(xì)方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • C/C++中extern

    C/C++中extern "C" 的作用分析

    這篇文章主要介紹了C/C++中extern "C" 的作用,是在進(jìn)行C/C++程序設(shè)計(jì)中非常常見的用法,需要的朋友可以參考下
    2014-09-09
  • C++實(shí)現(xiàn)連連看游戲

    C++實(shí)現(xiàn)連連看游戲

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)連連看游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評(píng)論