自己DIY动态数码管的实验时,发现控制4节数码管和8节数码管的消隐操作有所差别,思考理顺后作此篇总结。
一、假设:
P2控制数码管COM口,给0通,给1灭。
printNum()控制数码管段码端,段码中给0亮 给1灭。
二、示例代码
示例1:
for(i=0;i<8;i++)
{
P2=~(1<<(7-i)); //7-i位COM口打开,其他全关闭
printNum(screenNum[i]); //显示数字
j=8;
while(j--) ; //延时
P0=0x0; //消隐
}
- 调整所有COM口后再显示数字,显示完数字要让数字熄灭,否则会影响下一个显示的数字
示例2:
for(i=0;i<4;i++)
{
P2 &=~(1<<(7-i)); //7-i位COM口打开
printNum(screenNum[i]); //显示数字
j=8;
while(j--); //延时
P2 |=1<<(7-i); //7-i位COM口关闭
P0 |=0xf0; //将数字熄灭
}
- 打开某个COM口后显示数字,显示完数字后,要把该位COM口关闭,并将数字熄灭,否则会影响下一个显示的数字。
示例3:
for(i=0;i<4;i++)
{
printNum(screeenNum[i]); //准备好数字
P2 &=~(1<<(7-i)); //7-i位COM口打开
j=8;
while(j--); //延时
P2 |=1<<(7-i)); //将高四位COM口全部断开
}
- 先准备好需要显示的数字,再打开某个COM口,显示完后把COM口关闭。
三、总结
示例1是由P2控制8个数码管,可以一次性对所有COM口进行赋值:P2=~(1<<(7-i));
示例2和示例3是P2只控制4个数码管,其他没有用到的P2引脚要保持不变,所以只能通过与运算&来给单个COM口进行赋值:P2 &=~(1<<(7-i));
这样就存在一个问题,示例1编程时无需另外对打开了的COM口进行关闭操作,因为每次赋值都会重新调整所有COM口;而示例2和示例3编程时则需要另外对打开了的COM口进行关闭操作。否则会出现上一个数字重叠在当前数字的错误。
四、补充
注1:示例1和示例2的方法均是先打开COM口再给数字,这样的话一旦显示数字后没有记得熄灭数字,就会影响到第二个显示的数字。而示例3的方法是先准备好数字,然后再打开COM口,准备数字期间所有的COM口都是关闭的。
注2:示例2和示例3其实只是printNum()和P2 &=~(1<<(7-i));两句代码顺序的调换,示例3却能少掉一句”P0 |=0xf0;”,将数字熄灭这个操作。