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

C/C++百行代碼實(shí)現(xiàn)熱門(mén)游戲消消樂(lè)功能的示例代碼

 更新時(shí)間:2020年07月01日 10:31:30   作者:#殘芯  
這篇文章主要介紹了C/C++百行代碼實(shí)現(xiàn)熱門(mén)游戲消消樂(lè)功能的示例代碼,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

游戲設(shè)計(jì)

首先我們需要使用第三方框架,這里我使用的是sfml,不會(huì)使用sfml在我的上幾篇文章當(dāng)中-掃雷(上)有詳細(xì)的開(kāi)發(fā)環(huán)境搭建介紹

首先準(zhǔn)備圖片資源

一張背景圖片,一張寶石圖片

在這里插入圖片描述

窗口初始化加載圖片

Texture t1;
t1.loadFromFile(“images/bg2.png”);

當(dāng)鼠標(biāo)第一次單擊時(shí),記錄下位置,第二次單擊又記錄一下位置,如果兩個(gè)小方塊相鄰就交換位置,如果不相鄰如圖c的位置則,不發(fā)生變化

在這里插入圖片描述

判斷行或列如果三張一樣的圖片相鄰,清除一下圖片,進(jìn)行刷新

實(shí)列

#include <SFML/Graphics.hpp>
#include <SFML/Audio.hpp>
#include <time.h>

using namespace sf;

#define GAME_ROWS_COUNT 8
#define GAME_COLS_COUNT 8

int ts = 57; // 每一個(gè)游戲小方塊區(qū)域的大小

bool isMoving = false;
bool isSwap = false;

// 相鄰位置的第幾次單擊,第2次單擊才交換方塊
int click = 0;

Vector2i pos; //鼠標(biāo)單擊時(shí)的位置
Vector2i offset(15, 273);

int posX1, posY1; //第一次單擊的位置(記錄行和列的序號(hào))
int posX2, posY2; //第二次單擊的位置(記錄行和列的序號(hào))

struct Block {
	int x, y; //坐標(biāo)值 x == col * ts y == row * ts;
	int row, col; //第幾行,第幾列
	int kind; //表示第幾種小方塊
	bool match; //表示是否成三
	int alpha; //透明度

	Block() {
		match = false;
		alpha = 255;
		kind = -1;
	}
} grid[GAME_ROWS_COUNT + 2][GAME_ROWS_COUNT + 2];

void swap(Block p1, Block p2) {
	std::swap(p1.col, p2.col);
	std::swap(p1.row, p2.row);

	grid[p1.row][p1.col] = p1;
	grid[p2.row][p2.col] = p2;
}

void doEvent(RenderWindow* window) {
	Event e;
	while (window->pollEvent(e)) {
		if (e.type == Event::Closed) {
			window->close();
		}

		if (e.type == Event::MouseButtonPressed) {
			if (e.key.code == Mouse::Left) {
				if (!isSwap && !isMoving) click++;
				pos = Mouse::getPosition(*window) - offset;
			}
		}
	}

	if (click == 1) {
		posX1 = pos.x / ts + 1;
		posY1 = pos.y / ts + 1;
	}
	else if (click == 2) {
		posX2 = pos.x / ts + 1;
		posY2 = pos.y / ts + 1;

		// 是相鄰方塊就交換位置
		if (abs(posX2 - posX1) + abs(posY2 - posY1) == 1) {
			// 交換相鄰的兩個(gè)小方塊
			// 消消樂(lè)的方塊,怎么表示?
			swap(grid[posY1][posX1], grid[posY2][posX2]);
			isSwap = 1;
			click = 0;
		}
		else {
			click = 1;
		}
	}
}

void check() {
	for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			if (grid[i][j].kind == grid[i + 1][j].kind &&
				grid[i][j].kind == grid[i - 1][j].kind) {
				//grid[i - 1][j].match++;
				//grid[i][j].match++;
				//grid[i + 1][j].match++;
				for (int k = -1; k <= 1; k++) grid[i + k][j].match++;
			}

			if (grid[i][j].kind == grid[i][j - 1].kind &&
				grid[i][j].kind == grid[i][j + 1].kind) {
				//grid[i][j - 1].match++;
				//grid[i][j + 1].match++;
				//grid[i][j].match++;
				for (int k = -1; k <= 1; k++) grid[i][j + k].match++;
			}
		}
	}
}

void doMoving() {
	isMoving = false;

	for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			Block& p = grid[i][j]; // 引用p, 就是grid[i][j]的別名
			int dx, dy;

			for (int k = 0; k < 4; k++) {
				dx = p.x - p.col * ts;
				dy = p.y - p.row * ts;

				if (dx) p.x -= dx / abs(dx);
				if (dy) p.y -= dy / abs(dy);
			}

			if (dx || dy) isMoving = true;
		}
	}
}

void xiaochu() {
	for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			if (grid[i][j].match && grid[i][j].alpha > 10) {
				grid[i][j].alpha -= 10;
				isMoving = true;
			}
		}
	}
}

void huanYuan() {
	if (isSwap && !isMoving) {
		// 如果此時(shí)沒(méi)有產(chǎn)生匹配效果,就要還原
		int score = 0;
		for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
			for (int j = 1; j <= GAME_COLS_COUNT; j++) {
				score += grid[i][j].match;
			}
		}

		if (score == 0) {
			swap(grid[posY1][posX1], grid[posY2][posX2]);
		}

		isSwap = false;
	}
}

void updateGrid() {
	for (int i = GAME_ROWS_COUNT; i > 0; i--) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			if (grid[i][j].match) {
				for (int k = i - 1; k > 0; k--) {
					if (grid[k][j].match == 0) {
						swap(grid[k][j], grid[i][j]);
						break;
					}
				}

			}
		}
	}

	for (int j = 1; j <= GAME_COLS_COUNT; j++) {
		int n = 0;
		for (int i = GAME_ROWS_COUNT; i > 0; i--) {
			if (grid[i][j].match) {
				grid[i][j].kind = rand() % 7;
				grid[i][j].y = -ts * n;
				n++;
				grid[i][j].match = false;
				grid[i][j].alpha = 255;
			}
		}
	}
}

void drawBlocks(Sprite* sprite, RenderWindow* window) {
	for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			Block p = grid[i][j];
			sprite->setTextureRect(
				IntRect(p.kind * 52, 0, 52, 52));
			// 設(shè)置透明度
			sprite->setColor(Color(255, 255, 255, p.alpha));
			sprite->setPosition(p.x, p.y);
			// 因?yàn)閿?shù)組gird中的Block, 每個(gè)Block的行標(biāo),列標(biāo)是從1計(jì)算的,
			// 并根據(jù)行標(biāo)和列表來(lái)計(jì)算的x,y坐標(biāo)
			// 所以坐標(biāo)的偏移,需要少便宜一些,也就是相當(dāng)于在正方形區(qū)域的左上角的左上角方向偏移一個(gè)單位
			// 在這個(gè)位置開(kāi)發(fā)存放第0行第0列(實(shí)際不繪制第0行第0列)
			sprite->move(offset.x - ts, offset.y - ts); // to do
			window->draw(*sprite);
		}
	}
}

void initGrid() {
	for (int i = 1; i <= GAME_ROWS_COUNT; i++) {
		for (int j = 1; j <= GAME_COLS_COUNT; j++) {
			grid[i][j].kind = rand() % 3;
			grid[i][j].col = j;
			grid[i][j].row = i;
			grid[i][j].x = j * ts;
			grid[i][j].y = i * ts;
		}
	}
}

int main(void) {
	srand(time(0));

	RenderWindow window(VideoMode(485, 917), "canxin-xiaoxiaole");
	// 設(shè)置刷新的最大幀率
	window.setFramerateLimit(60);

	Texture t1, t2;
	t1.loadFromFile("images/bg2.png");
	if (!t2.loadFromFile("images/1.png")) {
		return -1;
	}
	Sprite spriteBg(t1);
	Sprite spriteBlock(t2);

	initGrid();

	while (window.isOpen()) {
		// 處理用戶的點(diǎn)擊事件
		doEvent(&window);

		// 檢查匹配情況
		check();

		// 移動(dòng)處理
		doMoving();

		// 消除
		if (!isMoving) {
			xiaochu();
		}

		// 還原處理
		huanYuan();

		if (!isMoving) {
			updateGrid();
		}

		// 渲染游戲畫(huà)面
		window.draw(spriteBg);
		// 渲染所有的小方塊 
		drawBlocks(&spriteBlock, &window);
		// 顯示
		window.display();
	}

	return 0;
}

總結(jié)

到此這篇關(guān)于C/C++百行代碼實(shí)現(xiàn)熱門(mén)游戲消消樂(lè)功能的示例代碼的文章就介紹到這了,更多相關(guān)C++ 消消樂(lè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++實(shí)現(xiàn)簡(jiǎn)單版圖書(shū)管理系統(tǒng)

    C++實(shí)現(xiàn)簡(jiǎn)單版圖書(shū)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單版圖書(shū)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語(yǔ)言入門(mén)篇--初識(shí)結(jié)構(gòu)體

    C語(yǔ)言入門(mén)篇--初識(shí)結(jié)構(gòu)體

    本篇文章是基礎(chǔ)篇,適合c語(yǔ)言剛?cè)腴T(mén)的朋友,本文對(duì)c語(yǔ)言的結(jié)構(gòu)體做了簡(jiǎn)單的分析,幫助大家快速入門(mén)c語(yǔ)言的世界,更好的理解c語(yǔ)言
    2021-08-08
  • C語(yǔ)言撲克牌游戲示例

    C語(yǔ)言撲克牌游戲示例

    大家好,本篇文章主要講的是C語(yǔ)言撲克牌游戲示例,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • C++分析講解類(lèi)的靜態(tài)成員變量是什么

    C++分析講解類(lèi)的靜態(tài)成員變量是什么

    在C++中,靜態(tài)成員是屬于整個(gè)類(lèi)的而不是某個(gè)對(duì)象,靜態(tài)成員變量只存儲(chǔ)一份供所有對(duì)象共用。所以在所有對(duì)象中都可以共享它。使用靜態(tài)成員變量實(shí)現(xiàn)多個(gè)對(duì)象之間的數(shù)據(jù)共享不會(huì)破壞隱藏的原則,保證了安全性還可以節(jié)省內(nèi)存
    2022-04-04
  • Qt如何通過(guò)pos()獲取坐標(biāo)信息

    Qt如何通過(guò)pos()獲取坐標(biāo)信息

    這篇文章主要給大家介紹了關(guān)于Qt如何通過(guò)pos()獲取坐標(biāo)信息的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用qt具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-01-01
  • C++制作簡(jiǎn)單的計(jì)算器功能

    C++制作簡(jiǎn)單的計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了C++制作簡(jiǎn)單的計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++萬(wàn)能庫(kù)頭文件在vs中的安裝步驟(圖文)

    C++萬(wàn)能庫(kù)頭文件在vs中的安裝步驟(圖文)

    這篇文章主要介紹了C++萬(wàn)能庫(kù)頭文件在vs中的安裝步驟(圖文),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • 詳解C++ 重載運(yùn)算符和重載函數(shù)

    詳解C++ 重載運(yùn)算符和重載函數(shù)

    這篇文章主要介紹了C++ 重載運(yùn)算符和重載函數(shù)的的相關(guān)資料,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • boost.asio框架系列之socket編程

    boost.asio框架系列之socket編程

    這篇文章介紹了boost.asio框架系列之socket編程,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • C++ Boost Flyweight庫(kù)使用介紹

    C++ Boost Flyweight庫(kù)使用介紹

    Boost是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱(chēng)。Boost庫(kù)是一個(gè)可移植、提供源代碼的C++庫(kù),作為標(biāo)準(zhǔn)庫(kù)的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開(kāi)發(fā)引擎之一,是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱(chēng)
    2022-12-12

最新評(píng)論