|
我的电路图如下:
8*8的行共阳点阵,74ls164驱动行,74hc154驱动列。164得到数据后,154导通,该列指定的led亮。目前给的数据是0x7e,就是一行里中间6个led亮,两边的led不亮。
代码如下:
#include <reg52.h>
#include <intrins.h>
#include <stdio.h>
#define ITM_Port8(n) (*((volatile unsigned char *)(0xE0000000+4*n)))
#define ITM_Port16(n) (*((volatile unsigned short*)(0xE0000000+4*n)))
#define ITM_Port32(n) (*((volatile unsigned long *)(0xE0000000+4*n)))
#define DEMCR (*((volatile unsigned long *)(0xE000EDFC)))
#define TRCENA 0x01000000
char putchar(char s)
{
SBUF=s;
while(TI==0)
{
_nop_();
}
TI=0;
}
sbit COW_1641 = P0^0;
//sbit COW_1642 = P0^2;
sbit CLK_1641 = P0^1;
sbit CLK_1642 = P0^3;
sbit CLE_1641 = P0^2;
unsigned char colcount[16]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
unsigned char code image[8] = {0x00,0x00,0x7E,0x50,0x50,0x50,0x00,0x00};
unsigned char i = 0; //动态扫描的索引
unsigned int cnt = 0; //记录 T0 中断次数
unsigned char flag1s = 0; //1 秒定时标志
void delay(unsigned int delay){
unsigned char i;
for(;delay>0;delay--)
for(i=0;i<150;i++);
}
void main(){
unsigned long sec = 0; //记录经过的秒数
TMOD = 0x01; //设置 T0 为模式 1
TH0 = 0xFC; //为 T0 赋初值 0xFC67,定时 1ms
TL0 = 0x67;
ET0 = 1; //使能 T0 中断
TR0 = 1; //启动 T0
while ( 1 ) {
}
}
/* 定时器 0 中断服务函数 */
void InterruptTimer0() interrupt 1 {
unsigned int col,coldata,speed;
unsigned char temp;
TH0 = 0xFC; //重新加载初值
TL0 = 0x67;
//以下代码完成数码管动态扫描刷新
for (col=0;col<8;col++){
P2=col;
//temp=image[col];
temp=0x7E;
printf("col = %u temp 1 = 0x%X \n", col, temp);
for(coldata=0;coldata<8;coldata++){
printf("coldata = %u temp&0x80 = 0x%X \n",coldata,temp);
CLK_1641 = 0;
COW_1641=temp&0x80;
printf("coldata = %u COW_1641 = 0x%X \n",coldata,COW_1641);
CLK_1641 = 1;
temp<<=1;
printf("temp <<1 = 0x%X \n",temp);
}
}
}
代码都是网上找的现成的例子。然后再proteus里一步一步运行的时候,显示的效果是一行里有两个相邻的led不亮,而且这两个不亮的led在这行里的位置是随机的,还没有找到规律,运行效果我截图了。
于是我就在程序里用printf输出几个值,看看是哪里的问题。现在的没有找到问题的原因。我的问题如下:
1、这样的运行效果代码哪里有问题,该如何修改?
2、还有就是我原来的问题,COW_1641=temp&0x01运算之后,printf函数输出COW_1641应该是什么值?
|
|