LED点阵显示与C语言编程 下载本文

void main(void) {

uchar N,T,m,n; for(m=0;m<6;m++) for(n=0;n<8;n++)

Buffer[8*m+n]=TAB[7-n+m*8]; //将TAB数组中的数据重新排列 //使得下移字母顺序不变 while(1) {

for(N=0;N<40;N++) //循环扫描一遍6帧 for(T=0;T<70;T++) //速度 {

P2=0x80;

for(i=0;i<8;i++) {

P1=Buffer[i+N]; delay(100);

P2=P2>>1|P2<<7; //扫描起始行为第一行 } } } }

四、行扫描左右移动显示。 如果将扫描方式改为列扫描,那么左右移动的程序就容易写了,但当点阵比较巨大并且硬件已经定下时,改变扫描方式不是好方法,甚至不可能实现。这里是以行扫描为例(逐行取字模),第一次取字码数组中的第1~8个数据到点阵列输入端,行码 扫描1~8行。第二次将第一次的 1~8个数据都循环左(右)移一位,并且将第9个数据的最高位移到第二次数据的最低处,再输入到列端口,行扫描1~8行。即每次扫描都要把前一次扫描的列码左移一位。

图7 图8 图7为左移效果,程序如下: /*8X8行扫描,左移显示*/ #include

#define uchar unsigned char #define uint unsigned int

uchar code TAB[]={0xFF,0xF7,0xFB,0x81,0xFB,0xF7,0xFF,0xFF}; uchar i,t,j=0;

delay(uchar t) {

while (t--) {;} }

void main(void) { uchar T,Y,Q; while(1) {

for(Q=0;Q<8;Q++)

for(T=0;T<100;T++) //速度 {

P2=0x01;

for(i=0;i<8;i++) {

Y=TAB[i+1]*256+TAB[i]; Y=Y<<(7-Q)|Y>>Q; P1=Y%6; delay(60);

P2=P2<<1|P2>>7; } } } }

类别:电子技术 | | 添加到搜藏 | 分享到i贴吧 | 浏览(2563) | 评论 (23)

上一篇:16×32双色LED点阵动画制作 下一篇:PCB转原理图的巧妙方法

?2011 Baidu hao niu good

我们可以交朋友吗 回复魔魂狂刀:当然

太好了!谢谢了

佩服,可以交个朋友吗?wo ye 喜欢用c语言编程,但是个初学者,能指点一下我吗? 回复sunpengpeng123:互相学习,我编程并不好

能加QQ317912348,初学者,多多指教,LED还有其他编程语言不 回复jinm1122:希望在这里讨论。 回复欠一个吻:好的, 请问左移的思想是:::

第一次取字码数组中的第1~8个数据到点阵列输入端,行码 扫描1~8行。第二次将第一次的 1~8个数据都循环左(右)移一位,并且将第9个数据的最高位移到第二次数据的最低处,再输入到列端口

程序中的语句是:

Y=TAB[i+1]*256+TAB[i]; Y=Y<<(7-Q)|Y>>Q;

能解释这两条语句的意思吗?我看不懂。谢谢!

回复weihegeng:TAB表中的数据都是8位二进制数, Y=TAB[i+1]*256+TAB[i];的含义是将第“i+1”个数和第“i”个数组合成16位二进制数,“i+1”是高八位,然后将这16位二进制数据赋给Y。

Y=Y<<(7-Q)|Y>>Q; 表示将数据Y循环右移Q位。 基础学习

很清晰,很透彻~谢谢~ 很明白 谢啦 哈哈

好,早看到这篇文章,我就不用辛苦地自己摸索了。 呵呵,赞一个!

Y=TAB[i+1]*256+TAB[i];

这条语句当i=7时,就该程序而言不是超过界限了吗? 回复Knukles:确实是,不过运行出来是想要的结果。

你好,有几个问题想请教你:Y=TAB[i+1]*256+TAB[i]; 首先你定义的Y是uchar类型,一次只能装8位,其次TAB[i+1]*256相当于左移8位,但是你的数组的类型也是uchar,如果这样的话你移掉的8位放哪?同理 TAB[i] 您能否具体讲解你的数据处理思路: Y=TAB[i+1]*256+TAB[i]; Y=Y<<(7-Q)|Y>>Q; P1=Y%6;

回复欠一个吻:i=7 时,TAB[i+1]跳到数组结束后的第一个数组,在c语言中是合法的,但是其内容是不确定的,这种越界可以说是成为“临界”状态,在一些数据处理中能发挥代码简练优化的作用,比如说求和.....

好友名片加载中...