微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 模拟电路设计 > t6963c的c51程序

t6963c的c51程序

时间:04-25 来源:互联网 点击:

/**********************************
//= 函数原型: uchar ard_data(uchar uData)
//= 功 能: 从T6963C读一个地址增加自动连续数据
//= 参 数:
//= 返 回 值: 返回0 成功,否则忙
//= 函数性质:私有函数
**********************************/
uchar ard_data(void) // 自动读数据
{
if(check_ar_st() == 0) return 1;
return LCMDP;
}

/**********************************
//= 函数原型: void char_addr_Pointer_Set(uchar urow, uchar ucol)
//= 功 能: 根据字符的行列设置vram地址
//= 参 数:
//= 返 回 值:
//= 函数性质:私有函数
**********************************/
void char_addr_Pointer_Set(uchar urow, uchar ucol)
{
uint iPos;
iPos = urow * 30 + ucol + txthome;
wr_cmd_2(LC_ADD_POS,iPos);
}

/**********************************
//= 函数原型: Clr_char_Scr(void)
//= 功 能: 清除当前文本屏幕
//= 参 数:
//= 返 回 值:
//= 函数性质:公有函数
**********************************/
void Clr_char_Scr(void)//文本屏可以在内存中保持很多屏
{
uint i;
// char_addr_Pointer_Set(0,0);//从0行0列开始
char_addr_Pointer_Set(2,0);//从0行0列开始
wr_cmd_0(LC_AUT_WR); // 自动写
// for(i=0;i16*30;i++) //16行30列字符
for(i=0;i14*30;i++) //16行30列字符
{
awr_data(0x00); // 写数据空白
}
wr_cmd_0(LC_AUT_OVR); // 自动写结束
char_addr_Pointer_Set(0,0); // 重置地址指针
}

/**********************************
//= 函数原型: Clr_lcdram(void)
//= 功 能: 清除所有的显示内存
//= 参 数:
//= 返 回 值:
//= 函数性质:私有函数
**********************************/
void Clr_lcdram(void)
{
uint i;
wr_cmd_2(LC_ADD_POS,0x0000); // 设置地址指针0
wr_cmd_0(LC_AUT_WR); // 自动写
for(i=0;i=DISRAM_SIZE;i++)
{
awr_data(0x00); // 写数据
}
wr_cmd_0(LC_AUT_OVR); // 自动写结束
wr_cmd_2(LC_ADD_POS,0x0000); // 重置地址指针
}


/**********************************
//= 函数原型: reset_lcm(void)
//= 功 能: 复位液晶模块
//= 参 数:
//= 返 回 值:
//= 函数性质:私有函数
**********************************/
void reset_lcm(void)
{
LCMRESET = 0;
_nop_();
_nop_();
LCMRESET=0XFF;
}

/**********************************
//= 函数原型: void lcm_init(void)
//= 功 能: 初始化液晶模块
//= 参 数:
//= 返 回 值:
//= 函数性质:公有函数
**********************************/
void lcm_init(void)
{
reset_lcm();//复位

wr_cmd_2(LC_TXT_HOME,TXTSTART); // 文本显示区首地址
wr_cmd_2(LC_TXT_AREA,30); // 文本显示区宽度30列
txthome = TXTSTART;

wr_cmd_2(LC_GRH_HOME,GRSTART); // 图形显示区首地址
wr_cmd_2(LC_GRH_AREA,30); // 图形显示区宽度30列
grhome = GRSTART;

wr_cmd_2(LC_CGR_OFFSET,CGRAMSTART >> 11);//CGRAM 偏移地址设置

wr_cmd_0(LC_MOD_XOR|0x08); // 显示方式设置,异或,字符全部用RAM区域生成
wr_cmd_0(LC_DIS_SW |0x0c); // 显示开关设置,图文混和模式

Clr_lcdram();//清除内存

}

/**********************************
//= 函数原型: Pixel(unsigned char PointX,unsigned char PointY, bit Mode)
//= 功 能: 在指定坐标位置显示一个点
//= 参 数: 坐标,显示点或清除点
//= 返 回 值:
//= 函数性质:私有函数
//= 如果显示屏超了256*256,请修改这个函数 PointX,PointY的类型
//= Mode 1:显示 0:清除该点
**********************************/
Pixel(unsigned char PointX,unsigned char PointY, bit Mode)
{
unsigned int StartAddr;
unsigned char dat;
StartAddr=(uint)PointX*30 + PointY/8 + grhome;
dat=LC_BIT_OP+7-PointY%8; //生产位操作命令画点的数据
if(Mode) dat=dat|0x08;
wr_cmd_2(LC_ADD_POS,StartAddr);//设置该点所在单元地址
wr_cmd_0(dat); // 利用位操作命令画点
}


/**********************************
//= 函数原型: void line( unsigned char x1, unsigned char y1, unsigned char x2, unsigned char y2, bit Mode)
//= 功 能: 划线函数
//= 参 数: 坐标1,坐标2,显示点或清除点
//= 返 回 值:
//= 函数性质:私有函数
//= 其它:显示点阵不超过255*255
/**********************************/

void line( unsigned char y1,unsigned char x1, unsigned char y2,unsigned char x2, bit Mode)
{
unsigned char x,y;
float k,b;
if( abs(y1-y2) = abs(x1-x2) ) // |k|=1
{
k=((float)y2-y1) / ((float)x2-x1) ;
b=y1-k*x1;
if( x1 = x2 )
{
for(x=x1;x=x2;x++)
{
y=(uchar)(k*x+b);
Pixel(x, y, Mode);
}
}
else
{
for(x=x2;x=x1;x++)
{
y=(uchar)(k*x+b);
Pixel(x, y, Mode);
}
}
}
else // abs(y1-y2) > abs(x1-x2) |K|>1
{
k=((float)x2-x1) / ((float)y2-y1) ;
b=x1-k*y1;
if( y1 = y2 )
{
for(y=y1;y=y2;y++)
{
x=(uchar)(k*y+b);
Pixel( x , y,Mode );
}
}
else
{
for(y=y2;y=y1;y++)
{
x=(uchar)(k*y+b);
Pixel( x , y,Mode );
}
}
}
}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top