微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 单片机驱动点阵16*16综合C程序-包含各种效果

单片机驱动点阵16*16综合C程序-包含各种效果

时间:11-29 来源:互联网 点击:

song(~table[ji*2+1]);//先发右半屏数

song(~table[ji*2]);//再发左半屏数

ji++;//取下一行数

CLKR=1;//在74HC595处锁存起来

CLKR=0;

CLKR=1;

LINE=line;//打开行

delay(10);

}

}

/******************************************/

/****快速将一个字上移16次,即一个整体字****/

/******************************************/

void shangla()

{

uchar i;

while(word<128)

{

for(i=0;i<16;i++)//循环16次将一个字上移16次

{

shang1();//调用显示

word+=1;

}

for(i=0;i<150;i++)//上移完一个字后,停留一段时间,从而形成上拉

shang1();

}

}

/************************************************************/

/************************************************************/

/**************************下拉函数***************************/

/************************************************************/

/************************************************************/

/********************显示一个字子程序************************/

void xia1()

{

ji=word;

for(line=0;line<16;line++)//循环16次显示一个字

{

song(~table1[ji*2+1]);

song(~table1[ji*2]);

ji++;

CLKR=1;//在74HC595处锁存起来

CLKR=0;

CLKR=1;

LINE=line;

delay(3);

}

}

/********************将一个字上移16次形成下拉子程序************************/

void xiala()

{

uchar i;

while(word>1)

{

for(i=0;i<16;i++)//将一个字下位16次

{

xia1();//调用显示子程序

word-=1;//下拉1位

}

for(i=0;i<150;i++)//下拉16次后停下来

xia1();//调用显示

}

}

/************************************************************/

/************************************************************/

/**************************左拉子函数************************/

/************************************************************/

/************************************************************/

/********************************/

/*将一行数据转换出来,然后显示*/

/********************************/

void yipai2()

{

uchar temp,yi;

if(move<8)//处理移动次数小于8次的部分

{

yi=move;

temp=(BUF[1]>(8-yi));/*将第1个字的右半屏数左移yi次,

然后或上第2个字左半屏的8-yi次数,注此句是处理右半屏的数*/

song(~temp);//发送给74HC595

temp=(BUF[0]>(8-yi));/*将第1个字的左半屏数左移yi次,

然后或上第1个字右半屏的8-yi次数,注此句是处理左半屏的数*/

song(~temp);//发送给74HC595

}

else//处理移动次数小于8次以外的部分

{

yi=move-8;

temp=(BUF[2]>(8-yi));//原理同上

song(~temp);//发送给74HC595

temp=(BUF[1]>(8-yi));//原理同上

song(~temp);//发送给74HC595

}

}

/********************************/

/*******将一个字移一位***********/

/********************************/

void zou3()

{

for(line=0;line<16;line++)//扫描16次,即完成一个字的移动

{

yixian();//调用一线子程序

yipai2();//调用数据转换子程序

LINE=line;//打开行线,即174HC154行线端

CLKR=1;//在74HC595处锁存起来

CLKR=0;

CLKR=1;

}

}

/********************************/

/*将一个左移16次,形成一个字左拉***/

/********************************/

void zoula()

{

uchar x;

while(word<256)

{

for(move=0;move<16;move++)//要移多少位?

zou3();

for(x=0;x<150;x++)

zou3();

word=word+32;//一个字显示完了,就显示下一个字

}

}

/************************************************************/

/************************************************************/

/**************************右拉子函数***************************/

/************************************************************/

/************************************************************/

/********************************/

/*将一行数据转换出来,然后显示*/

/********************************/

void yipai3()

{

uchar temp,yi;

if(move<8)//处理移动次数小于8次的部分

{

yi=move;//小于8次就直接给移动的次数

temp=(BUF[0]<(8-yi))|(BUF[1]>>yi);/*将第1个字的左半屏数左移8-yi次,

然后或上右半屏的yi次数,注此句是处理右半屏的数*/

song(~temp);//发送给74HC595

temp=(BUF[3]<(8-yi))|(BUF[0]>>yi);/*将第2个字的右半屏数与第1个字左

半屏的数左移8-yi次,然后或上右半屏的yi次数,注此句是处理左半屏的数*/

song(~temp);//发送给74HC595

}

else//处理移动次数小于8次以外的部分

{

yi=move-8;//不小于8次就给move-8次给变量

temp=(BUF[3]<(8-yi))|(BUF[0]>>yi);/*将第2个字的右半屏数左移8-yi次,

然后或上第1个字左半屏的yi次数,注此句是处理右半屏的数*/

song(~temp);//发送给74HC595

temp=(BUF[2]<(8-yi))|(BUF[3]>>yi);/*将第2个字的左半屏数左移8-yi次,

然后或上第2个字的右半屏的

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

网站地图

Top