Mình làm mạch led ma trận 8x8,dùng 1 nút nhấn nối vào ngắt ngoài P3_2 để đổi qua lại các hiệu ứng cho led,có tất cả 5 hiệu ứng,vấn đề là khi mình nhấn nút thì hiệu ứng đang chạy có tắt đi,nhưng nó không đổi sang hiệu ứng tiếp theo mà tắt ngúm luôn, mô phỏng cũng như mạch thật, riêng mạch thật thì khi nhấn nút liên tục thì "hên xui" nó lại chạy,còn mô phỏng thì ko hề chạy luôn,không biết là do phần cứng hay phần mềm,mình nối nút nhấn xuống âm nguồn,và mắc trở 2,2k nối lên dương,lúc code ít thì nó hoạt động khá tốt nhưng code nhiều lên thì ko biết sai chỗ nào,cái này mình tự học nên code hơi dài dòng hoặc thừa thiếu chỗ nào mong được mọi người chỉ giáo, xin chân thành cảm ơn
#include <REGX52.H>
#include <Codetable.H>
/************************************************** *********/
unsigned char k,e=0,b,d,f=0,g,c;
unsigned char n,m,i,j,count,time1,time2;
/************************************************** *********/
void delay(unsigned int ms) //ham delay
{
for(c=0;c<ms;c++)
{
if(e==0) break;
if(f!=b) break;
for(d=0;d<121;d++);
{
if(e==0) break;
if(f!=b) break;
}
}
}
/************************************************** ********/
/************************************************** ************/
void a1(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=1;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c1[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a2(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=2;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c2[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a3(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=3;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(!P3_2) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c3[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a4(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=4;
for(i=1;i<=time1;++i)
{
for(j=0;j<26;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c4[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==182) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a5(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=5;
for(i=1;i<=time1;++i)
{
for(j=0;j<26;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c5[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==182) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void main()
{
IT0=1;EX0 = 1; EA = 1;
while(1)
{
a2(50,50);
a4(50,50);
a5(50,50);
}
}
void nutnhan() interrupt 0
{
delay(20);
if(!P3_2)
{ e=1;f=b+1;
count=0;
do
{
delay(20);
count++;
}
while((count<100)&&(!P3_2));
if (count==100)
{
P2=0x00;e=0;
while(!P3_2);
}
}
}
#include <REGX52.H>
#include <Codetable.H>
/************************************************** *********/
unsigned char k,e=0,b,d,f=0,g,c;
unsigned char n,m,i,j,count,time1,time2;
/************************************************** *********/
void delay(unsigned int ms) //ham delay
{
for(c=0;c<ms;c++)
{
if(e==0) break;
if(f!=b) break;
for(d=0;d<121;d++);
{
if(e==0) break;
if(f!=b) break;
}
}
}
/************************************************** ********/
/************************************************** ************/
void a1(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=1;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c1[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a2(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=2;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c2[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a3(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=3;
for(i=1;i<=time1;++i)
{
for(j=0;j<16;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(!P3_2) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c3[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==112) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a4(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=4;
for(i=1;i<=time1;++i)
{
for(j=0;j<26;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c4[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==182) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void a5(time1,time2) //time = thoi gian tre,code chay nhanh hay cham
{
k=0;b=5;
for(i=1;i<=time1;++i)
{
for(j=0;j<26;++j) // so 28 la so dong cua code cot
{
if(e==0) break;
if(f!=b) break;
for(m=1;m<=time2;++m)
{
if(e==0) break;
if(f!=b) break;
for(n=0;n<7;++n) // neu' quet' 8 hang` thi <=7, neu' quet' 7 hang` thi` <7
{
if(e==0) break;
if(f!=b) break;
P0= quet[n];
P2 = c5[n+k];
delay(1);
P2=0x00;
}
}
k=k+7;
if(k==182) k=0; //so 196 = so "k = k+7" nhan voi so "m < 28"
}
}
e=0;
}
/************************************************** ********/
/************************************************** ************/
void main()
{
IT0=1;EX0 = 1; EA = 1;
while(1)
{
a2(50,50);
a4(50,50);
a5(50,50);
}
}
void nutnhan() interrupt 0
{
delay(20);
if(!P3_2)
{ e=1;f=b+1;
count=0;
do
{
delay(20);
count++;
}
while((count<100)&&(!P3_2));
if (count==100)
{
P2=0x00;e=0;
while(!P3_2);
}
}
}
Comment