51单片机 多种格式串口控制LED源码: http://www.51hei.com/bbs/dpj-163182-1.html,适合新手
拉动时候肯定有事件产生,你在窗体增加控件.事件 += new ```就ok啦。然后事件处理函数里再去开关或者切换led灯
自己定义一套协议就行,比如单片机收到上位机发送数据A1,A2,B1,B2 A1表示LED亮,A2表示LED灭,B1表示数码管亮,B2表示数码管灭,
pc通过串口和单片机交换数据,从而控制LED灯。 pc程序用labview 调用Visa 进行串口通讯。单片机接受到串口命令后控制I/O口的高低电平实现led灯亮灭控制。用串口调试助手就行,网上到处可以下载。也好用。关键问题是在电脑上发送
sbit K1=P3^2; //对应开发板K1按键 /*---*/ //串口初始化 void UART_Init(void){ SCON = 0x50; //串口工作方式为1 , 串行允许接收 //SM0=0;//SM1=1;//REN=1;TMOD = 0x20; //定时器1 工作在方式2
求单片机串口通信协议,做设计要求:上位机通过串口实现点亮和灭3盏LED灯,不太懂协议,最好有示例代码
MOV SCON, #00H ;设置串行口工作在方式0 MOV 50H, #00H ;个位清零 MOV 51H, #00H MOV 52H, #00H DL_LOOP:LCALL DL_100MS MOV A, 50H ADD A, #1 MOV 50H, A CJNE A,
51单片机 多种格式串口控制LED源码: http://www.51hei.com/bbs/dpj-163182-1.html,适合新手
COleSafeArray m_Input2;long length,i;BYTE data[1024];CString str;BYTE a;if(m_COM.get_CommEvent() == 2) //事件值为2表示接收缓冲区内有字符 { m_Input1 = m_COM.get_Input(); //读缓冲区 m_
0x03:led=1;break;//收到0x03,led灯亮 case 0x33:led=0;break;//收到0x03,led灯灭 } } } }
怎么用上位机通过串口去控制51单片机点亮一个LED? 求程序。。
在无限循环中,不断检测K1和K2按键状态,以改变全局变量“freq”并控制LED灯的闪烁频率;然后使用一个计时器中断服务程序来控制LED灯的闪烁,具体实现方式请参考代码注释。最后,为了保证每个周期的闪烁持续时间与频率相符,应该
首先要查看电路的连接,看看输入连接到单片机的哪个引脚(比如P1.0),LED灯连接到哪个引脚(比如P2.0)。然后看是高电平有效还是低电平有效(也就是高电平时LED灯亮,还是低电平时LED灯亮)。如果是高电平灯亮的话,
pc通过串口和单片机交换数据,从而控制LED灯。 pc程序用labview 调用Visa 进行串口通讯。单片机接受到串口命令后控制I/O口的高低电平实现led灯亮灭控制。用串口调试助手就行,网上到处可以下载。也好用。关键问题是在电脑上发送
0x33:led=0;break;//收到0x03,led灯灭 } } } }
51单片机 多种格式串口控制LED源码: http://www.51hei.com/bbs/dpj-163182-1.html,适合新手
51单片机串口控制led灯方法是什么?
unsigned char tmp; sbit led=P1^0; void main(void) { TMOD = 0x20; // 定时器1工作于8位自动重载模式, 用于产生波特率 TH1 = 0xFD; // 波特率9600 TL1 = 0xFD; SCON = 0x50; // 设定串行口工作方式 PCON &= 0xef; // 波特率不倍增 TR1 = 1; // 启动定时器1 IE = 0x0; // 禁止任何中断 while(1) { if(RI) // 是否有数据到来 { RI = 0; tmp = SBUF; // 暂存接收到的数据 switch(tmp ) { case 0x03:led=1;break;//收到0x03,LED灯亮 case 0x33:led=0;break;//收到0x03,LED灯灭 } } } }下面的程序我已经调试过了,你可以直接使用,但是一秒闪烁次数t的最大为2000,如果要大于这个数,你必须改小dalay1ms ()内的j值,就可以改大t #include sbit LED0=P1^0; unsigned int t=0,k; void dalay1ms (unsigned int i) //晶振选用11.0592 { unsigned int j; for(i;i>0;i--) for(j=922;j>0;j--); } void main () { EA=1; ES=1; TMOD=0x20; //定时器T1方式为2 TH1=0xfa; //波特率设定为9600 TL1=0xfa; while(1) { if(t!=0) { k=2000/t; dalay1ms (k) ; LED0=!LED0; } if(t==0) LED0=0; } } void counter4(void) interrupt 4 { while(RI==0); RI = 0; t= SBUF; }
基本没错。就是第一次发送没反应,第二次时才开始反应。应该是开串口中断放后面的原因。 就是buf[n]=SBUF;//这条不知什么用 。 还有,ES=1放在串口初始化中。
参考一下: http://hi.baidu.com/%D7%F6%B6%F8%C2%DB%B5%C0/blog/item/725053edc5cec62d27979143.html 双机通讯程序还有几种,自己在空间里面找找。