LJMP MAIN ORG 0100H MAIN: SETB P1.7 ; LED 灭 LL1: SETB P1.0 JB P1.0, LL1 MS: CPL P1.7 ; LED 慢 闪 MOV R7,#255 LCLL YS LL2: SETB
void main (void){ KEY=1; //按键输入端口电平置高 while (1) //主循环 { if(!KEY) //如果检测到低电平,说明按键按下 LED=0;else LED=1; //这里使用if判断,如果按键按下led点亮,否则熄灭 //上述4
LJMP EXT0 ;外部中断0,控制流水灯启停 ORG 000BH LJMP T0ISR ;定时0控制流水灯循环点亮 ORG 0030H MAIN:MOV TMOD,#01H ;设置定时器0工作模式 MOV TH0,#HIGH(65536-60000) ;60毫秒定时 MOV TL0,#LO
far @interrupt void TIM1_UPD_OVF_IRQHandler(void){ TIM1_SR1 = 0x00; // 清除更新标志 } far @interrupt void EXTI0 (void)//外部中断子函数 { if(PA_on){ sbi(PA_ODR,4);PA_on=0;}//PA4为灯亮
单片机用外部中断0实现:一个亮的LED灯,当按下按键后,闪烁2下,继续恢复原来状态。
LED6=1;LED7=0;LED8=0;Delay(500);LED7=0;LED8=0;} } 备注:1、led对应引脚可以修改,程序中默认单片机引脚低电平点亮led,如果是高电平点亮 led,反过来设置引脚电平就可以了;2、延时时间可以按自己需要修改;3、
51单片机输出pwm波控制led灯亮度 频率50HZ,周期是20ms 看你调节的精度 如定时器定时1ms,高电平宽度一次变化是5 如果想要调节精度高,定时器定时时间小,就要频繁地发生中断,会影响主程序的运行 如 要求占空比每步调节为1%
以上,把P3^7改为led=0; void lignt() interrupt 0中的led=0改为led=1; 另,延时可以不要。按住不放可实现LED一直亮。
是不是按一下开关触发中断,使LED闪烁,再按一下,LED熄灭?LED EQU P1.0 ORG 0000H LJMP MAIN ORG 0003H LJMP EXT0 ORG 0030H MAIN:MOV TMOD,#01H MOV TH0,#HIGH(65536-41667)MOV TL0,#LOW(65536-41667)SET
51单片机通过外部中断和开关控制LED闪亮
循环点亮LED灯,也就是流水灯效果的控制,可以用定时器来控制,这样做相对代码量较少而时间比较精确,外部中断0接以按键,可以控制动态效果的启停。程序如下:ORG 0000H LJMP MAIN ORG 0003H LJMP EXT0 ;外部中断0,
delay(1000); delay(1000); led=_crol_(led, 1); delay(1000); delay(1000);}}}void xianshi2(){ led=0xfe;if(temp==2){num=8;while(num--){ dat=led; delay(1000); delay(
单片机控制led灯亮和灭,led灯初始状态从左到右两个灯间隔一个灯循环亮灭,然后从右到左循环亮灭,,当按下按键,led灯全亮,然后全灭。然后再恢复循环。二、实验过程 (一)实验项目的方案分析 1.设计原理 STC12C5A
按键位置:P0.1;功能:1,当第一次按键按下,第一个灯亮,按键放开灯灭 2,当第二次按键按下,第二个灯亮,按键放开灯灭 3,重复执行前面两个步骤 灯的位置:P2口;/ include
1、首先打开桌面上的keil软件,在进行对51单片机进行编程时最常用的就是keil软件。2、编写相应的代码:#include
for(i = 0; i < x; i++) for(j = 0; j <= 148; j++);} //KEY1按一下LED1亮 再按一下LED1灭 //KEY2按下LED2亮 LED1灭 main(){ while(1) { if (!key2) { led1 = 1; led2 = 0;} el
P2IFG =0; //中断标志清除,防止配置过程中出现中断标志为1 _EINT(); //开总中断 LPM4; //进低功耗4 } /***端口中断程序***/ pragma vector = PORT2_VECTOR __interrupt void port2(void){ switch
用外部中断,按一次键,两个LED灯点亮,再按一次,两个LED灯熄灭,循环。用Keil(C语言)编译
单片机的P2.5,P2.6,P2.7口分别接三位动态数码管的位选端,P0口接动态数码管的段选端。然后,P1.0口接一个电阻串联一个LED灯然后接地,电阻取200~470欧之间就行,是一个限流电阻。中断用的是外部中断0,要触发
是不是按一下开关触发中断,使LED闪烁,再按一下,LED熄灭?LED EQU P1.0 ORG 0000H LJMP MAIN ORG 0003H LJMP EXT0 ORG 0030H MAIN:MOV TMOD,#01H MOV TH0,#HIGH(65536-41667)MOV TL0,#LOW(65536-41667)SET
PNP:将NPN三级管反过来接就行了(例如NPN发射极接地的话 PNP就集电极接地)。程序:头文件略 sbit P1.0=D1; //位声明 void delay(int x)main{ while(1){ D1=1; //NPN 1亮 PNP 0亮;delay(500); /
void INT0_ROUTING() interrupt 0//外部中断0子程序 { P0=0xfe;//LED0点亮 while((P3|0xfb)==0xff);//等待外部中断0口(P3^2松开)delay(10);//延时去抖动 P0=0xff;//LED0熄灭 } void INT0_ROUTING() i
1 你的程序中使用的控制引脚为P1.1与电路图中控制LED的引脚P1.0也没有对应上啊 2 修改如下:include "reg51.h"sbit P1_0=P1^0;void main(){ P1_0=0; \\ P1.0为低电平时, LED为灭 } 3
sbitled=P1^0;void main(void){ IT0=1;IT1=1;EX0=1;EX1=1;EA=1;while(1);} void int0(void)interrupt 0//外部中断0 { led=0;} void int1(void)interrupt 2//外部中断1 { led=1;} 第二题是指,每秒
while(!key);//等待按键松开 led=~led;} } flag_int1=0; //标志位清零 }EX1=1;//重新开始中断 } //外部中断初始化 void init_int1(void){ IT1=1;//边沿触发 EX0=1; //开总中断 EX1=1; //开外中断
求单片机程序 LED灯连接在P1.0管脚,要求使用外部中断0开灯,外部中断1关灯。
;led1=0;led2=1;led3=1;}if(s2==0){while(s2==0);led1=1;led2=0;led3=1;}if(s3==0){while(s3==0);led1=1;led2=1;led3=0;}if(s4==0){while(s4==0);led1=0;led2=0;led3=0;}}}
sbit led3=P0^2;sbit led4=P0^3;unsigned char a;main(){ while(1){ if(key==0){ while(key==0);a++;a%=9;} switch(a){ case 1:led1=0;led2=1;led3=1;led4=1;break;case 2:led1=0;led2=0
很简单的。循环(1){ 检测按键,等待按下;发现按下后,延时消抖,等待释放,然后执行下面的循环;循环(1){ //循环检测1秒钟 发现按下后,灯亮,等待释放,然后就跳出循环;延时10ms;次数加一;次数不到100,继续循环
include
代码 include
因为程序里面一旦进入外部中断,就把P1.0管脚翻转一下,如果接了LED就会有亮灭的变化。“P10=!P10 是什么意思”、将P1.0管脚的输出电平翻转。“为什么我改成P20=!P20就报错”因为程序里只定义了P10,P20这个符号没有
求讲解这段STC15单片机的代码,外部中断2让LED灯亮?
51单片机来实现60个led灯循环点亮的程序://***汇编程序:include
MAIN:MOVA,#0FFH;设置左移初值 CLRC;C=0 MOVR2,#08H;设置左移次数 LOOP:RLCA;左移1位 MOVP1,A;输出到P1 CALLDELAY;延时 DJNZR2,LOOP;左移7次 MOVR2,#07H;LOOP1:RRCA;右移1位 MOVP1,A;输出到P1 CALLDELAY;
1:你写汇编程序注意程序的入口地址,比如:“ORG 0000H,主程序开始的入口ORG 0100,中断程序开始的入口 ORG 0200等等”。你要知道汇编和C不同,汇编比起C语言要相对机械一些。汇编程序是写入硬件内部的,严格的配合硬
far @interrupt void TIM1_UPD_OVF_IRQHandler(void){ TIM1_SR1 = 0x00; // 清除更新标志 } far @interrupt void EXTI0 (void)//外部中断子函数 { if(PA_on){ sbi(PA_ODR,4);PA_on=0;}//PA4为灯亮
LJMP T0ISR ;定时0控制流水灯循环点亮 ORG 0030H MAIN:MOV TMOD,#01H ;设置定时器0工作模式 MOV TH0,#HIGH(65536-60000) ;60毫秒定时 MOV TL0,#LOW(65536-60000)SETB ET0 SETB EA MOV A,#0FEH ;
单片机汇编语言程序,我想写一个循环点亮的LED,然后用外部中断0接到一个按键上,怎么写我需要详细的程序
1)P2口的8个脚对应8个LED;设D1灯对应高位,D8灯对应低位; 2)P1口的P1.0脚对应XO按钮;P1.1脚对应X1按钮; 3)开始时,显示第一种方式:向P2口写入a=01111111,延时0.5S,a 循环右移一位,再延时0.5S,如此反复。 4)当收到XO按钮信号后,向P2口写入a=01111111,延时1.5S,a 循环右移二位,再延时1.5S,如此反复。 5)当收到X1按钮信号后,向P2口写入a=10111111,延时1S,a 带进位右移二位,再延时1.5S,如此反复。当Cy=0时,执行 3)。在四个灯循环点亮的状态下,每点亮一个灯需要延时,如果调用延时子程序,按键就显示不灵敏了,所以,采用定时器中断的方式控制延时,就不影响按键了。 #include #include 仿真图效果。
main() { // CLK_CKDIVR=0x00; CLK_Init(); IO_Init(); led_on=0; //timer1_init(); EXTI_DeInit();?/初始化外部中断IO口 _asm("rim"); while(1) { cbi(PA_ODR,4); } } @far @interrupt void TIM1_UPD_OVF_IRQHandler(void) { TIM1_SR1 = 0x00; // 清除更新标志 } @far @interrupt void EXTI0 (void)//外部中断子函数 { if(PA_on) { sbi(PA_ODR,4);PA_on=0;}//PA4为灯亮 else { cbi(PA_ODR,4);PA_on=1;}//PA4为灯灭 EXTI_CR1=0x00 ; } 不懂再追问,你只需要把主程序里面的灯定为一个状态,外部中断里面再定一个状态。要亮2次,加个延时,就行了。
使用方法: 单片机的P2.5,P2.6,P2.7口分别接三位动态数码管的位选端,P0口接动态数码管的段选端。然后,P1.0口接一个电阻串联一个LED灯然后接地,电阻取200~470欧之间就行,是一个限流电阻。 中断用的是外部中断0,要触发中断的时候,就用一根杜邦线一端接地,一端接到单片机的P3.2口就行,这样,就满足了你的要求了。 外部中断的触发方式有低电平触发和下降沿触发。到底是那种触发方式,要设置中断允许寄存器中IT0的值,如果IT0=0,像我写的程序,就是低电平触发,如果为1,就是下降沿触发。 灯不是一定要接到P3.2口上的。中断要执行的任务是在中断函数中写代码控制的,就像我写的代码中,你只需要控制LED灯接的那个IO口就行了。 代码如下: #include #define uchar unsigned char sbit led=P1^0; uchar code duan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; uchar code wei[3]={0x06,0x05,0x03}; void delay(uchar c); void ini_() //初始化函数,设置中断触发方式,开中断 { EA=1; IT0=0; EX0=1; } void main() { uchar i; ini_(); led=0; //由于单片机上电之后,所有的IO口默认是高电平,而要求是开始不亮,所以要将P1.0口开始设置为低电平。 while(1) { for(i=0;i<3;i++) 动态数码管闪烁 { P2=wei[i]; P0=duan[i]; delay(35); } } } void led_() interrupt 0 //外部中断0函数,中断函数不需要申明 { uchar i; led=1; //在中断中让灯亮起来 while(1) { for(i=0;i<3;i++) { P2=wei[i]; P0=duan[i]; delay(1); } } } void delay(uchar c) { uchar a,b; for(c;c>0;c--) for(a=38;a>0;a--) for(b=80;b>0;b--); }
“为什么按下外部中断键就能让LED灯亮一下” 因为程序里面一旦进入外部中断,就把P1.0管脚翻转一下,如果接了LED就会有亮灭的变化。 “P10=!P10 是什么意思”、 将P1.0管脚的输出电平翻转。 “为什么我改成P20=!P20就报错” 因为程序里只定义了P10,P20这个符号没有定义,你需要自己添加 sbit P20 = P2^0; “开发板的外部中断焊接到单片机的P1.0引脚,如果我焊接的不是P1.0引脚,那P10=!P10还好使吗” 外部中断跟P1.0管脚没有关系。你重新看电路图去…… “为什么头文件加上#include“STC15.H”就会报错” 因为编译器找不到这个文件在哪儿,当然就会嗷嗷叫唤……
中断处理函数感觉有些问题,for循环之前使用P1=0x0f;然后将for内的P1=0x0f;改为 P1= ~ P1; 同时for 循环中应该需要调用延时函数 Delay(10); 这里的值看你自己设置,保证能分辨闪烁即可
main() { // CLK_CKDIVR=0x00; CLK_Init(); IO_Init(); led_on=0; //timer1_init(); EXTI_DeInit();?/初始化外部中断IO口 _asm("rim"); while(1) { cbi(PA_ODR,4); } } @far @interrupt void TIM1_UPD_OVF_IRQHandler(void) { TIM1_SR1 = 0x00; // 清除更新标志 } @far @interrupt void EXTI0 (void)//外部中断子函数 { if(PA_on) { sbi(PA_ODR,4);PA_on=0;}//PA4为灯亮 else { cbi(PA_ODR,4);PA_on=1;}//PA4为灯灭 EXTI_CR1=0x00 ; } 不懂再追问,你只需要把主程序里面的灯定为一个状态,外部中断里面再定一个状态。要亮2次,加个延时,就行了。
/* 按键位置:P0.1; 功能:1,当第一次按键按下,第一个灯亮,按键放开灯灭 2,当第二次按键按下,第二个灯亮,按键放开灯灭 3,重复执行前面两个步骤 灯的位置:P2口; */ #include #define uint unsigned int #define uchar unsigned char sbit BUTTON=P0^1;//按键的位置 void DELAY(uint x) { uchar s,j; for(s=0;s<x;s++) for(j=0;j<114;j++); } void main() { uint led=0; while(1) { if(BUTTON==0) { led++; if(led==1)//第一次按键按下 { P2=0XFE;//1111 1110 第一个灯亮 DELAY(500);//延时 while(BUTTON!=0)//等待按键放开 { P2=0xff;/1111 1111灯灭 DELAY(500)//延时 } } if(led==2)//第二次按键按下 { led=0;//要给次数初始化 P2=0XFC;//1111 1101第二个灯亮 DELAY(500);//延时 while(BUTTON!=0)//等待按键放开 { P2=0xff;//1111 1111第二个灯灭 DELAY(500)//延时 } } } }
main() {P3^7=0; EA=1;EX0=1;IT0=1;while(1);} void lignt() interrupt 0 { led=0; delay(100);} 以上,把P3^7改为led=0; void lignt() interrupt 0中的led=0改为led=1; 另,延时可以不要。按住不放可实现LED一直亮。
while(1) { if(num>=20) //num==20最好改成 >=20 防止由于按銉延时而错过num==20的机会而使程序出现长时的混乱 { num=0; led1=~led1; led2=~led2; } if (KEY==0)//按键是否按下 { 延时10-20MS; while(KEY==0);//按键是否抬起 if (TR0==1)TR0=0: else TR0=1: } } 也可以用开关中断来实现 如果按键不听使唤,在if (KEY==0)后大括号里的延时语句后再加一次if (KEY==0)判断
请你参考: 电路 代码 #include#define LED P2unsigned char step;void Delayms(unsigned int x){ unsigned char t; while(x--) for(t=0;t<120;t++);}void main(){ unsigned char i,j; TCON|=0x01; IE|=0x81; i=0; j=0xFF; step=0; while(1) { switch(step) { case 1: LED=~(1<<i);break; case 2: j=j^0xFF;LED=j;break; case 3: LED=0x00;break; } i=++i%8; Delayms(200); }}void EX0_INT() interrupt 0{ EX0=0; Delayms(10); if(++step==4) step=1; EX0=1;}希望对你有所帮助!!!!
#define LED P1 sbit key=P2𠆢0; void main() {LED=0x0F; while(1) {if(key==0) {delayms(10); if(key==0){ LED=0;delayms(500);LED=0x0FF;delayms(500); LED=0;delayms(500);LED=0xFF;delayms(500); LED=0;delay(500);LED=0xFF;delayms(500); } LED=0x0F; } } }