亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? russia.cpp

?? VC++6游戲編程入門及源碼,新手必備~
?? CPP
字號:
// Russia.cpp: implementation of the CRussia class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "4_1.h"
#include "Russia.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CRussia::CRussia()
{
	jiemian.LoadBitmap(IDB_BITMAP2);
	fangkuai.LoadBitmap(IDB_BITMAP4);
}

CRussia::~CRussia()
{

}

void CRussia::Start()
{
	end=false;//運行結束標志
    m_Score=0;		//初始分數
	m_Speed=0;		//初始速度
	m_Level=1;		//初始難度
	m_RowCount=18;	//行數
	m_ColCount=12;	//列數
	Count=7;		//方塊種類

	for(int i=0;i<m_RowCount;i++)
		for(int j=0;j<m_ColCount;j++)
		{
			Russia[i][j]=0;
		}

	for(i=0;i<4;i++)
		for(int j=0;j<4;j++)
		{
			Now[i][j]=0;
			Will[i][j]=0;
		}
    //Will[][]
	DrawWill();
	//Now[][]&Will[][]
	DrawWill();

}

void CRussia::DrawJiemian(CDC*pDC)
{	
	CDC Dc;
	if(Dc.CreateCompatibleDC(pDC)==FALSE)
		AfxMessageBox("Can't create DC");
	//畫背景
    Dc.SelectObject(jiemian);
	pDC->BitBlt(0,0,500,550,&Dc,0,0,SRCCOPY);
    //畫分數,速度,難度
	DrawScore(pDC);
    //如果有方塊,顯示方塊
	//游戲區
	for(int i=0;i<m_RowCount;i++)
		for(int j=0;j<m_ColCount;j++)
			if(Russia[i][j]==1)
			{
				Dc.SelectObject(fangkuai);
				pDC->BitBlt(j*30,i*30,30,30,&Dc,0,0,SRCCOPY);
			}
    //預先圖形
	for(int n=0;n<4;n++)
		for(int m=0;m<4;m++)
			if(Will[n][m]==1)
			{	
				Dc.SelectObject(fangkuai);
				pDC->BitBlt(365+m*30,240+n*30,30,30,&Dc,0,0,SRCCOPY);
			}
}


void CRussia::DrawWill()
{
	int i,j;
	int k=4,l=4;

    //把將要出現的方塊給當前數組,并把將要出現數組賦值為零
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
		{
			Now[i][j]=Will[i][j];
			Will[i][j]=0;
		}
	//初始化隨即數種子
	srand(GetTickCount());
	int nTemp=rand()%Count;
	//各種圖形
	switch(nTemp)
	{
	case 0:
		Will[0][0]=1;
		Will[0][1]=1;
		Will[1][0]=1;
		Will[1][1]=1;
		break;
	case 1:
		Will[0][0]=1;
		Will[0][1]=1;
		Will[1][0]=1;
		Will[2][0]=1;
		break;
	case 2:
		Will[0][0]=1;
		Will[0][1]=1;
		Will[1][1]=1;
		Will[2][1]=1;
		break;
	case 3:
		Will[0][1]=1;
		Will[1][0]=1;
		Will[1][1]=1;
		Will[2][0]=1;
		break;
	case 4:
		Will[0][0]=1;
		Will[1][0]=1;
		Will[1][1]=1;
		Will[2][1]=1;
		break;
	case 5:
		Will[0][0]=1;
		Will[1][0]=1;
		Will[1][1]=1;
		Will[2][0]=1;
		break;
	case 6:
		Will[0][0]=1;
		Will[1][0]=1;
		Will[2][0]=1;
		Will[3][0]=1;
		break;
//適應于難度擴展
/*	case 7:
		Will[0][0]=1;
		Will[1][0]=1;
		Will[1][1]=1;
		Will[1][2]=1;
		Will[0][2]=1;
		break;
	case 8:
		Will[0][0]=1;
		Will[1][0]=1;
		Will[2][0]=1;
		Will[1][1]=1;
		Will[1][2]=1;
		break;
*/
	}

	int tmp[4][4];
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			tmp[i][j]=Will[j][3-i];

	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			if(tmp[i][j]==1)
			{
				if(k>i) k=i;
				if(l>j) l=j;
			}

	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			Will[i][j]=0;
	//把變換后的矩陣移到左上角
	for(i=k;i<4;i++)
		for(j=l;j<4;j++)
			Will[i-k][j-l]=tmp[i][j];

    //開始位置
	NowPosition.x=0;
	NowPosition.y=m_ColCount/2;

}



//是否遇到了邊界或者有其他方塊檔住了
bool CRussia::Meet(int a[][4],int direction,CPoint p)
{
	int i,j;
	//先把原位置清0 
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			if(a[i][j]==1)
				Russia[p.x+i][p.y+j]=0;
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
		if(a[i][j]==1)
		{
			switch(direction)
			{
			case 1:	//左移
				if((p.y+j-1)<0) goto exit;
				if(Russia[p.x+i][p.y+j-1]==1) goto exit;
				break;
			case 2://右移
				if((p.y+j+1)>=m_ColCount) goto exit;
				if(Russia[p.x+i][p.y+j+1]==1) goto exit;
				break;
			case 3://下移
				if((p.x+i+1)>=m_RowCount) goto exit;
				if(Russia[p.x+i+1][p.y+j]==1) goto exit;
				break;
			case 4://變換
				if(!Change(a,p,Russia)) goto exit;				
				for(i=0;i<4;i++)
					for(j=0;j<4;j++)
					{
						Now[i][j]=After[i][j];
						a[i][j]=Now[i][j];
					}
				return false;
				break;
			}
		}
	int x,y;
	x=p.x;
	y=p.y;
	//移動位置,重新給數組賦值
	switch(direction)
	{
	case 1:
		y--;break;
	case 2:
		y++;break;
	case 3:
		x++;break;
	case 4:
		break;
	}
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			if(a[i][j]==1)
				Russia[x+i][y+j]=1;

	return false;
exit:
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			if(a[i][j]==1)
				Russia[p.x+i][p.y+j]=1;
	return true;
}

//轉換
bool CRussia::Change(int a[][4], CPoint p,int  b[][100])
{
	int tmp[4][4];
	int i,j;
	int k=4,l=4;

	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
		{
			tmp[i][j]=a[j][3-i];
			After[i][j]=0;	//存放變換后的方塊矩陣
		}
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
			if(tmp[i][j]==1)
			{
				if(k>i) k=i;
				if(l>j) l=j;
			}
	for(i=k;i<4;i++)
		for(j=l;j<4;j++)
		{
			After[i-k][j-l]=tmp[i][j];
		}	//把變換后的矩陣移到左上角

		//判斷是否接觸,是:返回失敗
	for(i=0;i<4;i++)
		for(j=0;j<4;j++)
		{	
			if(After[i][j]==0) continue;
			if(((p.x+i)>=m_RowCount)||((p.y+j)<0)||((p.y+j)>=m_ColCount)) return false;
			if(b[p.x+i][p.y+j]==1)
				return false;
		}
	return true;
}


void CRussia::Move(int direction)
{
	if(end) return;

	switch(direction)
	{
		//左
	case 1:
		if(Meet(Now,1,NowPosition)) break;
		NowPosition.y--;
		break;
		//右
	case 2:
		if(Meet(Now,2,NowPosition)) break;
		NowPosition.y++;
		break;
		//下
	case 3:
		if(Meet(Now,3,NowPosition))
		{
			LineDelete();			
			break;
		}
		NowPosition.x++;
		break;
		//上
	case 4:
		Meet(Now,4,NowPosition);
		break;
	default:
		break;
	}

}
//消去行
void CRussia::LineDelete()
{
	int m=0;		//本次共消去的行數
	bool flag=0;
	for(int i=0;i<m_RowCount;i++)
	{
		//檢查要不要消行
		flag=true;
		for(int j=0;j<m_ColCount;j++)
			if(Russia[i][j]==0)
				flag=false;
		//如果要
		if(flag==true)
		{
			m++;
			for(int k=i;k>0;k--)
			{
				//上行給下行
				for(int l=0;l<m_ColCount;l++)
				{
					Russia[k][l]=Russia[k-1][l];
				}
			}
			//第一行為零
			for(int l=0;l<m_ColCount;l++)
			{
				Russia[0][l]=0;
			}
		}
	}
    
	DrawWill();

	//加分
	switch(m)
	{
	case 1:
		m_Score++;
		break;
	case 2:
		m_Score+=3;
		break;
	case 3:
		m_Score+=6;
		break;
	case 4:
		m_Score+=10;
		break;
	default:
		break;
	}

	//速度
	m_Speed=m_Score/100;
	
	for(i=0;i<4;i++)
		for(int j=0;j<4;j++)
			if(Now[i][j]==1)
				//到了頂點
				if(Russia[i+NowPosition.x][j+NowPosition.y]==1)
				{
					end=true;
					AfxMessageBox("游戲結束!");
					return;
				}

}

void CRussia::DrawScore(CDC*pDC)
{	
	int nOldDC=pDC->SaveDC();	
	//設置字體
	CFont font;    
	if(0==font.CreatePointFont(300,"Comic Sans MS"))
					{
						AfxMessageBox("Can't Create Font");
					}
	pDC->SelectObject(&font);
    //設置字體顏色及其背景顏色
	CString str;
	pDC->SetTextColor(RGB(39,244,10));
	pDC->SetBkColor(RGB(255,255,0));
    //輸出數字
	str.Format("%d",m_Level);
	if(m_Level>=0)
		pDC->TextOut(440,120,str);

	str.Format("%d",m_Speed);	
	if(m_Speed>=0)	
		pDC->TextOut(440,64,str);

	str.Format("%d",m_Score);	
	if(m_Score>=0)
		pDC->TextOut(440,2,str);

	pDC->RestoreDC(nOldDC);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品视频一区二区| 亚洲欧洲日产国产综合网| 日韩欧美高清dvd碟片| av电影在线观看不卡| 精品无人码麻豆乱码1区2区| 国产一区二区不卡在线| 成人免费看片app下载| 欧美影院一区二区| 91精品国产高清一区二区三区| 91精品欧美福利在线观看| 久久久精品国产免大香伊| 久久综合久久综合亚洲| 日韩理论片在线| 免费国产亚洲视频| av电影在线观看不卡| 91精品一区二区三区在线观看| 精品免费视频一区二区| 国产精品三级电影| 五月婷婷激情综合| av电影天堂一区二区在线| 欧美一区二区视频在线观看2020 | 国产精品热久久久久夜色精品三区 | 国产精品一区在线观看乱码| 日韩国产欧美在线观看| 国产激情一区二区三区四区| 欧美精品自拍偷拍| 综合精品久久久| 天天免费综合色| 91蜜桃免费观看视频| 日韩免费看网站| 日本欧美在线观看| 91福利视频久久久久| 国产性做久久久久久| 国产a视频精品免费观看| 91精品国产91热久久久做人人| 国产精品成人网| 丰满白嫩尤物一区二区| 亚洲精品在线网站| 美女高潮久久久| 欧美一级在线免费| 奇米一区二区三区av| 欧美一区二区三区在线视频| 亚洲成人综合在线| 欧美日韩精品三区| 视频在线观看国产精品| 欧美精品电影在线播放| 日韩avvvv在线播放| 精品国产免费视频| 国产91综合网| 日韩毛片一二三区| 欧美亚洲一区二区在线观看| 亚洲主播在线观看| 欧美一区二区视频在线观看2020 | 日韩欧美成人午夜| av亚洲产国偷v产偷v自拍| 天堂蜜桃91精品| 中文字幕第一区| 91精品国产91热久久久做人人| 国产电影精品久久禁18| 亚洲成人av一区二区三区| 久久在线观看免费| 欧美少妇xxx| a在线欧美一区| 精品一区精品二区高清| 亚洲成年人网站在线观看| 中文字幕欧美日韩一区| 欧美日韩免费一区二区三区视频| 国产在线观看一区二区| 水蜜桃久久夜色精品一区的特点| 最新欧美精品一区二区三区| 欧美电影免费提供在线观看| 91免费小视频| 岛国av在线一区| 麻豆精品精品国产自在97香蕉| 亚洲妇熟xx妇色黄| 亚洲一区二区三区激情| 亚洲精品videosex极品| 亚洲免费观看高清完整版在线观看熊| 久久久亚洲高清| 精品少妇一区二区三区在线播放 | 91在线观看成人| av在线播放不卡| 不卡的av在线播放| 色偷偷久久人人79超碰人人澡| 972aa.com艺术欧美| 99综合电影在线视频| 成人网男人的天堂| 色婷婷av一区二区三区gif | 亚洲一二三区视频在线观看| 一区二区三区四区在线免费观看| 亚洲综合久久久| 美国三级日本三级久久99| 国内精品国产三级国产a久久| 国产一区二区看久久| 成人av网站在线| 91精品在线一区二区| 26uuu精品一区二区| 亚洲日本一区二区三区| 亚洲电影在线免费观看| 国模无码大尺度一区二区三区| 成人免费毛片a| 日韩你懂的电影在线观看| 国产精品久久久久久久久搜平片| 亚洲蜜桃精久久久久久久| 丝袜美腿亚洲一区二区图片| 成人午夜私人影院| 精品国产一区二区三区久久影院 | 99国产精品久久久久久久久久久| 欧美性高清videossexo| 国产亚洲va综合人人澡精品| 午夜精品久久久久久久久| 国产精品亚洲人在线观看| 欧美老肥妇做.爰bbww视频| 国产精品天美传媒沈樵| 青青草视频一区| 51久久夜色精品国产麻豆| 亚洲同性同志一二三专区| 国产盗摄一区二区| 精品国产电影一区二区| 麻豆91在线播放免费| 91精品国产乱| 日本一区中文字幕| 日韩一区二区电影在线| 九色综合国产一区二区三区| 91精品一区二区三区在线观看| 午夜精品成人在线| 91精品国产综合久久精品app| 一区二区三区中文在线观看| 91丨九色丨蝌蚪富婆spa| 亚洲色大成网站www久久九九| 色偷偷一区二区三区| 亚洲蜜臀av乱码久久精品| 欧美特级限制片免费在线观看| 午夜成人在线视频| 久久婷婷一区二区三区| 国产精品99久久久久久久女警| 国产精品美女www爽爽爽| 欧美无砖专区一中文字| 麻豆国产欧美一区二区三区| 国产精品天干天干在线综合| 精品视频在线视频| 国产一区二区伦理片| 亚洲综合在线第一页| 91精品福利在线一区二区三区 | 欧美精品一区二区三区久久久| 国产盗摄视频一区二区三区| 亚洲最大成人网4388xx| 精品处破学生在线二十三| 91欧美激情一区二区三区成人| 天堂久久久久va久久久久| 国产精品乱码一区二三区小蝌蚪| 色综合久久中文综合久久97| 激情亚洲综合在线| 亚洲精品第1页| 亚洲三级在线播放| 国产精品久久免费看| 日韩欧美亚洲一区二区| 色婷婷久久99综合精品jk白丝| 国内精品久久久久影院一蜜桃| 三级欧美在线一区| 亚洲综合一二区| 亚洲国产精品一区二区www在线| 国产精品色哟哟| 国产精品成人在线观看| 国产精品无遮挡| 国产三级精品三级| 国产欧美一区二区精品性色 | 国产在线播精品第三| 精品一区二区三区影院在线午夜| 亚洲国产成人av网| 亚洲午夜一区二区| 日韩精品一二区| 亚洲精品欧美激情| 一区二区三区不卡视频在线观看| 国产精品久久三区| 一区二区三区在线观看国产 | 色哟哟在线观看一区二区三区| 色中色一区二区| 欧美一区二区视频在线观看 | 国产在线不卡一卡二卡三卡四卡| 国产一区不卡视频| av在线播放不卡| 欧美一区二区三区婷婷月色| 久久欧美中文字幕| 亚洲精品乱码久久久久久| 欧美aaa在线| 成人午夜视频免费看| 欧美日韩欧美一区二区| 久久夜色精品一区| 悠悠色在线精品| 国产精品一区二区在线观看网站| 91老司机福利 在线| 2020日本不卡一区二区视频| 亚洲黄网站在线观看| 成人午夜私人影院| 欧美精品一区二区三区一线天视频| 一区二区欧美视频| 国产精品亚洲人在线观看| 日韩一区二区在线观看视频播放| 亚洲精品视频免费观看|