软件延时:(asm)
晶振12MHZ,延时1秒
程序如下:
DELAY:MOV 72H,#100
LOOP3:MOV 71H,#100
LOOP1:MOV 70H,#47
LOOP0:DJNZ 70H,LOOP0
NOP
DJNZ 71H,LOOP1
MOV 70H,#46
LOOP2:DJNZ 70H,LOOP2
NOP
DJNZ 72H,LOOP3
MOV 70H,#48
LOOP4:DJNZ 70H,LOOP4
定时器延时:
晶振12MHZ,延时1s,定时器0工作方式为方式1
DELAY1:MOV R7,#0AH 晶振12MHZ,延时0.5秒
AJMP DELAY
DELAY2:MOV R7,#14H 晶振12MHZ,延时1秒
DELAY:CLR EX0
MOV TMOD,#01H设置定时器的工局早局作方式为方式1
MOV TL0,#0B0H给定时器设置计数初始值
MOV TH0,#3CH
SETB TR0 开启定时器
HERE:JBC TF0,NEXT1
SJMP HERE
NEXT1:MOV TL0,#0B0H
MOV TH0,#3CH
DJNZ R7,HERE
CLR TR0 定时器要软件清零
SETB EX0
RET
C语桐让言延时程序:
10ms延时子程序(12MHZ)
void delay10ms(void)
{
unsigned char i,j,k
for(i=5i>0i--)
for(j=4j>0j--)
for(k=248k>0k--)
}
1s延时子程序(12MHZ)
void delay1s(void)
{
unsigned char h,i,j,k
for(h=5h>0h--)
for(i=4i>0i--)
for(j=116j>0j--)
for(k=214k>0k--)
}
200ms延时子程序(12MHZ)
void delay200ms(void)
{
unsigned char i,j,k
for(i=5i>0i--)
for(j=132j>0j--)
for(k=150k>0k--)
}
500ms延时子程序程序: (12MHZ)
void delay500ms(void)
{
unsigned char i,j,k
for(i=15i>0i--)
for(j=202j>0j--)
for(k=81k>0k--)
}
下面是用了8.0000MHZ的晶振的几个延时程序(用定时0的工作模式1):
(1)延时0.9MS
void delay_0_9ms(void)
{
TMOD=0x01/*定时器0工作在模式1下(16位计数器)*/
TH0=0xfd
TL0=0xa8
TR0=1/*启动定时器*/
while(TF0==0)
TR0=0
}
(2)延睁陵时1MS
void delay_1ms(void)
{
TMOD=0x01/*定时器0工作在模式1下(16位计数器)*/
TH0=0xfd
TL0=0x65
TR0=1/*启动定时器*/
while(TF0==0)
TR0=0
}
(3)延时4.5ms
void delay_4_5ms(void)
{
TMOD=0x01/*定时器0工作在模式1下(16位计数器)*/
TH0=0xf4
TL0=0x48
TR0=1/*启动定时器*/
while(TF0==0)
TR0=0
}
没用过这款单片机,但是大和团燃致代唤虚码如下定义一个按键或慧key 控制倍数
char beishu=1;
if(key被按下)//倍数选择 共1 2 3三档最好加个按键防抖程序
{
if(beishu=4)
beishu=1;
beishu++;
}
然后延时程序这样写
for(j=1500000*beishu;j>0;j--)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)