我是靠谱客的博主 典雅吐司,最近开发中收集的这篇文章主要介绍AT89C51单片机 C语言实现坦克大战游戏代码,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

#include "reg51.h"
#include"lcd12864.h"
#include <stdlib.h>

sbit P1_row1 = P1 ^ 0;
sbit P1_row2 = P1 ^ 1;
sbit P1_col1 = P1 ^ 2;
sbit P1_col2 = P1 ^ 3;
sbit P2_row1 = P1 ^ 4;
sbit P2_row2 = P1 ^ 5;
sbit P2_col1 = P1 ^ 6;
sbit P2_col2 = P1 ^ 7;

#define		Up			1													//定义上下左右方向
#define 	Right		2
#define 	Down		3
#define 	Left		4

#define		Up_Left			1												//定义炮弹炸毁效果4个方向(但是由于炮弹的非对称性,导致比如"上左"与"左上"坐标计算有区别)
#define 	Up_Right		2
#define 	Down_Left		3
#define 	Down_Right		4
#define 	Left_Up			5
#define 	Left_Down       6												
#define 	Right_Up		7
#define 	Right_Down		8

#define     Steel			1													//定义障碍物属性
#define     Brick       	2
	
#define		Prefect			1              										//定义基地状态
#define		Destroy			2

#define		Tank_Count		2													//坦克数量
#define		Barrier_Count	8													//障碍物数量

#define	    Computer		1													//坦克的阵营
#define		Human			2							  


uint8 code Human_Tank1_Up[8]	={0xFF,0xFF,0x7C,0x7F,0x7F,0x7C,0xFF,0xFF};			//玩家模型1的上下左右的贴图
uint8 code Human_Tank1_Right[8]	={0xC3,0xFF,0xFF,0xFF,0xFF,0xFF,0xDB,0xDB};
uint8 code Human_Tank1_Down[8]	={0xFF,0xFF,0x3E,0xFE,0xFE,0x3E,0xFF,0xFF};
uint8 code Human_Tank1_Left[8]	={0xDB,0xDB,0xFF,0xFF,0xFF,0xFF,0xFF,0xC3};

uint8 code Human_Tank2_Up[8]		={0xFF,0xCC,0x78,0x3F,0x3F,0x78,0xCC,0xFF};			//玩家模型2的上下左右的贴图
uint8 code Human_Tank2_Right[8]	={0xC3,0xE7,0xBD,0xBD,0xFF,0xDB,0x99,0x99};
uint8 code Human_Tank2_Down[8]	={0xFF,0x33,0x1E,0xFC,0xFC,0x1E,0x33,0xFF};
uint8 code Human_Tank2_Left[8]	={0x99,0x99,0xDB,0xFF,0xBD,0xBD,0xE7,0xC3};

uint8 code Human_Tank3_Up[8]		={0xFF,0xFC,0x70,0x7F,0x7F,0x70,0xFC,0xFF};			//玩家模型3的上下左右的贴图
uint8 code Human_Tank3_Right[8]	={0xC3,0xFF,0xFF,0xFF,0xDB,0xDB,0x99,0x99};
uint8 code Human_Tank3_Down[8]	={0xFF,0x3F,0x0E,0xFE,0xFE,0x0E,0x3F,0xFF};
uint8 code Human_Tank3_Left[8]	={0x99,0x99,0xDB,0xDB,0xFF,0xFF,0xFF,0xC3};

uint8 code Computer_Tank1_Up[8]		={0xFF,0xFC,0xF8,0x43,0x43,0xF8,0xFC,0xFF};			//电脑模型1的上下左右的贴图
uint8 code Computer_Tank1_Right[8]	={0xE7,0xFF,0xE7,0xE7,0xE7,0xC3,0x99,0x99};
uint8 code Computer_Tank1_Down[8]	={0xFF,0x3F,0x1F,0xC2,0xC2,0x1F,0x3F,0xFF};
uint8 code Computer_Tank1_Left[8]	={0x99,0x99,0xC3,0xE7,0xE7,0xE7,0xFF,0xE7};

uint8 code Computer_Tank2_Up[8]		={0xFF,0x62,0x30,0xDF,0xDF,0x30,0x62,0xFF};			//电脑模型2的上下左右的贴图
uint8 code Computer_Tank2_Right[8]	={0x99,0xDB,0xE7,0xBD,0x99,0x99,0xDB,0x99};
uint8 code Computer_Tank2_Down[8]	={0xFF,0x46,0x0C,0xFB,0xFB,0x0C,0x46,0xFF};
uint8 code Computer_Tank2_Left[8]	={0x99,0xDB,0x99,0x99,0xBD,0xE7,0xDB,0x99};

uint8 code Computer_Tank3_Up[8]		={0xE7,0x3C,0xC6,0xF3,0xF3,0xC6,0x3C,0xE7};			//电脑模型3的上下左右的贴图
uint8 code Computer_Tank3_Right[8]	={0xBD,0xBD,0xDB,0x5A,0x42,0xE7,0xBD,0x99};
uint8 code Computer_Tank3_Down[8]	={0xE7,0x3C,0x63,0xCF,0xCF,0x63,0x3C,0xE7};
uint8 code Computer_Tank3_Left[8]	={0x99,0xBD,0xE7,0x42,0x5A,0xDB,0xBD,0xBD};

uint8 code Prefect_Home[8]={0xE7,0xFF,0x99,0x81,0xC3,0x66,0x3C,0x18};					//正常基地的贴图
uint8 code Destroy_Home[8]={0xE7,0xF7,0x05,0xB1,0xCF,0xE7,0xBC,0x3A};					//被摧毁基地的贴图

struct TANK 
{
	uint8 Exist;													//玩家坦克是否存在,1为存在,0为不存在
	uint8 Life;														//剩余坦克的数量
	uint8 Level;													//坦克的级别
	uint8 Camp;														//玩家阵营
	uint8 Position[2];												//坦克的坐标
	uint8 Direction;												//坦克的方向
	uint8 Tank_Bounce_Wall_Flg;                                     //坦克碰壁标志位
	uint8 Tank_Bounce_Tank_Flg;                                     //坦克碰其他坦克标志位
	uint8 Tank_Bounce_Home_Flg;
	uint8 Shot_Position[2];											//炮弹的位置
	uint8 Shot_Direction;											//炮弹的方向
	uint8 Send_Shot_Flg;                                            //发射炮弹标志位
	uint8 Shot_Bounce_Wall_Flg;                                     //炮弹碰壁标志位
	uint8 Shot_Bounce_Tank_Flg;                                     //炮弹碰其他坦克标志位
	uint8 Button__Down_Flg;											//是否有按键按下的标志位
}Tank1,Tank2;

struct  Barrier
{
	uint8   Position[2];											//障碍物的坐标
	uint8   Length;													//障碍物的长度
	uint8   Width;													//障碍物的宽度
	uint8   Property;												//障碍物的材质(砖瓦还是钢铁)									
	uint8  	Exist;													//障碍物的破坏程度(位保存,一个字节可以存储8块)
}Barrier1,Barrier2,Barrier3,Barrier4,Barrier5,Barrier6,Barrier7,Barrier8;



uint8  Time_Flg=0;														//用于时间调整
uint8  xdata Temp_tank1[16];											//存放显示塔克1的数据
uint8  xdata Temp_tank2[16];											//存放显示塔克2的数据
uint8  xdata Temp_data[16];                                             //显示一些临时数据,比如基地贴图 

void Init_Total(void);													//初始化(包括LCD,中断寄存器,计时器,背景等)
void Ar_Intel_Tank(struct TANK *t);										//电脑随机控制坦克函数
void Tank_Wall_Check(struct TANK *t);									//坦克碰壁检测
void Tank_Tank_Check(struct TANK *t);									//坦克碰坦克检测
void Tank_Home_Check(struct TANK *t);									//坦克碰基地检测
void Tank_Advance(struct TANK *t);										//坦克行进函数
void Display_Tank(struct TANK *t,uint8 *temp);							//显示坦克
void Delete_Tank_Tail(struct TANK *t,uint8 *temp);						//去除坦克残像
void Replace_Tank(uint8 num);											//根据编号重置坦克位置数据

void Replace_Shot(struct TANK *t);										//重置炮弹数据
void Shot_Wall_Check(struct TANK *t);									//炮弹碰壁检测函数
void Shot_Tank_Check(struct TANK *t);									//炮弹碰坦克检测函数
void Shot_Shot_Check(struct TANK *t);									//炮弹碰炮弹检测并处理函数
void Shot_Home_Check(struct TANK *t);									//炮弹碰基地检测并处理函数
void Display_Shot(struct TANK *t);										//显示炮弹
void Delete_Shot_Tail(struct TANK *t);									//去除炮弹残像
void Delete_Shot(uint8 shot_direction,uint8 *shot_position);			//无视条件去除炮弹残像
void Shot_Bounce_Wall_Effect(struct TANK *t);						    //炮弹碰壁影响函数
void Shot_Bounce_Tank_Effect(struct TANK *t);						    //炮弹碰坦克影响函数
void Shot_Disappear(uint8 direction,uint8 *shot_position,uint8 *tank_position);//炮弹碰撞物体消失函数
void Shot_Break(uint8 *Shot_Position,uint8 direction );					//炮弹破坏障碍物的效果函数

void Draw_Blackground(void);											//绘制背景
void Draw_Barrier(struct Barrier *b);									//绘制障碍物
void Draw_Home(uint8 state);											//绘制基地
void Draw_Piece_Steel(uint8 x,uint8 y); 								//指定坐标处画铁的贴图
void Draw_Piece_Brick(uint8 x,uint8 y);									//指定坐标处画砖的贴图

void  Copy_Array(uint8 *Desition,uint8 *original,uint8 length);         							//复制数组函数
void  Change_Picture(uint8 Position,uint8 *Desition);         										//贴图转化函数(转化的贴图字节存在*Destion中)

void  Get_Nearest_Barrier(uint8 *position,uint8 direction,uint8 object_length,uint8 object_width,uint8 *num);//查找离被查物最近的障碍物,以障碍物的后边沿为准
uint8 Get_Nearest_Tank(uint8 *position,uint8 direction,uint8 object_length,uint8 object_width);	//查找离被查物最近的坦克,以坦克的前边沿为准	

void  Get_Barrier_Quality (uint8 number,uint8 *position,uint8 *length,uint8 *width);				//获得指定障碍物的坐标值,长度,宽度
void  Get_Tank_Position (uint8 number,uint8 *position);												//获得指定坦克的坐标值
void  Change_Tank_Exist (uint8 number,uint8 *exist);												//更改指定坦克是否存在
void  Get_Tank_Camp (uint8 number,uint8 *camp);														//获得指定坦克的阵营
void  Get_Tank_Life (uint8 number,uint8 *life);														//获得指定坦克的生命
void  Change_Tank_Life (uint8 number,uint8 *life);													//更改指定坦克的生命
void  Get_Tank_Level (uint8 number,uint8 *level);													//获得指定坦克的级别
void  Change_Tank_Level (uint8 number,uint8 *level);												//更改指定坦克的级别
void  Get_Tank_Shot_Quality (uint8 number,uint8 *position,uint8 *direction);						//获得指定坦克炮弹的坐标值,方向
void  Read_Barrier_Exist (uint8 number,uint8 *exist);												//读取障碍物的破坏程度
void  Write_Barrier_Exist (uint8 number,uint8 *exist);												//写入障碍物的破坏程度
void  Get_Barrier_Property (uint8 number,uint8 *property);											//获得障碍物的组成物质



void main()
{   	
	Init_Total();
	while(1)
	{		
		P1_row1=0;P1_row2=0;
		P2_row1=0;P2_row2=0;		
		EX0=1;EX1=1;
		if(Time_Flg%12==10)										//操作坦克1
		{
			//Ar_Intel_Tank(&Tank1);
			if(Tank1.Button__Down_Flg==1&&Tank1.Exist==1)
			{			
				Delete_Tank_Tail(&Tank1,Temp_tank1);
				Tank1.Tank_Bounce_Wall_Flg=0;
				Tank1.Tank_Bounce_Tank_Flg=0;
				Tank1.Tank_Bounce_Home_Flg=0;
				Tank_Wall_Check(&Tank1);
				Tank_Tank_Check(&Tank1);
				Tank_Home_Check(&Tank1);
				if(Tank1.Tank_Bounce_Wall_Flg==0&&Tank1.Tank_Bounce_Tank_Flg==0&&Tank1.Tank_Bounce_Home_Flg==0)
				{
					Tank_Advance(&Tank1);
				}
				Display_Tank(&Tank1,Temp_tank1);
				if(Tank1.Position[0]%2==0&&Tank1.Position[1]%2==0)
				{
					Tank1.Button__Down_Flg=0;					
				}
			}			
		}
		if(Time_Flg%12==1)										//操作坦克2
		{
			Ar_Intel_Tank(&Tank2);
			if(Tank2.Button__Down_Flg==1&&Tank2.Exist==1)
			{						
				Delete_Tank_Tail(&Tank2,Temp_tank2);
				Tank2.Tank_Bounce_Wall_Flg=0;
				Tank2.Tank_Bounce_Tank_Flg=0;
				Tank2.Tank_Bounce_Home_Flg=0;
				Tank_Wall_Check(&Tank2);
				Tank_Tank_Check(&Tank2);
				Tank_Home_Check(&Tank2);
				if(Tank2.Tank_Bounce_Wall_Flg==0&&Tank2.Tank_Bounce_Tank_Flg==0&&Tank2.Tank_Bounce_Home_Flg==0)
				{
					Tank_Advance(&Tank2);
				}
				Display_Tank(&Tank2,Temp_tank2);
				if(Tank2.Position[0]%2==0&&Tank2.Position[1]%2==0)
				{
					Tank2.Button__Down_Flg=0;					
				}
			}
		}
		if(Time_Flg%3==1)													//操作坦克1的炮弹
		{
			if(Tank1.Exist==1)
			{
				if(Tank1.Send_Shot_Flg!=0)
				{
					Shot_Shot_Check(&Tank1);
					Shot_Home_Check(&Tank1);
				}
				if(Tank1.Shot_Bounce_Wall_Flg==1)
				{
					Shot_Bounce_Wall_Effect(&Tank1);
					Tank1.Shot_Bounce_Wall_Flg=0;
				}
				if(Tank1.Shot_Bounce_Tank_Flg==1)
				{
					Shot_Bounce_Tank_Effect(&Tank1);
					Tank1.Shot_Bounce_Tank_Flg=0;
				}
				if(Tank1.Send_Shot_Flg==0)
				{
					 Replace_Shot(&Tank1);
				}
				if(Tank1.Send_Shot_Flg!=0)
				{
					Shot_Wall_Check(&Tank1);
					Shot_Tank_Check(&Tank1);
					Display_Shot(&Tank1);
					Delete_Shot_Tail(&Tank1);
				}
			}
		}
		if(Time_Flg%3==2)													//操作坦克2的炮弹
		{
			if(Tank2.Exist==1)
			{
				if(Tank2.Send_Shot_Flg!=0)
				{
					Shot_Shot_Check(&Tank2);
					Shot_Home_Check(&Tank2);
				}
				if(Tank2.Shot_Bounce_Wall_Flg==1)
				{
					Shot_Bounce_Wall_Effect(&Tank2);
					Tank2.Shot_Bounce_Wall_Flg=0;
				}
				if(Tank2.Shot_Bounce_Tank_Flg==1)
				{
					Shot_Bounce_Tank_Effect(&Tank2);
					Tank2.Shot_Bounce_Tank_Flg=0;
				}
				if(Tank2.Send_Shot_Flg==0)
				{
					 Replace_Shot(&Tank2);
				}
				if(Tank2.Send_Shot_Flg!=0)
				{
					Shot_Wall_Check(&Tank2);
					Shot_Tank_Check(&Tank2);
					Display_Shot(&Tank2);
					Delete_Shot_Tail(&Tank2);
				}
			}
		}
	}	 
}
/* *************************************************************************************************
* Function Name : Init_Total                                                                       *
* Description	: 初始化(包括LCD,中断寄存器,计时器,背景,我方与敌方坦克数据等)   	               *
* Date		    : 09/09/19                                                             	           *
* Parameter     :无                                                        						   *
* Return Code   :无                                                                                *
* Author	    :                                                                 	          	   *
************************************************************************************************* */
void Init_Total(void)																
{
	LCD12864_Init();                               //lcd初始化
	CleanAll();

	EA=1;											//中断初始化
	EX0=1;EX1=1;
	IT0=1;IT1=1;

	TMOD=0X51;										//定时器初始化
	TL0=0XFE;  TL1=0XFF;
  	TH0=0XFD;  TH1=0XFF;
	ET0=1;     ET1=1;

	Tank1.Exist=1;
	Replace_Tank(1);								//坦克数据1初始化
	Tank1.Camp=Human;
	Tank1.Life=50;	

	Tank2.Exist=1;
	Replace_Tank(2);								//坦克数据2初始化
	Tank2.Camp=Computer;
	Tank2.Life=50;

	Barrier1.Position[0]=12;						//障碍物数据初始化
	Barrier1.Position[1]=20;
	Barrier1.Length=8;
	Barrier1.Width=4;
	Barrier1.Property=Brick;
	Barrier1.Exist=0X1F;

	Barrier2.Position[0]=12;
	Barrier2.Position[1]=28;
	Barrier2.Length=8;
	Barrier2.Width=4;
	Barrier2.Property=Brick;
	Barrier2.Exist=0X0F;

	Barrier3.Position[0]=12;
	Barrier3.Position[1]=36;
	Barrier3.Length=8;
	Barrier3.Width=4;
	Barrier3.Property=Brick;
	Barrier3.Exist=0X8F;

	Barrier4.Position[0]=16;
	Barrier4.Position[1]=20;
	Barrier4.Length=8;
	Barrier4.Width=4;
	Barrier4.Property=Brick;
	Barrier4.Exist=0XF1;

	Barrier5.Position[0]=16;
	Barrier5.Position[1]=28;
	Barrier5.Length=8;
	Barrier5.Width=4;
	Barrier5.Property=Brick;
	Barrier5.Exist=0XF0;

	Barrier6.Position[0]=16;
	Barrier6.Position[1]=36;
	Barrier6.Length=8;
	Barrier6.Width=4;
	Barrier6.Property=Brick;
	Barrier6.Exist=0XF8;

	Barrier7.Position[0]=12;					//7号与8号障碍物为基地周围的保护建筑
	Barrier7.Position[1]=56;
	Barrier7.Length=8;
	Barrier7.Width=4;
	Barrier7.Property=Brick;
	Barrier7.Exist=0X2E;

	Barrier8.Position[0]=16;
	Barrier8.Position[1]=56;
	Barrier8.Length=8;
	Barrier8.Width=4;
	Barrier8.Property=Brick;
	Barrier8.Exist=0XE2;

	Draw_Blackground();
	TR0=1;TR1=1;
}
/* *************************************************************************************************
* Function Name :Replace_Tank                                                                	   *
* Description	:根据编号重置坦克位置数据   	               								       *
* Date		    :09/09/20                                                             	           *
* Parameter     :坦克编号                                                     		  			   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Replace_Tank(uint8 num)
{
	switch(num)
	{
		case 1:				
				Tank1.Position[0]=20;							//坦克数据1初始化
				Tank1.Position[1]=60;
				Tank1.Direction=Left;  
				Tank1.Button__Down_Flg=0;
				Tank1.Send_Shot_Flg=0;
				Tank1.Shot_Bounce_Wall_Flg=0;
				Tank1.Level=3;
				break;
		case 2:				
				Tank2.Position[0]=14;							//坦克数据2初始化
				Tank2.Position[1]=0;
				Tank2.Direction=Right;	   
				Tank2.Button__Down_Flg=0;
				Tank2.Send_Shot_Flg=0;
				Tank2.Shot_Bounce_Wall_Flg=0;
				Tank2.Level=3;
				break;				
	}
}											
/* *************************************************************************************************
* Function Name :Draw_Blackground                                                                  *
* Description	:绘制背景   	               											  		   *
* Date		    :09/09/20                                                             	           *
* Parameter     :无                                                      		  				   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Draw_Blackground(void)	
{
	Display_Tank(&Tank1,Temp_tank1);
	Display_Tank(&Tank2,Temp_tank2);
	Draw_Barrier(&Barrier1);
	Draw_Barrier(&Barrier2);
	Draw_Barrier(&Barrier3);
	Draw_Barrier(&Barrier4);
	Draw_Barrier(&Barrier5);
	Draw_Barrier(&Barrier6);
	Draw_Barrier(&Barrier7);
	Draw_Barrier(&Barrier8);
	Draw_Home(Prefect);
}
/* *************************************************************************************************
* Function Name : Draw_Home                                                                  		*
* Description	:绘制基地						   	               					  				*
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Draw_Home(uint8 state)	
{
	uint8 i,j;
	switch(state)
	{
		case	Prefect:Copy_Array(Temp_data,Prefect_Home,8);break;
		case    Destroy:Copy_Array(Temp_data,Destroy_Home,8);break;
	}
	Change_Picture(2,Temp_data);
	for(i=0;i<2;i++)
	{
		for(j=0;j<8;j++)
		{
			Add_Points(3+i,60*2+j,Temp_data[i*8+j]);
		}
	}

}									
/* *************************************************************************************************
* Function Name : Ar_Intel_Tank                                                                    *
* Description	: 电脑随机控制坦克函数						   	               					   *
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */	
void Ar_Intel_Tank(struct TANK *t)
{
	uint8 i;
	i=rand()%256;
	if(i>64)
	{
		t->Button__Down_Flg=1;
	}
	if(i>240)
	{
		t->Send_Shot_Flg=1;
	}
	if(i<40)
	{
		if(t->Position[0]%2==0&&t->Position[1]%2==0)
		{
			i=rand()%256;
			if(t->Position[0]==0)                                      //随机控制坦克方向概率-坦克游戏横坐标为0时,各种方向概率
			{
				if(i<=4)
				{
					t->Direction=Up;
				}
				if(i>4&&i<=192)
				{
					t->Direction=Down;
				}
				if(i>192&&i<=224)
				{
					t->Direction=Left;
				}
				if(i>224)
				{
					t->Direction=Right;
				}
			}
			if(t->Position[0]==28)									//随机控制坦克方向概率-坦克游戏横坐标为28时,各种方向概率
			{
				if(i<=188)
				{
					t->Direction=Up;
				}
				if(i>188&&i<=192)
				{
					t->Direction=Down;
				}
				if(i>192&&i<=224)
				{
					t->Direction=Left;
				}
				if(i>224)
				{
					t->Direction=Right;
				}
			}
			if(t->Position[1]==0)									//随机控制坦克方向概率-坦克游戏纵坐标为0时,各种方向概率
			{
				if(i<=32)
				{
					t->Direction=Up;
				}
				if(i>32&&i<=64)
				{
					t->Direction=Down;
				}
				if(i>64&&i<=68)
				{
					t->Direction=Left;
				}
				if(i>68)
				{
					t->Direction=Right;
				}
			}
			if(t->Position[1]==60)									//随机控制坦克方向概率-坦克游戏纵坐标为60时,各种方向概率
			{
				if(i<=32)
				{
					t->Direction=Up;
				}
				if(i>32&&i<=64)
				{
					t->Direction=Down;
				}
				if(i>64&&i<=252)
				{
					t->Direction=Left;
				}
				if(i>252)
				{
					t->Direction=Right;
				}
			}
			else													//随机控制坦克方向概率-坦克位于中间区域时,各种方向概率
			{
				if(i<=64)
				{
					t->Direction=Up;
				}
				if(i>64&&i<=128)
				{
					t->Direction=Down;
				}
				if(i>128&&i<=192)
				{
					t->Direction=Left;	
				}
				if(i>192)
				{
					t->Direction=Right;
				}
			}
		}
	}
}										
/* *************************************************************************************************
* Function Name : Tank_Wall_Check                                                                  *
* Description	: 坦克碰壁检测						   	               					     	   *
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Tank_Wall_Check(struct TANK *t)													
{
	uint8 barrier_number[2]=0;
	uint8 barrier_position[2];
	uint8 barrier_length=0;
	uint8 barrier_width=0;
	uint8 barrier_exist[2];
	uint8 i,j;
	Get_Nearest_Barrier(t->Position,t->Direction,4,4,barrier_number);	
	switch(t->Direction)
	{
		case Up:
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(t->Position[0]==0)					
				{
					t->Tank_Bounce_Wall_Flg=1;
					return;
				}
				if(barrier_number[1]==0)
				{				
					if(t->Position[0]<=barrier_position[0]+barrier_width)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Position[1]==barrier_position[1]+barrier_length*j-2&&t->Position[0]==barrier_position[0]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j*(barrier_length/2-1)))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;										
									}
								}
							}
						}
						if(barrier_length<4)
						{
							return;
						}
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<1+(barrier_length-4)/2;j++)
							{
								if(t->Position[1]==barrier_position[1]+j*2&&t->Position[0]==barrier_position[0]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{					
					if(t->Position[0]<=barrier_position[0]+barrier_width)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_width/2;i++)
						{
							if(t->Position[0]==barrier_position[0]+2+i*2)
							{
								if(t->Position[1]>barrier_position[1])
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[1]&1<<((barrier_length/2)*i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}	
					}
				}
				break;
		case Down:
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(t->Position[0]==28)
				{
					t->Tank_Bounce_Wall_Flg=1;
					return;
				}
				if(barrier_number[1]==0)
				{				
					if(t->Position[0]>=barrier_position[0]-4)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Position[1]==barrier_position[1]+barrier_length*j-2&&t->Position[0]==barrier_position[0]-4+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j*(barrier_length/2-1)))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
						if(barrier_length<4)
						{
							return;
						}
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<1+(barrier_length-4)/2;j++)
							{
								if(t->Position[1]==barrier_position[1]+j*2&&t->Position[0]==barrier_position[0]-4+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{					
					if(t->Position[0]>=barrier_position[0]-4)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_width/2;i++)
						{
							if(t->Position[0]==barrier_position[0]-4+i*2)
							{
								if(t->Position[1]>barrier_position[1])
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[1]&1<<((barrier_length/2)*i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}	
					}
				}
				break;
		case Left:
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(t->Position[1]==0)
				{
					t->Tank_Bounce_Wall_Flg=1;
					return;
				}
				if(barrier_number[1]==0)
				{
				    if(t->Position[1]<=barrier_position[1]+barrier_length)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Position[0]==barrier_position[0]+barrier_width*j-2&&t->Position[1]==barrier_position[1]+2+i*2)
								{
									if((barrier_exist[0]&1<<(j*(barrier_length/2)*(barrier_width/2-1)+i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
						if(barrier_width<4)
						{
							return;
						}
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<1+(barrier_width-4)/2;j++)
							{
								if(t->Position[0]==barrier_position[0]+j*2&&t->Position[1]==barrier_position[1]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0||(barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{
					if(t->Position[1]<=barrier_position[1]+barrier_length)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_length/2;i++)
						{
							if(t->Position[1]==barrier_position[1]+2+i*2)
							{
								if(t->Position[0]<barrier_position[0])
								{
									if((barrier_exist[0]&1<<i)!=0||(barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<i)!=0||(barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}	
					}
				}
				break;	
		case Right:
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(t->Position[1]==60)
				{
					t->Tank_Bounce_Wall_Flg=1;
					return;
				}
				if(barrier_number[1]==0)
				{
				    if(t->Position[1]>=barrier_position[1]-4)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Position[0]==barrier_position[0]+barrier_width*j-2&&t->Position[1]==barrier_position[1]-4+i*2)
								{
									if((barrier_exist[0]&1<<(j*(barrier_length/2)*(barrier_width/2-1)+i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
						if(barrier_width<4)
						{
							return;
						}
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<1+(barrier_width-4)/2;j++)
							{
								if(t->Position[0]==barrier_position[0]+j*2&&t->Position[1]==barrier_position[1]-4+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0||(barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{
					if(t->Position[1]>=barrier_position[1]-4)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_length/2;i++)
						{
							if(t->Position[1]==barrier_position[1]-4+i*2)
							{
								if(t->Position[0]<barrier_position[0])
								{
									if((barrier_exist[0]&1<<i)!=0||(barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<i)!=0||(barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Tank_Bounce_Wall_Flg=1;
										return;
									}
								}
							}
						}	
					}
				}
				break;	
	}
}
/* ************************************************************************************************
* Function Name : Tank_Tank_Check                                                                  *
* Description	: 坦克碰坦克检测   	               											   	   *
* Date		    : 09/10/1                                                             	           *
* Parameter     : 指向坦克结构体的指针                                                      	   *
* Return Code   : 无                                                                               *
* Author	    :                                                                	       *
************************************************************************************************* */
void Tank_Tank_Check(struct TANK *t)
{
	uint8  tank_number=0;
	uint8  tank_position[2];
	switch(t->Direction)
	{
		case Up:
				tank_number=Get_Nearest_Tank(t->Position,t->Direction,4,4);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Position[0]==tank_position[0]+4)
				{
					t->Tank_Bounce_Tank_Flg=1;
					return;
				}
				break;
		case Down:
				tank_number=Get_Nearest_Tank(t->Position,t->Direction,4,4);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Position[0]+4==tank_position[0])
				{
					t->Tank_Bounce_Tank_Flg=1;
					return;
				}
				break;
		case Left:
				tank_number=Get_Nearest_Tank(t->Position,t->Direction,4,4);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Position[1]==tank_position[1]+4)
				{
					t->Tank_Bounce_Tank_Flg=1;
					return;
				}
				break;
		case Right:
				tank_number=Get_Nearest_Tank(t->Position,t->Direction,4,4);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Position[1]+4==tank_position[1])
				{
					t->Tank_Bounce_Tank_Flg=1;
					return;
				}
				break;
	}
}
/* ************************************************************************************************
* Function Name : Tank_Home_Check                                                                  *
* Description	: 坦克碰基地检测   	               											   	   *
* Date		    : 09/10/2                                                             	           *
* Parameter     : 指向坦克结构体的指针                                                      	   *
* Return Code   : 无                                                                               *
* Author	    :                                                                	       *
************************************************************************************************* */
void Tank_Home_Check(struct TANK *t)
{
	switch(t->Direction)
	{
		case Up:
				if(t->Position[1]+4>60&&t->Position[0]==18)
				{
					t->Tank_Bounce_Home_Flg=1;
				}
				break;
		case Down:
				if(t->Position[1]+4>60&&t->Position[0]+4==14)
				{
					t->Tank_Bounce_Home_Flg=1;
				}
				break;
		case Right:
				if(t->Position[0]+4>14&&t->Position[0]<18&&t->Position[1]+4==60)
				{
					t->Tank_Bounce_Home_Flg=1;
				}
				break;
	}
}
/* ************************************************************************************************
* Function Name : Tank_Advance                                                                     *
* Description	: 坦克行进函数   	               											   	   *
* Date		    : 09/10/1                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Tank_Advance(struct TANK *t)
{
	switch(t->Direction)
	{
		case Up:	t->Position[0]--;break;
		case Down:	t->Position[0]++;break;
		case Left:	t->Position[1]--;break;
		case Right:	t->Position[1]++;break;
	}
}																			
/* ************************************************************************************************
* Function Name : Display_Tank                                                                     *
* Description	: 显示坦克   	               											   		   *
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                                	       *
************************************************************************************************* */
void Display_Tank(struct TANK *t,uint8 *temp)													
{
	uint8 i=0;
	uint8 j=0;
	if(t->Level==1&&t->Camp==Human)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Human_Tank1_Up,8);break;
			case Left: Copy_Array(temp,Human_Tank1_Left,8);break;
			case Down: Copy_Array(temp,Human_Tank1_Down,8);break;
			case Right:Copy_Array(temp,Human_Tank1_Right,8);break;
		}
	}
	if(t->Level==2&&t->Camp==Human)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Human_Tank2_Up,8);break;
			case Left: Copy_Array(temp,Human_Tank2_Left,8);break;
			case Down: Copy_Array(temp,Human_Tank2_Down,8);break;
			case Right:Copy_Array(temp,Human_Tank2_Right,8);break;
		}
	}
	if(t->Level==3&&t->Camp==Human)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Human_Tank3_Up,8);break;
			case Left: Copy_Array(temp,Human_Tank3_Left,8);break;
			case Down: Copy_Array(temp,Human_Tank3_Down,8);break;
			case Right:Copy_Array(temp,Human_Tank3_Right,8);break;
		}
	}
	if(t->Level==1&&t->Camp==Computer)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Computer_Tank1_Up,8);break;
			case Left: Copy_Array(temp,Computer_Tank1_Left,8);break;
			case Down: Copy_Array(temp,Computer_Tank1_Down,8);break;
			case Right:Copy_Array(temp,Computer_Tank1_Right,8);break;
		}
	}
	if(t->Level==2&&t->Camp==Computer)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Computer_Tank2_Up,8);break;
			case Left: Copy_Array(temp,Computer_Tank2_Left,8);break;
			case Down: Copy_Array(temp,Computer_Tank2_Down,8);break;
			case Right:Copy_Array(temp,Computer_Tank2_Right,8);break;
		}
	}
	if(t->Level==3&&t->Camp==Computer)
	{
		switch(t->Direction)
		{
			case Up:   Copy_Array(temp,Computer_Tank3_Up,8);break;
			case Left: Copy_Array(temp,Computer_Tank3_Left,8);break;
			case Down: Copy_Array(temp,Computer_Tank3_Down,8);break;
			case Right:Copy_Array(temp,Computer_Tank3_Right,8);break;
		}
	}
	Change_Picture(t->Position[0]%4,temp);
	if(t->Position[0]!=28||t->Position[0]%4!=0)
	{
		for(i=0;i<2;i++)
		{
			for(j=0;j<8;j++)
			{
				Add_Points(t->Position[0]/4+i,t->Position[1]*2+j,temp[i*8+j]);
			}
		}
	}else
	for(j=0;j<8;j++)
	{
		Add_Points(t->Position[0]/4,t->Position[1]*2+j,temp[j]);
	}


}
/* *************************************************************************************************
* Function Name :Delete_Tank_Tail                                                                  *
* Description	:去除坦克残像  	               											   		   *
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向坦克结构体的指针                                                      		   *
* Return Code   :无                                                                                *
* Author	    :                                                               	       	   *
************************************************************************************************* */
void Delete_Tank_Tail(struct TANK *t,uint8 *temp)								
{
	uint8 i=0;
	uint8 j=0;
	if(t->Position[0]!=28||t->Position[0]%4!=0)
	{
		for(i=0;i<2;i++)
		{
			for(j=0;j<8;j++)
			{
				Reduce_Points(t->Position[0]/4+i,t->Position[1]*2+j,temp[i*8+j]);
			}
		}
	}else
	for(j=0;j<8;j++)
	{
		Reduce_Points(t->Position[0]/4,t->Position[1]*2+j,temp[j]);
	}
}
/* *************************************************************************************************
* Function Name :Replace_Shot                                                                      *
* Description	:初始化炮弹数据  	               											   	   *
* Date		    : 09/09/25                                                             	       	   *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Replace_Shot(struct TANK *t)
{
	switch(t->Direction)
	{
		case Up:
				t->Shot_Position[0]=t->Position[0]+1;
				t->Shot_Position[1]=t->Position[1]+1;
				break;
		 case Down:
		 		t->Shot_Position[0]=t->Position[0]+2;
				t->Shot_Position[1]=t->Position[1]+1;
				break;
		case Left:
				t->Shot_Position[0]=t->Position[0]+1;
				t->Shot_Position[1]=t->Position[1]+1;
				break;
		case Right:
				t->Shot_Position[0]=t->Position[0]+1;
				t->Shot_Position[1]=t->Position[1]+2;
				break;
	}
	t->Shot_Direction=t->Direction;
}										
/* *************************************************************************************************
* Function Name :Shot_Wall_Check                                                                   *
* Description	:炮弹碰壁检测函数  	               											   	   *
* Date		    : 09/09/22.23                                                             	       *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Shot_Wall_Check(struct TANK *t)
{
	uint8 barrier_number[2]=0;
	uint8 barrier_exist[2]=0xff;
	uint8 barrier_position[2];
	uint8 barrier_length=0;
	uint8 barrier_width=0;
	uint8 i,j;
	switch(t->Shot_Direction)
	{
		case Up:
				if(t->Shot_Position[0]==0)
				{
						t->Shot_Bounce_Wall_Flg=1;
						t->Send_Shot_Flg=0;
						return;
				}
				Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,2,1,barrier_number);
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(barrier_number[1]==0)
				{
				    if(t->Shot_Position[0]<=barrier_position[0]+barrier_width)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+barrier_length*j-1&&t->Shot_Position[0]==barrier_position[0]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j*(barrier_length/2-1)))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
						if(barrier_length<4)
						{
							t->Shot_Position[0]--;
							return;
						}
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<1+(barrier_length-4)/2;j++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+j*2+1&&t->Shot_Position[0]==barrier_position[0]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{
					if(t->Shot_Position[0]<=barrier_position[0]+barrier_width)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_width/2;i++)
						{
							if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
							{
								if(t->Shot_Position[1]>barrier_position[1])
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[1]&1<<((barrier_length/2)*i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}	
					}
				}t->Shot_Position[0]--;
				break;
		case Left:
				if(t->Shot_Position[1]==0)
				{
						t->Shot_Bounce_Wall_Flg=1;
						t->Send_Shot_Flg=0;
						return;
				}
				Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,1,2,barrier_number);
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(barrier_number[1]==0)
				{					
				    if(t->Shot_Position[1]<=barrier_position[1]+barrier_length)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+barrier_width*j-1&&t->Shot_Position[1]==barrier_position[1]+2+i*2)
								{
									if((barrier_exist[0]&1<<(j*(barrier_length/2)*(barrier_width/2-1)+i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
						if(barrier_width<4)
						{
							t->Shot_Position[1]--;
							return;
						}
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<1+(barrier_width-4)/2;j++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+j*2+1&&t->Shot_Position[1]==barrier_position[1]+2+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0||(barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{					
					if(t->Shot_Position[1]<=barrier_position[1]+barrier_length)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_length/2;i++)
						{
							if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
							{
								if(t->Shot_Position[0]<barrier_position[0])
								{
									if((barrier_exist[0]&1<<i)!=0||(barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<i)!=0||(barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}	
					}
				}t->Shot_Position[1]--;
				break;	
		case Right:
				if(t->Shot_Position[1]==63)
				{
						t->Shot_Bounce_Wall_Flg=1;
						t->Send_Shot_Flg=0;
						return;
				}
				Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,1,2,barrier_number);
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(barrier_number[1]==0)
				{					
				    if(t->Shot_Position[1]>=barrier_position[1]-1)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+barrier_width*j-1&&t->Shot_Position[1]==barrier_position[1]-1+i*2)
								{
									if((barrier_exist[0]&1<<(j*(barrier_length/2)*(barrier_width/2-1)+i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
						if(barrier_width<4)
						{
							t->Shot_Position[1]++;
							return;
						}
						for(i=0;i<barrier_length/2;i++)
						{
							for(j=0;j<1+(barrier_width-4)/2;j++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+j*2+1&&t->Shot_Position[1]==barrier_position[1]-1+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0||(barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{
					if(t->Shot_Position[1]>=barrier_position[1]-1)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_length/2;i++)
						{
							if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
							{
								if(t->Shot_Position[0]<barrier_position[0])
								{
									if((barrier_exist[0]&1<<i)!=0||(barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<i)!=0||(barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}	
					}
				}t->Shot_Position[1]++;
				break;
		case Down:
				if(t->Shot_Position[0]==31)
				{
						t->Shot_Bounce_Wall_Flg=1;
						t->Send_Shot_Flg=0;
						return;
				}
				Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,2,1,barrier_number);
				Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
				if(barrier_number[1]==0)
				{					
				    if(t->Shot_Position[0]>=barrier_position[0]-1)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<2;j++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+barrier_length*j-1&&t->Shot_Position[0]==barrier_position[0]-1+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j*(barrier_length/2-1)))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
						if(barrier_length<4)
						{
							t->Shot_Position[0]++;
							return;
						}
						for(i=0;i<barrier_width/2;i++)
						{
							for(j=0;j<1+(barrier_length-4)/2;j++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+j*2+1&&t->Shot_Position[0]==barrier_position[0]-1+i*2)
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
					}
				}
				if(barrier_number[1]!=0)
				{
					if(t->Shot_Position[0]>=barrier_position[0]-1)
					{
						Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
						Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
						for(i=0;i<barrier_width/2;i++)
						{
							if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
							{
								if(t->Shot_Position[1]>barrier_position[1])
								{
									if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[1]&1<<((barrier_length/2)*i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}else
								{
									if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0||(barrier_exist[0]&1<<((barrier_length/2)*i))!=0)
									{
										t->Shot_Bounce_Wall_Flg=1;
										t->Send_Shot_Flg=0;
										return;
									}
								}
							}
						}
					}
				}t->Shot_Position[0]++;
				break;	
	}
}
/* *************************************************************************************************
* Function Name :Shot_Tank_Check                                                                   *
* Description	:炮弹碰坦克检测函数  	               											   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Shot_Tank_Check(struct TANK *t)
{
	uint8  tank_number=0;
	uint8  tank_position[2];
	switch(t->Shot_Direction)
	{
		case Up:
				tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,2,1);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Shot_Position[0]==tank_position[0]+4)
				{
					t->Shot_Bounce_Tank_Flg=1;
					t->Send_Shot_Flg=0;
					return;
				}
				break;
		case Down:
				tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,2,1);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Shot_Position[0]==tank_position[0]-1)
				{
					t->Shot_Bounce_Tank_Flg=1;
					t->Send_Shot_Flg=0;
					return;
				}
				break;
		case Left:
				tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,1,2);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Shot_Position[1]==tank_position[1]+4)
				{
					t->Shot_Bounce_Tank_Flg=1;
					t->Send_Shot_Flg=0;
					return;
				}
				break;
		case Right:
				tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,1,2);
				Get_Tank_Position(tank_number,tank_position);
				if(tank_number!=0&&t->Shot_Position[1]==tank_position[1]-1)
				{
					t->Shot_Bounce_Tank_Flg=1;
					t->Send_Shot_Flg=0;
					return;
				}
				break;
	}
}
/* *************************************************************************************************
* Function Name :Shot_Shot_Check                                                                   *
* Description	:炮弹碰炮弹检测并处理函数  	               									   		*
* Date		    : 09/10/1                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Shot_Shot_Check(struct TANK *t)
{
	uint8 shot_position[2];
	uint8 shot_direction;
	uint8 i;
	uint8 j=0;
	uint8 tank_number=0;
	for(i=1;i<Tank_Count+1;i++)
	{
		if( (i==1&&Tank1.Exist==1) ||(i==2&&Tank2.Exist==1) )
		{
			Get_Tank_Shot_Quality (i,shot_position,&shot_direction);
			switch(t->Shot_Direction)
			{
				case Up:
						if(shot_direction==Down)
						{
							if(t->Shot_Position[1]==shot_position[1]&&t->Shot_Position[0]==shot_position[0]+1)
							{
								j=1;tank_number=i;
							}
						}
						if(shot_direction==Left||shot_direction==Right)
						{
							if((t->Shot_Position[1]==shot_position[1]-1||t->Shot_Position[1]==shot_position[1])&&t->Shot_Position[0]==shot_position[0]+1)
							{
								j=1;tank_number=i;
							}
						}
						break;
				case Down:
						if(shot_direction==Up)
						{
							if(t->Shot_Position[1]==shot_position[1]&&t->Shot_Position[0]==shot_position[0]-1)
							{
								j=1;tank_number=i;
							}
						}
						if(shot_direction==Left||shot_direction==Right)
						{
							if((t->Shot_Position[1]==shot_position[1]-1||t->Shot_Position[1]==shot_position[1])&&t->Shot_Position[0]==shot_position[0])
							{
								j=1;tank_number=i;
							}
						}		
				case Left:
						if(shot_direction==Right)
						{
							if(t->Shot_Position[1]==shot_position[1]+1&&t->Shot_Position[0]==shot_position[0])
							{
								j=1;tank_number=i;
							}
						}
						if(shot_direction==Up||shot_direction==Down)
						{
							if(t->Shot_Position[1]==shot_position[1]+1&&(t->Shot_Position[0]==shot_position[0]||t->Shot_Position[0]==shot_position[0]-1))
							{
								j=1;tank_number=i;
							}
						}
						break;
				case Right:
						if(shot_direction==Left)
						{
							if(t->Shot_Position[1]==shot_position[1]-1&&t->Shot_Position[0]==shot_position[0])
							{
								j=1;tank_number=i;
							}
						}
						if(shot_direction==Up||shot_direction==Down)
						{
							if(t->Shot_Position[1]==shot_position[1]&&(t->Shot_Position[0]==shot_position[0]||t->Shot_Position[0]==shot_position[0]-1))
							{
								j=1;tank_number=i;
							}
						}
						break;					
						
			}
			if(j==1)
			{
				t->Send_Shot_Flg=0;
				Delete_Shot(t->Shot_Direction,t->Shot_Position);
				switch(tank_number)
				{
					case 1:Delete_Shot(Tank1.Shot_Direction,Tank1.Shot_Position);Tank1.Send_Shot_Flg=0;break;
					case 2:Delete_Shot(Tank2.Shot_Direction,Tank2.Shot_Position);Tank2.Send_Shot_Flg=0;break;
				}
			}
		}
	}
	
}	
/* *************************************************************************************************
* Function Name :Shot_Home_Check                                                                   *
* Description	:炮弹碰基地检测并处理函数  	               									   		*
* Date		    : 09/10/2                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Shot_Home_Check(struct TANK *t)
{
	uint8 j=0;
	switch(t->Shot_Direction)
	{
		case Up:
				if(t->Shot_Position[1]>58-1&&t->Shot_Position[0]==18)
				{
					j=1;
				}
				break;
		case Down:
				if(t->Shot_Position[1]>58-1&&t->Shot_Position[0]==13)
				{
					j=1;
				}
				break;
			case Right:
				if(t->Shot_Position[0]>=13&&t->Shot_Position[0]<=18&&t->Shot_Position[1]==59)
				{
					j=1;
				}
				break;
	}
	if(j==1)
	{
		t->Send_Shot_Flg=0;
		Delete_Shot(t->Shot_Direction,t->Shot_Position);		
	}
}															
/* *************************************************************************************************
* Function Name :Display_Shot                                                                  	   *
* Description	:显示炮弹  	               											   	   		   *
* Date		    : 09/09/24                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Display_Shot(struct TANK *t)
{
	if(t->Shot_Direction==Left||t->Shot_Direction==Right)
	{
		Creat_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2);
		Creat_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2+1);
		Creat_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2);
		Creat_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2+1);
 	}
	if(t->Shot_Direction==Up||t->Shot_Direction==Down)
	{
		Creat_Point((t->Shot_Position[0]*2),t->Shot_Position[1]*2+1);
		Creat_Point((t->Shot_Position[0]*2),t->Shot_Position[1]*2+2);
		Creat_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2+1);
		Creat_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2+2);
	}	
}
/* *************************************************************************************************
* Function Name :Delete_Shot_Tail                                                                  *
* Description	:去除炮弹残像  	               											   	   	   *
* Date		    : 09/09/24                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Delete_Shot_Tail(struct TANK *t)
{
	switch(t->Shot_Direction)
	{
		case	Right:
				if(t->Shot_Position[1]>t->Position[1]+4)
				{
					Delete_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2-2);
					Delete_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2-1);
					Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2-2);
					Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2-1);
				}
			break;
		case	Down:
				if(t->Shot_Position[0]>t->Position[0]+4)
				{
					Delete_Point((t->Shot_Position[0]*2)-2,t->Shot_Position[1]*2+1);
					Delete_Point((t->Shot_Position[0]*2)-2,t->Shot_Position[1]*2+2);
					Delete_Point((t->Shot_Position[0]*2)-1,t->Shot_Position[1]*2+1);
					Delete_Point((t->Shot_Position[0]*2)-1,t->Shot_Position[1]*2+2);
				}
			break;
		case	Up:
				if(t->Shot_Position[0]<t->Position[0]-1)
				{
					if(t->Position[0]!=0)
					{
						Delete_Point((t->Shot_Position[0]*2)+3,t->Shot_Position[1]*2+1);
						Delete_Point((t->Shot_Position[0]*2)+3,t->Shot_Position[1]*2+2);
						Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2+1);
						Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2+2);
					}
				}
			break;
		 case	Left:
		 		if(t->Shot_Position[1]<t->Position[1]-1)
				{
					if(t->Position[1]!=0)
					{
		 				Delete_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2+2);
						Delete_Point((t->Shot_Position[0]*2)+1,t->Shot_Position[1]*2+3);
						Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2+2);
						Delete_Point((t->Shot_Position[0]*2)+2,t->Shot_Position[1]*2+3);
					}
				}
			break;			
	}		
}
/* *************************************************************************************************
* Function Name :Delete_Shot                                                                 		*
* Description	:无视条件去除炮弹残像  	               											   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :指向坦克结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Delete_Shot(uint8 shot_direction,uint8 *shot_position)
{
	if(shot_direction==Left||shot_direction==Right)
	{
		Delete_Point(((*shot_position)*2)+1,(*(shot_position+1))*2);
		Delete_Point(((*shot_position)*2)+1,(*(shot_position+1))*2+1);
		Delete_Point(((*shot_position)*2)+2,(*(shot_position+1))*2);
		Delete_Point(((*shot_position)*2)+2,(*(shot_position+1))*2+1);
 	}
	if(shot_direction==Up||shot_direction==Down)
	{
		Delete_Point(((*shot_position)*2),(*(shot_position+1))*2+1);
		Delete_Point(((*shot_position)*2),(*(shot_position+1))*2+2);
		Delete_Point(((*shot_position)*2)+1,(*(shot_position+1))*2+1);
		Delete_Point(((*shot_position)*2)+1,(*(shot_position+1))*2+2);
	}			
}										
/** *************************************************************************************************
* Function Name :Shot_Effect                                                                  		*
* Description	:炮弹碰壁影响函数	               										            *
* Date		    : 09/09/25                                                             	            *
* Parameter     :指向坦克结构体的指针                                							    *
* Return Code   :无                                                                                 *
* Author	    :                                                               	            *
************************************************************************************************* */
void Shot_Bounce_Wall_Effect(struct TANK *t)
{
	uint8  barrier_number[2]=0;
	uint8  barrier_exist[2];
	uint8  barrier_position[2];
	uint8  barrier_length=0;
	uint8  barrier_width=0;
	uint8  barrier_property=0;
	uint8  xdata i, xdata j;
	Shot_Disappear(t->Shot_Direction,t->Shot_Position,t->Position);
	switch(t->Shot_Direction)
	{
		case Up:
				if(t->Position[0]>0)
				{
					Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,2,1,barrier_number);
					Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
					Get_Barrier_Property(barrier_number[0],&barrier_property);
					Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
					Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
					if(barrier_number[1]==0&&barrier_property==Brick)
					{						
						if(t->Shot_Position[1]<barrier_position[1])
						{
							Shot_Break(t->Shot_Position,Up_Right);
							for(i=0;i<barrier_width/2;i++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<(barrier_length/2)*i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else if(t->Shot_Position[1]==barrier_position[1]+barrier_length-1)
						{
							Shot_Break(t->Shot_Position,Up_Left);
							for(i=0;i<barrier_width/2;i++)
							{
								if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<(barrier_length/2)*i+(barrier_length/2)-1);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else						
						{				
							for(i=0;i<barrier_width/2;i++)
							{
								for(j=0;j<1+(barrier_length-4)/2;j++)
								{
									if(t->Shot_Position[1]==barrier_position[1]+j*2+1&&t->Shot_Position[0]==barrier_position[0]+2+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0)
										{
											Shot_Break(t->Shot_Position,Up_Left);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+j));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
										if((barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
										{
											Shot_Break(t->Shot_Position,Up_Right);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+j+1));										
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
						}
					}
					if(barrier_number[1]!=0)
					{
						if(t->Shot_Position[1]>barrier_position[1])
						{
							if(barrier_property==Brick)
							{							
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0)
										{
											Shot_Break(t->Shot_Position,Up_Left);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+(barrier_length/2-1)));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
									{
										if((barrier_exist[1]&1<<((barrier_length/2)*i))!=0)	
										{
											Shot_Break(t->Shot_Position,Up_Right);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_length/2)*i));
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
						else
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
									{
										if((barrier_exist[0]&1<<((barrier_length/2)*i))!=0)	
										{
											Shot_Break(t->Shot_Position,Up_Right);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]+2+i*2)
									{	if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0)
										{
											Shot_Break(t->Shot_Position,Up_Left);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_length/2)*i+(barrier_length/2-1)));
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
					}						
				}break;
		case Down:
				if(t->Position[0]<31)
				{
					Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,2,1,barrier_number);
					Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
					Get_Barrier_Property(barrier_number[0],&barrier_property);
					Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
					Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
					if(barrier_number[1]==0&&barrier_property==Brick)
					{						
						if(t->Shot_Position[1]<barrier_position[1])
						{
							Shot_Break(t->Shot_Position,Down_Right);
							for(i=0;i<barrier_width/2;i++)
							{
								if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<(barrier_length/2)*i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else if(t->Shot_Position[1]==barrier_position[1]+barrier_length-1)
						{
							Shot_Break(t->Shot_Position,Down_Left);
							for(i=0;i<barrier_width/2;i++)
							{
								if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<(barrier_length/2)*i+(barrier_length/2)-1);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else
						{
							for(i=0;i<barrier_width/2;i++)
							{
								for(j=0;j<1+(barrier_length-4)/2;j++)
								{
									if(t->Shot_Position[1]==barrier_position[1]+j*2+1&&t->Shot_Position[0]==barrier_position[0]-1+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_length/2)*i+j))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Left);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+j));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
										if((barrier_exist[0]&1<<((barrier_length/2)*i+j+1))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Right);											
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+j+1));										
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
						}
					}
					if(barrier_number[1]!=0)
					{
						if(t->Shot_Position[1]>barrier_position[1])
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
									{
										if((barrier_exist[0]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Left);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i+(barrier_length/2-1)));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
									{
										if((barrier_exist[1]&1<<((barrier_length/2)*i))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Right);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_length/2)*i));
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
						else
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
									{
										if((barrier_exist[0]&1<<((barrier_length/2)*i))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Right);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*i));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_width/2;i++)
								{	
									if(t->Shot_Position[0]==barrier_position[0]-1+i*2)
									{	
										if((barrier_exist[1]&1<<((barrier_length/2)*i+(barrier_length/2-1)))!=0)
										{
											Shot_Break(t->Shot_Position,Down_Left);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_length/2)*i+(barrier_length/2-1)));
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
					}						
				}break;
		case Left:
				if(t->Position[1]>0)
				{
					Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,1,2,barrier_number);
					Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
					Get_Barrier_Property(barrier_number[0],&barrier_property);
					Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
					Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
					if(barrier_number[1]==0&&barrier_property==Brick)
					{						
						if(t->Shot_Position[0]<barrier_position[0])
						{
							Shot_Break(t->Shot_Position,Left_Down);
							for(i=0;i<barrier_length/2;i++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else if(t->Shot_Position[0]==barrier_position[0]+barrier_width-1)
						{
							Shot_Break(t->Shot_Position,Left_Up);
							for(i=0;i<barrier_length/2;i++)
							{
								if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else
						{						
							for(i=0;i<barrier_length/2;i++)
							{
								for(j=0;j<1+(barrier_width-4)/2;j++)
								{
									if(t->Shot_Position[0]==barrier_position[0]+j*2+1&&t->Shot_Position[1]==barrier_position[1]+2+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
										{
											Shot_Break(t->Shot_Position,Left_Down);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*(j+1)+i));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
										if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0)
										{
											Shot_Break(t->Shot_Position,Left_Up);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*j+i));										
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
						}
					}
					if(barrier_number[1]!=0)
					{
						if(t->Shot_Position[0]<barrier_position[0])
						{
							if(barrier_property==Brick)
							{
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
									{	
										if((barrier_exist[0]&1<<i)!=0)
										{
											Shot_Break(t->Shot_Position,Left_Down);
											barrier_exist[0]=~(~barrier_exist[0]|1<<i);
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
									{	
										if((barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
										{
											Shot_Break(t->Shot_Position,Left_Up);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
						else
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
									{
										if((barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
										{
											Shot_Break(t->Shot_Position,Left_Up);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]+2+i*2)
									{	
										if((barrier_exist[1]&1<<i)!=0)
										{
											Shot_Break(t->Shot_Position,Left_Down);
											barrier_exist[1]=~(~barrier_exist[1]|1<<i);
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
					}						
				}break;
		case Right:
				if(t->Position[1]<63)
				{
					Get_Nearest_Barrier(t->Shot_Position,t->Shot_Direction,1,2,barrier_number);
					Get_Barrier_Quality(barrier_number[0],barrier_position,&barrier_length,&barrier_width);
					Get_Barrier_Property(barrier_number[0],&barrier_property);
					Read_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
					Read_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
					if(barrier_number[1]==0&&barrier_property==Brick)
					{						
						if(t->Shot_Position[0]<barrier_position[0])
						{
							Shot_Break(t->Shot_Position,Right_Down);
							for(i=0;i<barrier_length/2;i++)
							{
								if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else if(t->Shot_Position[0]==barrier_position[0]+barrier_width-1)
						{
							Shot_Break(t->Shot_Position,Right_Up);
							for(i=0;i<barrier_length/2;i++)
							{
								if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
								{
									barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
									Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
								}
							}
						}else
						{							
							for(i=0;i<barrier_length/2;i++)
							{
								for(j=0;j<1+(barrier_width-4)/2;j++)
								{
									if(t->Shot_Position[0]==barrier_position[0]+j*2+1&&t->Shot_Position[1]==barrier_position[1]-1+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_length/2)*(j+1)+i))!=0)
										{
											Shot_Break(t->Shot_Position,Right_Down);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*(j+1)+i));
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
										if((barrier_exist[0]&1<<((barrier_length/2)*j+i))!=0)
										{
											Shot_Break(t->Shot_Position,Right_Up);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_length/2)*j+i));										
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
						}
					}
					if(barrier_number[1]!=0)
					{
						if(t->Shot_Position[0]<barrier_position[0])
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
									{
										if((barrier_exist[0]&1<<i)!=0)
										{
											Shot_Break(t->Shot_Position,Right_Down);
											barrier_exist[0]=~(~barrier_exist[0]|1<<i);
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
									{	
										if((barrier_exist[1]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
										{
											Shot_Break(t->Shot_Position,Right_Up);
											barrier_exist[1]=~(~barrier_exist[1]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
						else
						{
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
									{	
										if((barrier_exist[0]&1<<((barrier_width/2)-1)*(barrier_length/2)+i)!=0)
										{
											Shot_Break(t->Shot_Position,Right_Up);
											barrier_exist[0]=~(~barrier_exist[0]|1<<((barrier_width/2)-1)*(barrier_length/2)+i);
											Write_Barrier_Exist(barrier_number[0],&barrier_exist[0]);
										}
									}
								}
							}
							Get_Barrier_Quality(barrier_number[1],barrier_position,&barrier_length,&barrier_width);
							Get_Barrier_Property(barrier_number[1],&barrier_property);
							if(barrier_property==Brick)
							{								
								for(i=0;i<barrier_length/2;i++)
								{	
									if(t->Shot_Position[1]==barrier_position[1]-1+i*2)
									{	
										if((barrier_exist[1]&1<<i)!=0)
										{
											Shot_Break(t->Shot_Position,Right_Down);
											barrier_exist[1]=~(~barrier_exist[1]|1<<i);
											Write_Barrier_Exist(barrier_number[1],&barrier_exist[1]);
										}
									}
								}
							}
						}
					}						
				}break;
	}
}
/****************************************************************************************************
* Function Name :Shot_Bounce_Tank_Effect                                                            *
* Description	:炮弹碰坦克影响函数	               													*
* Date		    : 09/09/30                                                             	            *
* Parameter     :指向坦克结构体的指针                                								*
* Return Code   :无                                                                                 *
* Author	    :                                                               	            *
****************************************************************************************************/	
void Shot_Bounce_Tank_Effect(struct TANK *t)
{
	uint8  tank_number;
	uint8  camp;
	uint8  level;
	uint8  life;
	uint8  exist=0;
	Shot_Disappear(t->Shot_Direction,t->Shot_Position,t->Position);
	switch(t->Shot_Direction)
	{
		case Up:	tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,2,1);break;
		case Down:	tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,2,1);break;
		case Left:	tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,1,2);break;
		case Right:	tank_number=Get_Nearest_Tank(t->Shot_Position,t->Shot_Direction,1,2);break;
	}
	Get_Tank_Camp(tank_number,&camp);
	Get_Tank_Level(tank_number,&level);
	Get_Tank_Life(tank_number,&life);
	if(t->Camp==camp)
	{
		return;
	}
	if(level>1)
	{
		level--;
		Change_Tank_Level(tank_number,&level);
		switch(tank_number)
		{
			case 1:Delete_Tank_Tail(&Tank1,Temp_tank1);Display_Tank(&Tank1,Temp_tank1);break;
			case 2:Delete_Tank_Tail(&Tank2,Temp_tank2);Display_Tank(&Tank2,Temp_tank2);break;
		}
		return;
	}
	if(level==1&&life!=0)
	{
		life--;
		Change_Tank_Life(tank_number,&life);		
		switch(tank_number)
		{
			case 1:Delete_Tank_Tail(&Tank1,Temp_tank1);Delete_Shot(Tank1.Shot_Direction,Tank1.Shot_Position);break;
			case 2:Delete_Tank_Tail(&Tank2,Temp_tank2);Delete_Shot(Tank2.Shot_Direction,Tank2.Shot_Position);break;
		}
		Replace_Tank(tank_number);
		switch(tank_number)
		{
			case 1:Display_Tank(&Tank1,Temp_tank1);break;
			case 2:Display_Tank(&Tank2,Temp_tank2);break;
		}
		return;				
	}
	if(level==1&&life==0)
	{
		Change_Tank_Exist(tank_number,&exist);
		switch(tank_number)
		{
			case 1:Delete_Tank_Tail(&Tank1,Temp_tank1);Delete_Shot(Tank1.Shot_Direction,Tank1.Shot_Position);break;
			case 2:Delete_Tank_Tail(&Tank2,Temp_tank2);Delete_Shot(Tank2.Shot_Direction,Tank2.Shot_Position);break;
		}
		return;
	}	
}

/****************************************************************************************************
* Function Name :Shot_Disappear                                                                     *
* Description	:炮弹碰撞物体消失函数	               												*
* Date		    : 09/09/25                                                             	            *
* Parameter     :炮弹的方向,炮弹坐标的指针,坦克坐标的指针                                			*
* Return Code   :无                                                                                 *
* Author	    :                                                               	            *
****************************************************************************************************/
void Shot_Disappear(uint8 direction,uint8 *shot_position,uint8 *tank_position)
{
	if(direction==Left&&( *(shot_position+1) )<*(tank_position+1))
	{
		Delete_Point( (	(*shot_position) *2)+1,( *(shot_position+1) )*2 );
		Delete_Point( (	(*shot_position) *2)+1,( *(shot_position+1) )*2+1);
		Delete_Point( (	(*shot_position) *2)+2,( *(shot_position+1) )*2);
		Delete_Point( (	(*shot_position) *2)+2,( *(shot_position+1) )*2+1);
 	}
	if(direction==Right&&( *(shot_position+1) )>*(tank_position+1)+4)
	{
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2);
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2+1);
		Delete_Point((	(*shot_position) *2)+2,( *(shot_position+1) )*2);
		Delete_Point((	(*shot_position) *2)+2,( *(shot_position+1) )*2+1);
 	}
	if(direction==Up&&	(*shot_position) <*tank_position)
	{
		Delete_Point((	(*shot_position) *2),( *(shot_position+1) )*2+1);
		Delete_Point((	(*shot_position) *2),( *(shot_position+1) )*2+2);
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2+1);
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2+2);
	}
	if(direction==Down&&	(*shot_position) >*tank_position+4)
	{
		Delete_Point((	(*shot_position) *2),( *(shot_position+1) )*2+1);
		Delete_Point((	(*shot_position) *2),( *(shot_position+1) )*2+2);
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2+1);
		Delete_Point((	(*shot_position) *2)+1,( *(shot_position+1) )*2+2);
	}	
}											    
/****************************************************************************************************
* Function Name :Shot_Effect                                                                  		*
* Description	:炮弹碰壁或敌方坦克的效果函数	               										*
* Date		    : 09/09/25                                                             	            *
* Parameter     :指向坦克结构体的指针,要炸毁的方向                                					*
* Return Code   :无                                                                                 *
* Author	    :                                                               	            *
****************************************************************************************************/									    
void Shot_Break(uint8 *Shot_Position,uint8 direction )
{
	uint8 i;
	uint8 j;
	switch(direction)
	{
		case Up_Left:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]-2)*2+i,(Shot_Position[1]-1)*2+j);
						}
					}break;
		case Up_Right:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]-2)*2+i,(Shot_Position[1]+1)*2+j);
						}
					}break;
		case Down_Left:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]+1)*2+i,(Shot_Position[1]-1)*2+j);
						}
					}break;
		case Down_Right:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]+1)*2+i,(Shot_Position[1]+1)*2+j);
						}
					}break;
		case Left_Up:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]-1)*2+i,(Shot_Position[1]-2)*2+j);
						}
					}break;
		case Left_Down:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]+1)*2+i,(Shot_Position[1]-2)*2+j);
						}
					}break;
		case Right_Up:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]-1)*2+i,(Shot_Position[1]+1)*2+j);
						}
					}break;
		case Right_Down:
					for(i=0;i<4;i++)
					{
						for(j=0;j<4;j++)
						{
							Delete_Point((Shot_Position[0]+1)*2+i,(Shot_Position[1]+1)*2+j);
						}
					}break;
	}
}																											
/* *************************************************************************************************
* Function Name :Draw_Barrier                                                                  	   *
* Description	:绘制障碍物  	               											   		   *
* Date		    : 09/09/27                                                             	           *
* Parameter     :指向障碍物结构体的指针                                							   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Draw_Barrier(struct Barrier *b)
{
	uint8 i,j;
	//uint8 num=Get_Barrier_Number(b->Position);
	//Read_Barrier_Exist(num,&barrier_exist);
	for(i=0;i<b->Length/2;i++)
	{
		for(j=0;j<b->Width/2;j++)
		{
			if((b->Exist&1<<j*(b->Length/2)+i)!=0)
			{
				switch(b->Property)
				{
					case Steel:Draw_Piece_Steel(b->Position[0]+j*2,b->Position[1]+i*2);break;
					case Brick:Draw_Piece_Brick(b->Position[0]+j*2,b->Position[1]+i*2);break;
				}
			}

		}
	}
}																									
/* *************************************************************************************************
* Function Name :Draw_Piece_Steel                                                                  *
* Description	:指定坐标处画铁的贴图  	               											   *
* Date		    : 09/09/27                                                             	           *
* Parameter     :要绘制贴图的游戏横坐标与纵坐标                                					   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Draw_Piece_Steel(uint8 x,uint8 y)
{
	uint8 i,j;
	for(i=0;i<4;i++)
	{
		for(j=0;j<4;j++)
		{
			Creat_Point(x*2+i,y*2+j);
		}
	}
}
/* *************************************************************************************************
* Function Name :Draw_Piece_Brick                                                                  *
* Description	:指定坐标处画砖的贴图  	               											   *
* Date		    : 09/09/27                                                             	           *
* Parameter     :要绘制贴图的游戏横坐标与纵坐标                                					   *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Draw_Piece_Brick(uint8 x,uint8 y)
{
	uint8 i,j;
	for(i=0;i<4;i++)
	{
		for(j=0;j<4;j++)
		{
			if((x*2+i)%2==0&&(y*2+j)%2==0||(x*2+i)%2==1&&(y*2+j)%2==1)
			{
				Creat_Point(x*2+i,y*2+j);
			}
		}
	}
}  														
/* *************************************************************************************************
* Function Name :Copy_Array                                                                  	   *
* Description	:复制数组函数  	               											   		   *
* Date		    : 09/09/19                                                             	           *
* Parameter     :指向目的数组的指针,指向原数组指针,复制变量的个数                                *
* Return Code   :无                                                                                *
* Author	    :                                                               	           *
************************************************************************************************* */
void Copy_Array(uint8 *Desition,uint8 *original,uint8 length)        
{
	uint8 i;
	for(i=0;i<length;i++)
	{
		*(Desition+i)=*(original+i);
	}
}
/* *************************************************************************************************
* Function Name :Change_Picture                                                                   *
* Description	:贴图转化函数(转化的贴图字节存在*Destion中)  	               					  *
* Date		    : 09/09/20                                                             	          *
* Parameter     :贴图所在页的游戏坐标,转化后用于存储的地址指针                                   *
* Return Code   :无                                                                               *
* Author	    :                                                               	          *
************************************************************************************************* */
void Change_Picture(uint8 position,uint8 *Desition)        		
{
	uint8  i;
	switch(position)
	{
			
		case 0:for(i=0;i<8;i++)
				{
					*(Desition+8+i)=0;
				}
				break;			
		case 1:for(i=0;i<8;i++)
				{
					*(Desition+8+i)=*(Desition+i);
					*(Desition+8+i)=*(Desition+8+i)>>6&0X03;
					*(Desition+i)=*(Desition+i)<<2&0XFC;
				}
				break;
		case 2:for(i=0;i<8;i++)
				{
					*(Desition+8+i)=*(Desition+i);
					*(Desition+8+i)=*(Desition+8+i)>>4&0X0F;
					*(Desition+i)=*(Desition+i)<<4&0XF0;
				}
				break;
		case 3:for(i=0;i<8;i++)
				{
					*(Desition+8+i)=*(Desition+i);
					*(Desition+8+i)=*(Desition+8+i)>>2&0X3F;
					*(Desition+i)=*(Desition+i)<<6&0XC0;
				}
				break;
	}
}
/* *************************************************************************************************
* Function Name :Get_Nearest_Barrier                                                               *
* Description	:查找离被查物最近的障碍物,以障碍物的后边沿为准  								   *
* Date		    : 09/09/21.22                                                             	       *
* Parameter     :指向坦克的坐标的指针,指定方向                                   				   *
* Return Code   :障碍物编号(返回0表示坦克前进方向没有障碍物)                                       *
* Author	    :                                                               	           *
************************************************************************************************* */
void  Get_Nearest_Barrier(uint8 *position,uint8 direction,uint8 object_length,uint8 object_width,uint8 *num)
{
	uint8 xdata  i;
	uint8 xdata  barrier1=0;					//用于返回的障碍物编号
	uint8 xdata  barrier2=0;					//用于返回的障碍物编号
	uint8 xdata  barrier_poisition[2];
	uint8 xdata  barrier_length;
	uint8 xdata  barrier_width;
	uint8 xdata  distance1=200;			//坦克和位于坦克同排或同列的障碍物的距离
	uint8 xdata  distance2=0;		     	//坦克和位于坦克同排或同列的障碍物的距离
	switch(direction)
	{
		case Up:
				for(i=1;i<Barrier_Count+1;i++)
				{
					Get_Barrier_Quality(i,barrier_poisition,&barrier_length,&barrier_width);		
					if(*(position+1)<=barrier_poisition[1]+barrier_length-1&&*position>barrier_poisition[0])
					{
						if((barrier_poisition[1]>=2&&*(position+1)+(object_length-1)>=barrier_poisition[1])||(barrier_poisition[1]<=2&&*(position+1)>=barrier_poisition[1]))
						{
							if(distance1==200)
							{
								distance1=*position-barrier_poisition[0];
								barrier1=i;
							}
							else if((*position-barrier_poisition[0])==distance1)
							{
								barrier2=i;
								distance2=*position-barrier_poisition[0];
							}
							else if((*position-barrier_poisition[0])<distance1)
							{
							 	distance1=*position-barrier_poisition[0];
								barrier1=i;
							}

						}
					}
				}break;
			case Down:
				for(i=1;i<Barrier_Count+1;i++)
				{
					Get_Barrier_Quality(i,barrier_poisition,&barrier_length,&barrier_width);		
					if(*(position+1)<=barrier_poisition[1]+barrier_length-1&&barrier_poisition[0]+barrier_width>*position+object_width)
					{
						if((barrier_poisition[1]>=2&&*(position+1)+(object_length-1>=barrier_poisition[1]))||(barrier_poisition[1]<=2&&*(position+1)>=barrier_poisition[1]))
						{
							if(distance1==200)
							{
								distance1=barrier_poisition[0]+barrier_width-(*position+object_width);
								barrier1=i;
							}
						 	else if((barrier_poisition[0]+barrier_width-(*position+object_width))==distance1)
							{
							 	distance2=barrier_poisition[0]+barrier_width-(*position+object_width);
								barrier2=i;
							}
							else if((barrier_poisition[0]+barrier_width-(*position+object_width))<distance1)
							{
							 	distance1=barrier_poisition[0]+barrier_width-(*position+object_width);
								barrier1=i;
							}
						}
					}
				}break;
			case Left:
				for(i=1;i<Barrier_Count+1;i++)
				{
					Get_Barrier_Quality(i,barrier_poisition,&barrier_length,&barrier_width);		
					if(*position<=barrier_poisition[0]+barrier_width-1&&barrier_poisition[1]<*(position+1))
					{
						if((barrier_poisition[0]>=2&&*position+(object_width-1)>=barrier_poisition[0])||(barrier_poisition[0]<=2&&*position>=barrier_poisition[0]))
						{
							if(distance1==200)
							{
								distance1=*(position+1)-barrier_poisition[1];
								barrier1=i;
							}
							else if((*(position+1)-barrier_poisition[1])==distance1)
							{
							 	distance2=*(position+1)-barrier_poisition[1];
								barrier2=i;
							}
							else if((*(position+1)-barrier_poisition[1])<distance1)
							{
							 	distance1=*(position+1)-barrier_poisition[1];
								barrier1=i;
							}

						}
					}
				}break;
			case Right:
				for(i=1;i<Barrier_Count+1;i++)
				{
					Get_Barrier_Quality(i,barrier_poisition,&barrier_length,&barrier_width);		
					if(*position<=barrier_poisition[0]+barrier_width-1&&barrier_poisition[1]+barrier_length>(*(position+1)+object_length))
					{
						if((barrier_poisition[0]>=2&&*position+(object_width-1)>=barrier_poisition[0])||(barrier_poisition[0]<=2&&*position>=barrier_poisition[0]))
						{
							if(distance1==200)
							{
								distance1=barrier_poisition[1]+barrier_length-(*(position+1)+object_length);
								barrier1=i;
							}
							else if((barrier_poisition[1]+barrier_length-(*(position+1)+object_length))==distance1)
							{
							 	distance2=barrier_poisition[1]+barrier_length-(*(position+1)+object_length);
								barrier2=i;
							}
							else if((barrier_poisition[1]+barrier_length-(*(position+1)+object_length))<distance1)
							{
							 	distance1=barrier_poisition[1]+barrier_length-(*(position+1)+object_length);
								barrier1=i;
							}
						}
					}
				}break;
			}
		if(distance1!=distance2)
		{
			barrier2=0;
		}
		*num=barrier1;
		*(num+1)=barrier2;
}
/* *************************************************************************************************
* Function Name :Get_Nearest_Tank                                                          		   *
* Description	:查找离被查物最近的坦克,以坦克的前边沿为准						   	   			   *
* Date		    : 09/09/21.22                                                             	       *
* Parameter     :指向坦克的坐标的指针,指定方向                                   				   *
* Return Code   :障碍物编号(返回0表示坦克前进方向没有障碍物)                                       *
* Author	    :                                                               	           *
************************************************************************************************* */
uint8  Get_Nearest_Tank(uint8 *position,uint8 direction,uint8 object_length,uint8 object_width)
{
	uint8  i;
	uint8  tank_number=0;					//用于返回坦克的编号
	uint8  tank_poisition[2];
	uint8  distance=200;						//初始化距离
	switch(direction)
	{
		case Up:
				for(i=1;i<Tank_Count+1;i++)
				{
					if( (i==1&&Tank1.Exist==1) ||(i==2&&Tank2.Exist==1) )
					{					
						Get_Tank_Position(i,tank_poisition);		
						if(*(position+1)<=tank_poisition[1]+4-1&&*position>=tank_poisition[0]+4)
						{
							if((tank_poisition[1]>=2&&*(position+1)+(object_length-1)>=tank_poisition[1])||(tank_poisition[1]<=2&&*(position+1)>=tank_poisition[1]))
							{
								if(distance==200)
								{
									distance=*position-tank_poisition[0]-4;
									tank_number=i;
								}
								else if((*position-tank_poisition[0]-4)<distance)
								{
								 	distance=*position-tank_poisition[0]-4;
									tank_number=i;
								}	
							}
						}
					}
				}break;
			case Down:
				for(i=1;i<Tank_Count+1;i++)
				{
					if( (i==1&&Tank1.Exist==1) ||(i==2&&Tank2.Exist==1) )
					{					
						Get_Tank_Position(i,tank_poisition);
						if(*(position+1)<=tank_poisition[1]+4-1&&tank_poisition[0]>=*position+object_width)
						{
							if((tank_poisition[1]>=2&&*(position+1)+(object_length-1)>=tank_poisition[1])||(tank_poisition[1]<=2&&*(position+1)>=tank_poisition[1]))
							{
								if(distance==200)
								{
									distance=tank_poisition[0]-(*position+object_width);
									tank_number=i;
								}
								else if((tank_poisition[0]-(*position+object_width))<distance)
								{
								 	distance=tank_poisition[0]-(*position+object_width);
									tank_number=i;
								}
							}
						}
					}
				}break;
			case Left:
				for(i=1;i<Tank_Count+1;i++)
				{
					if( (i==1&&Tank1.Exist==1) ||(i==2&&Tank2.Exist==1) )
					{
						Get_Tank_Position(i,tank_poisition);
						if(*position<=tank_poisition[0]+4-1&&tank_poisition[1]+4<=*(position+1))
						{
							if((tank_poisition[0]>=2&&*position+(object_width-1)>=tank_poisition[0])||(tank_poisition[0]<=2&&*position>=tank_poisition[0]))
							{
								if(distance==200)
								{
									distance=*(position+1)-tank_poisition[1]-4;
									tank_number=i;
								}
								else if((*(position+1)-tank_poisition[1])-4<distance)
								{
								 	distance=*(position+1)-tank_poisition[1]-4;
									tank_number=i;
								}
	
							}
						}
					}
				}break;
			case Right:
				for(i=1;i<Tank_Count+1;i++)
				{
					if( (i==1&&Tank1.Exist==1) ||(i==2&&Tank2.Exist==1) )
					{
						Get_Tank_Position(i,tank_poisition);		
						if(*position<=tank_poisition[0]+4-1&&tank_poisition[1]>=(*(position+1)+object_length))
						{
							if((tank_poisition[0]>=2&&*position+(object_width-1)>=tank_poisition[0])||(tank_poisition[0]<=2&&*position>=tank_poisition[0]))
							{
								if(distance==200)
								{
									distance=tank_poisition[1]-(*(position+1)+object_length);
									tank_number=i;
								}
								else if((tank_poisition[1]-(*(position+1)+object_length))<distance)
								{
								 	distance=tank_poisition[1]-(*(position+1)+object_length);
									tank_number=i;
								}
							}
						}
					}
				}break;
	}
	return tank_number;
}

/* *************************************************************************************************
* Function Name :Get_Barrier_Quality                                                               *
* Description	:获得指定障碍物的坐标值,长度 ,宽度 	               				  			   *
* Date		    : 09/09/20                                                             	           *
* Parameter     :障碍物编号,指向障碍物坐标的指针,指向障碍物长度的指针,指向障碍物宽度的指针       *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
*************************************************************************************************  */        								
void  Get_Barrier_Quality (uint8 number,uint8 *position,uint8 *length,uint8 *width)
{
	switch(number)
	{
		case 1: *position=Barrier1.Position[0];		*(position+1)=Barrier1.Position[1];		*length=Barrier1.Length;	*width=Barrier1.Width;break;
		case 2: *position=Barrier2.Position[0];		*(position+1)=Barrier2.Position[1];		*length=Barrier2.Length;	*width=Barrier2.Width;break;
		case 3: *position=Barrier3.Position[0];		*(position+1)=Barrier3.Position[1];		*length=Barrier3.Length;	*width=Barrier3.Width;break;
		case 4: *position=Barrier4.Position[0];		*(position+1)=Barrier4.Position[1];		*length=Barrier4.Length;	*width=Barrier4.Width;break;	
		case 5: *position=Barrier5.Position[0];		*(position+1)=Barrier5.Position[1];		*length=Barrier5.Length;	*width=Barrier5.Width;break;
		case 6: *position=Barrier6.Position[0];		*(position+1)=Barrier6.Position[1];		*length=Barrier6.Length;	*width=Barrier6.Width;break;
		case 7: *position=Barrier7.Position[0];		*(position+1)=Barrier7.Position[1];		*length=Barrier7.Length;	*width=Barrier7.Width;break;
		case 8: *position=Barrier8.Position[0];		*(position+1)=Barrier8.Position[1];		*length=Barrier8.Length;	*width=Barrier8.Width;break;
		case 0: break;
	}
}
/* *************************************************************************************************
* Function Name :Read_Barrier_Exist                                                                 *
* Description	:读取指定障碍物的破坏程度 	               				  			   				*
* Date		    : 09/09/25                                                             	            *
* Parameter     :障碍物编号,指向障碍物破坏程度的指针        										*
* Return Code   :无                                                                       		    *
* Author	    :                                                               	            *
*************************************************************************************************   */ 
void  Read_Barrier_Exist (uint8 number,uint8 *exist)
{
	switch(number)
	{
		case 1: *exist=Barrier1.Exist;break;		
		case 2: *exist=Barrier2.Exist;break;		
		case 3: *exist=Barrier3.Exist;break;
		case 4: *exist=Barrier4.Exist;break;	
		case 5: *exist=Barrier5.Exist;break;
		case 6: *exist=Barrier6.Exist;break;
		case 7: *exist=Barrier7.Exist;break;
		case 8: *exist=Barrier8.Exist;break;
	}
}
/* *************************************************************************************************
* Function Name :Write_Barrier_Exist                                                                *
* Description	:改变指定障碍物的破坏程度 	               				  			   			 	*
* Date		    : 09/09/25                                                             	            *
* Parameter     :障碍物编号,指向障碍物破坏程度的指针        										*
* Return Code   :无                                                                       		    *
* Author	    :                                                               	            *
*************************************************************************************************   */ 
void  Write_Barrier_Exist (uint8 number,uint8 *exist)
{
	switch(number)
	{
		case 1: Barrier1.Exist=*exist;break;
		case 2: Barrier2.Exist=*exist;break;
		case 3: Barrier3.Exist=*exist;break;
		case 4: Barrier4.Exist=*exist;break;	
		case 5: Barrier5.Exist=*exist;break;
		case 6: Barrier6.Exist=*exist;break;
		case 7: Barrier7.Exist=*exist;break;
		case 8: Barrier8.Exist=*exist;break;
	}	
}
/* *************************************************************************************************
* Function Name :Get_Barrier_Property                                                               *
* Description	:获得障碍物的组成物质 	               				  			   			 		*
* Date		    : 09/09/25                                                             	            *
* Parameter     :障碍物编号,指向障碍物组成物质的指针        										*
* Return Code   :无                                                                       		    *
* Author	    :                                                               	            *
*************************************************************************************************   */ 
void  Get_Barrier_Property (uint8  number,uint8 *property)
{
	switch(number)
	{
		case 1: *property=Barrier1.Property;break;		
		case 2: *property=Barrier2.Property;break;		
		case 3: *property=Barrier3.Property;break;
		case 4: *property=Barrier4.Property;break;	
		case 5: *property=Barrier5.Property;break;
		case 6: *property=Barrier6.Property;break;
		case 7: *property=Barrier7.Property;break;
		case 8: *property=Barrier8.Property;break;
	}
}
/* *************************************************************************************************
* Function Name :Change_Tank_Exist                                                                 *
* Description	:更改指定坦克是否存在 	               				  		   					   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克存在性的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Change_Tank_Exist (uint8 number,uint8 *exist)
{
	switch(number)
	{
		case 1: Tank1.Exist=*exist;		break;
		case 2: Tank2.Exist=*exist;		break;	
	}	
}
/* *************************************************************************************************
* Function Name :Get_Tank_Position                                                                  *
* Description	:获得指定坦克的坐标值 	               				  			   			 		*
* Date		    : 09/09/29                                                             	            *
* Parameter     :坦克编号,指向坦克坐标的指针        												*
* Return Code   :无                                                                       		    *
* Author	    :                                                               	            *
*************************************************************************************************** */ 
void  Get_Tank_Position (uint8 number,uint8 *position)
{
	switch(number)
	{
		case 1: *position=Tank1.Position[0];	*(position+1)=Tank1.Position[1];break;
		case 2: *position=Tank2.Position[0];	*(position+1)=Tank2.Position[1];break;	
	}
}
/* *************************************************************************************************
* Function Name :Get_Tank_Camp                                                                     *
* Description	:获得指定坦克的阵营 	               				  		   					   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克阵营的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Get_Tank_Camp (uint8 number,uint8 *camp)
{
	switch(number)
	{
		case 1: *camp=Tank1.Camp;		break;
		case 2: *camp=Tank2.Camp;		break;	
	}
}
/* *************************************************************************************************
* Function Name :Get_Tank_Life                                                                     *
* Description	:获得指定坦克的生命 	               				  		   					   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克生命的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Get_Tank_Life (uint8 number,uint8 *life)
{
	switch(number)
	{
		case 1: *life=Tank1.Life;		break;
		case 2: *life=Tank2.Life;		break;	
	}	
}
/* *************************************************************************************************
* Function Name :Change_Tank_Life                                                                  *
* Description	:更改指定坦克的生命 	               				  		   					   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克生命的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Change_Tank_Life (uint8 number,uint8 *life)
{
	switch(number)
	{
		case 1: Tank1.Life=*life;		break;
		case 2: Tank2.Life=*life;		break;	
	}
}
/* *************************************************************************************************
* Function Name :Get_Tank_Level                                                                    *
* Description	:获得指定坦克的级别 	               				  		   					   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克生命的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Get_Tank_Level (uint8 number,uint8 *level)
{
	switch(number)
	{
		case 1: *level=Tank1.Level;		break;
		case 2: *level=Tank2.Level;		break;	
	}	
}
/* *************************************************************************************************
* Function Name :Change_Tank_Level                                                                 *
* Description	:更改指定坦克的级别               				  		   					  	   *
* Date		    : 09/09/30                                                             	           *
* Parameter     :坦克编号,指向坦克生命的指针        								   			   *
* Return Code   :无                                                                       		   *
* Author	    :                                                               	           *
****************************************************************************************************/ 
void  Change_Tank_Level (uint8 number,uint8 *level)	
{
	switch(number)
	{
		case 1: Tank1.Level=*level;		break;
		case 2: Tank2.Level=*level;		break;	
	}
}																		
/* *************************************************************************************************
* Function Name :Get_Tank_Shot_Quality                                                              *
* Description	:获得指定坦克炮弹的坐标值,方向 	               				  			   			*
* Date		    : 09/09/25                                                             	            *
* Parameter     :坦克编号,指向炮弹坐标的指针,指向炮弹方向的指针        							*
* Return Code   :无                                                                       		    *
* Author	    :                                                               	            *
*************************************************************************************************** */ 
void  Get_Tank_Shot_Quality (uint8 number,uint8 *position,uint8 *direction)						
{
	switch(number)
	{
		case 1: *position=Tank1.Shot_Position[0];	*(position+1)=Tank1.Shot_Position[1];*direction=Tank1.Shot_Direction;break;
		case 2: *position=Tank2.Shot_Position[0];	*(position+1)=Tank2.Shot_Position[1];*direction=Tank2.Shot_Direction;break;	
	}
}
																																																				
void Keyboard_P1_ISR(void) interrupt 0          					//中断键盘函数(控制坦克1)
{    	
	P1_col1=P1_col2=1;												//列线
	P1_row1=0; P1_row2=1;                     						// 将行线1置低,其他行线置高		
     if (P1_col1==0) 
	{
		if(Tank1.Position[0]%2==0&&Tank1.Position[1]%2==0)
		{ 
			Tank1.Direction=Up;
		}
	}
	if(Tank1.Position[0]%2==0&&Tank1.Position[1]%2==0)
	{ 		 		
    	if (P1_col2==0) 
		{
			Tank1.Direction=Left;
		} 
    }	
	P1_row1=1; P1_row2=0;              								// 将行线2置低,其他行线置高
    if(Tank1.Position[0]%2==0&&Tank1.Position[1]%2==0)
	{ 		   	
     	if (P1_col1==0) 
		{
			Tank1.Direction=Right;
		}  
	}
	if(Tank1.Position[0]%2==0&&Tank1.Position[1]%2==0)
	{ 		 
    	if (P1_col2==0)
		{
			Tank1.Direction=Down;
		}
	}
	Tank1.Button__Down_Flg=1;
    EX0=0;  
}

void Keyboard_P2_ISR(void) interrupt 2          					//中断键盘函数(控制坦克2)
{    	
	P2_col1=P2_col2=1;												//列线
	P2_row1=0; P2_row2=1;                     						// 将行线1置低,其他行线置高		
     if (P2_col1==0) 
	{
		if(Tank2.Position[0]%2==0&&Tank2.Position[1]%2==0)
		{ 
			Tank2.Direction=Up;
		}
	}
	if(Tank2.Position[0]%2==0&&Tank2.Position[1]%2==0)
	{ 		 		
    	if (P2_col2==0) 
		{
			Tank2.Direction=Left;
		} 
    }	
	P2_row1=1; P2_row2=0;              								// 将行线2置低,其他行线置高
    if(Tank2.Position[0]%2==0&&Tank2.Position[1]%2==0)
	{ 		   	
     	if (P2_col1==0) 
		{
			Tank2.Direction=Right;
		}  
	}
	if(Tank2.Position[0]%2==0&&Tank2.Position[1]%2==0)
	{ 		 
    	if (P2_col2==0)
		{
			Tank2.Direction=Down;
		}
	}
	Tank2.Button__Down_Flg=1;
    EX1=0;  

}
void INT0_ISR(void) interrupt 1            					//中断定时器函数,基本定时5ms
{
	TL0=0X78;
  	TH0=0XEC;
	Time_Flg++;
}

void INT1_ISR(void) interrupt 3            					//T1用于计数器,当来一个低电平是发生中断,用于发射炮弹
{
	TL1=0XFF;
  	TH1=0XFF;
	Tank1.Send_Shot_Flg=1;
}
/* *************************************************************************************************
* Function Name : LCD12864_Init                                                                    *
* Description	: 主屏模块初始化															       *
* Date		    : 09/04/1                                                                 	       *
* Parameter     : 无                                                                               *
* Return Code   : 无                                                                               *
* Author	    :                                                                                  *
************************************************************************************************* */
void LCD12864_Init(void)
{

	LCD12864_EN = 0;															//LCD12864始能位清0
	WriteCmd(SET_ON);															//将LCD12864设置为ON

	WriteCmd(SET_COL);															//设置开始的列

	WriteCmd(SET_PAGE);															//设置开始的行
	WriteCmd(0xC0);

}

//****************************************************************************
//* 名称:CleanAll
//* 功能:清屏

//****************************************************************************
void CleanAll(void)
{
	uint8 ucPage,ucCol;
	LCD12864_CSA = 0;	//左右两屏都选中
	LCD12864_CSB = 0;
	for(ucPage=0;ucPage<8;ucPage++)
	{
	
		WriteCmd(SET_PAGE+ucPage);	  //页
		WriteCmd(SET_COL);		 //列
		for(ucCol=0;ucCol<64;ucCol++)
			WriteData(0x00);
	}
}


/* *************************************************************************************************
* Function Name : DisplayByte                                                                      *
* Description	: 显示一个字节,即纵向8个像素    							             	       *
* Date		    : 09/04/1                                                             	           *
* Parameter     : ucPage         显示的页 (屏幕一共8页)                                            *
*                 ucCol          要显示的列 (屏幕一共128列)                                        *
*                 ucData         要显示的数据                                                      *
* Return Code   : 无                                                                               *
* Author	    :                                                                 	           	   *
************************************************************************************************* */
void  DisplayByte(uint8 ucPage,uint8 ucCol,uint8 ucData)
{
	uint8 i=SET_PAGE+ucPage;
	uint8 j=SET_COL+ucCol%SINGLE_SCREEN_COL;
	if(ucPage<0||ucPage>=8||ucCol<0||ucCol>=128)
	{
		while(1);
	}
	
	if(ucCol/SINGLE_SCREEN_COL==0)
	{
		LCD12864_CSA=0;												            //选择A屏
		LCD12864_CSB=1;
	}
	else{
		LCD12864_CSB=0;  											            //选择B屏
		LCD12864_CSA=1;
	}

	//WriteCmd(SET_COL);														//设置开始的列
	//WriteCmd(SET_PAGE);														//设置开始的行

	WriteCmd(i);
	WriteCmd(j);
	WriteData(ucData);

}



/* *************************************************************************************************
* Function Name : WriteCmd                                                                         *
* Description	:    	                  						             	       			   *
* Date		    : 09/04/1                                                             	           *
* Parameter     : ucCmd         要写的命令                                                         *
* Return Code   : 无                                                                               *
* Author	    :                                                                  	          	   *
************************************************************************************************* */
void WriteCmd(uint8 ucCmd) 
{

	LCD12864_RS = 0;
	LCD12864_RW = 0;

	LCD12864_DATA = ucCmd;
	LCD12864_EN = 1;
	
	LCD12864_EN = 0;

}
/* *************************************************************************************************
* Function Name : MWriteData                                                                       *
* Description	: 显示游戏地图    	                  						             	       *
* Date		    : 09/04/1                                                             	           *
* Parameter     : ucData要写的数据                                                       		    *
* Return Code   : 无                                                                               *
* Author	    :                                                                 	          		 *
************************************************************************************************* */
void WriteData(uint8 ucData)  
{

	LCD12864_RS = 1;
	LCD12864_RW = 0;
	
	LCD12864_DATA = ucData;
	LCD12864_EN = 1;

	LCD12864_EN = 0;
}
/* *************************************************************************************************
* Function Name : ReadByte                                                                         *
* Description	:    	                  						             	      			   *
* Date		    : 09/04/1                                                             	           *
* Parameter     : ucPage         要读的页数                                                        *
* 				  ucCol          要读的列数                                                        *
*   			  ucData         将读的内容存放在某个变量中                                        *
* Return Code   : 无                                                                               *
* Author	    :                                                                  	               *
************************************************************************************************* */
void ReadByte(uint8 ucPage,uint8 ucCol,uint8 *ucData) 
{
	uint8  ucTemp;
	if(ucPage<0||ucPage>=8||ucCol<0||ucCol>=128)
	{
		while(1);
	}
	if(ucCol/SINGLE_SCREEN_COL==0)
	{
		LCD12864_CSA=0;															//选择A屏
		LCD12864_CSB=1;
	}
	else{
		LCD12864_CSB=0;  														//选择B屏
		LCD12864_CSA=1;
	}

  
	WriteCmd(SET_COL);															//设置开始的列
	WriteCmd(SET_PAGE);															//设置开始的行

																			   	//空读
	WriteCmd(SET_PAGE+ucPage);
	WriteCmd(SET_COL+ucCol%SINGLE_SCREEN_COL);
	LCD12864_DATA=0xFF;
	LCD12864_RS = 1;
 	LCD12864_RW = 1;
	LCD12864_EN = 1;
	ucTemp = P0;
	LCD12864_EN = 0;


																				//读到ucTemp中
	WriteCmd(SET_PAGE+ucPage);
	WriteCmd(SET_COL+ucCol%SINGLE_SCREEN_COL);
	LCD12864_DATA=0xFF;
	LCD12864_RS = 1;
 	LCD12864_RW = 1;
	LCD12864_EN = 1;
	ucTemp = P0;
	LCD12864_EN = 0;
	*ucData=ucTemp;
}
/* *************************************************************************************************
* Function Name : Creat_Point                                                                      *
* Description	: lcd12864指定坐标产生一个点   	                  						           *
* Date		    : 09/09/24                                                             	           *
* Parameter     : 指定横坐标x,指定纵坐标y                                        				   *
* Return Code   : 无                                                                               *
* Author	    :                                                                 	       *
************************************************************************************************* */
void Creat_Point(uint8 x,uint8 y)
{
	uint8  ucTemp;
	if(x<0||x>=64||y<0||y>=128)
	{
		while(1);
	}
	ReadByte(x/8,y,&ucTemp);
	ucTemp=ucTemp|1<<(x%8);
	DisplayByte(x/8,y,ucTemp);
}
/* *************************************************************************************************
* Function Name : Delete_Point                                                                     *
* Description	: lcd12864指定坐标删去一个点   	                  						           *
* Date		    : 09/09/24                                                             	           *
* Parameter     : 指定横坐标x,指定纵坐标y                                        				   *
* Return Code   : 无                                                                               *
* Author	    :                                                               	           *
************************************************************************************************* */
void Delete_Point(uint8 x,uint8 y)
{
	uint8  ucTemp;
	if(x<0||x>=64||y<0||y>=128)
	{
		while(1);
	}
	ReadByte(x/8,y,&ucTemp);
	ucTemp=~(~ucTemp|1<<(x%8));
	DisplayByte(x/8,y,ucTemp);
}
/* *************************************************************************************************
* Function Name : Add_Points                                                                       *
* Description	: lcd12864指定页和列上添加数据(增加点)   	                  					   *
* Date		    : 09/09/24                                                             	           *
* Parameter     : ucPage         显示的页 (屏幕一共8页)                                            *
*                 ucCol          要显示的列 (屏幕一共128列)                                        *
*                 ucData         要添加的数据                               				       *
* Return Code   : 无                                                                               *
* Author	    :                                                               	           *
************************************************************************************************* */
void Add_Points(uint8 ucPage,uint8 ucCol,uint8 ucdata)
{
	uint8  ucTemp;
	if(ucPage<0||ucPage>=8||ucCol<0||ucCol>=128)
	{
		while(1);
	}
	ReadByte(ucPage,ucCol,&ucTemp);
	ucdata=ucTemp|ucdata;
	DisplayByte(ucPage,ucCol,ucdata);	
}
/* *************************************************************************************************
* Function Name : Reduce_Points                                                                    *
* Description	: lcd12864指定页和列上减少数据(删除点)   	                  					   *
* Date		    : 09/09/24                                                             	           *
* Parameter     : ucPage         显示的页 (屏幕一共8页)                                            *
*                 ucCol          要显示的列 (屏幕一共128列)                                        *
*                 ucData         要删除的数据                               				       *
* Return Code   : 无                                                                               *
* Author	    :                                                               	           *
************************************************************************************************* */
void Reduce_Points(uint8 ucPage,uint8 ucCol,uint8 ucdata)
{
	uint8  ucTemp;
	if(ucPage<0||ucPage>=8||ucCol<0||ucCol>=128)
	{
		while(1);
	}
	ReadByte(ucPage,ucCol,&ucTemp);
	ucdata=ucTemp&~ucdata;
	DisplayByte(ucPage,ucCol,ucdata);	
}

最后

以上就是典雅吐司为你收集整理的AT89C51单片机 C语言实现坦克大战游戏代码的全部内容,希望文章能够帮你解决AT89C51单片机 C语言实现坦克大战游戏代码所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部