51单片机 通过串口发送控制LED灯 闪烁频率 c代码 跪求!!

51单片机 通过串口发送控制LED灯 闪烁频率 c代码 跪求!!,第1张

下面的程序我已经调试过了,你可以直接使用,但是一秒闪烁次数t的最大为2000,如果要大于这个数,你必须改小dalay1ms ()内的j值,就可以改大t

#include <reg52h>

sbit LED0=P1^0;

unsigned int t=0,k;

void dalay1ms (unsigned int i) //晶振选用110592

{

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;

}

我的程序的一部分,供参考

//主流程

void

main(void)

{

//系统初始化

SCON

=

0x50;

//串口方式为1,SM2=

0,TB8=

1

PCON

=

0x80;

//

SMOD=1

TMOD

=

0x22;

//设定定时器0/1的工作模式为方式2

//设置T0中断的定时时间为1/7200毫秒

TH0

=

0x00;

TL0

=

0x00;

//设置异步串口的波特率

//TH1

=

0x0f4;

//OSC

=

110592MHz

bps

=

4800

SMOD=1

//TL1

=

0x0f4;

TH1

=

0x0fd;

//OSC

=

110592MHz

bps

=

19200

SMOD=1

TL1

=

0x0fd;

//设置中断优先级,T0中断为高优先级中断,其他为低优先级中断

IP

=

0x02;

//

设置中断优先级--T0为高优先级,其他低

ET0

=

1;

//定时器0中断

ES

=

1;

//串行接口中断

EA

=

1;

//系统中断允许

TR0

=

1;

//启动定时器0

TR1

=

1;

//串口接收中断处理程序

//发送采用查询处理

void

SerialComm(void)

interrupt

4

{

_pReceive[_cReceive]

=

SBUF;

_cReceive

++;

if(_cReceive

>=

RecBuffSize)

_cReceive

=

0;

RI

=

0;

}

//串口发送一个字节

//senddata:需要发送的数据

void

SendOneByte(unsigned

char

senddata)

{

ES

=

0;

TI

=

0;

SBUF

=

senddata;

while(TI

==

0);

TI

=

0;

ES

=

1;

}

可靠的接受程序!!从LZ 的display(a1a10)看出来这程序就不咋样,如果显示函数 还是 用 延时做的,可靠的接受程序给LZ 也是 白瞎……

以下是 UART 驱动程序

/10位异步收发串口通讯驱动——火柴天堂作品-20130119/

/源程序硬件环境:52单片机,110592MHz晶振,定时器1作为波特率发生器,通讯波特率9600 bit/s/

//

#define UART_H

#include"REG52h" //包含52头文件

#include"UARTh" //包含串口头文件

#define th1 0xfa //651us at 110592MHz Fosc for 8bit auto reload mode

static uchar UART_DataR; //串口接收数据寄存器

static uchar bdata Flag=0; //标志位 寄存器

sbit UART_ReFlag=Flag^0; //串口接收标志位 0:无数据 1:新数据

sbit UART_SendFlag=Flag^1; //串口发送标志位 0:空闲中 1:发送中

void UART()interrupt 4 //串口中断函数

{

if(RI) //若串口接收完成

{

RI=0; //清 串口接收溢出位

UART_DataR=SBUF; //将串口收到的数据存进 UART_DataR

UART_ReFlag=TRUE; //串口接收标志位 置位(有新数据)

}

if(TI) //若串口发送完成

{

TI=0; //清 串口发送溢出位

UART_SendFlag=FALSE; //清串口发送标志位(空闲中)

}

}

void UART_Init() //串口初始化函数

{

SCON=0x50; //选择通讯方式:10位异步收发,串口中断使能

PCON=0x80; //波特率倍频

TMOD&=0x0f; //定时器1控制位清0

TMOD|=0x20; //定时器1工作模式2(8位自重装,做波特率发生器)

TH1=th1; //定时器初值

TL1=th1; //定时器初值

TR1=1; //开始计时

ES=1; //允许串口中断

EA=1; //允许系统中断

}

bit UART_SendByte(uchar send_data) //串口发送字节函数,发送内容send_data,返回值:0 *** 作失败,1 *** 作成功

{

if(!UART_SendFlag) //若串口空闲中,则

{

SBUF=send_data; //将发送内容 送到 串口寄存器

UART_SendFlag=TRUE; //置位串口发送标志位(进入忙态)

return TRUE; //返回1, *** 作成功

}

return FALSE; //否则,返回0, *** 作失败

}

uchar ASCII_ToHex(uchar ascii_data) //ASCII 转 Hex 函数

{

uchar hex_data=0; //定义 Hex变量存储转换结果

if(ascii_data>='0' && ascii_data<='9') hex_data=ascii_data-'0'; //若 转换内容为 字符'0-9',则转成对应数字0-9

else if(ascii_data>='a' && ascii_data<='f') hex_data=ascii_data-'a'+10; //若 转换内容为 字符'a-f',则转成数字10-15

else if(ascii_data>='A' && ascii_data<='F') hex_data=ascii_data-'A'+10; //若 转换内容为 字符'A-F',则转成数字10-15

return hex_data; //返回转换结果,非以上字符,不在Hex(0-F)范围内,默认0

}

bit UART_ReadByte(uchar p_data,bit data_mode) //串口读字节函数,返回值0 无数据,1 有数据,将data_mode模式(ASCII_Mode或HEX_Mode)转成Hex结果存到p_data指向地址

{

if(!UART_ReFlag) return FALSE; //若无新数据,则返回 0(无数据)

UART_ReFlag=FALSE; //否则,清 串口接收标志位

if(data_mode==HEX_Mode) p_data=UART_DataR; //Hex模式,将串口接收结果存到p_data指向地址

if(data_mode==ASCII_Mode) p_data=ASCII_ToHex(UART_DataR); //ASCII模式,将串口接收结果转成Hex后,存到p_data指向地址

return TRUE; //返回 1(有数据)

}

下面是stc串口测试程序,供你参考,协议你自己编把,按键需要软件做消抖处理,led简单,如果你不会写led就不要搞这个了

#include<reg51h>

#include<intrinsh>

sfr S2CON = 0x9A;

//S2SM0,S2SM1,S2SM2,S2REN,S2TB8,SRB8,S2TI,S2RI

sfr IE2 = 0xAF;

//X,X,X,X,X,X,ESPI,ES2

sfr S2BUF = 0x9B;

sfr AUXR = 0x8e;

sfr BRT = 0x9c;

sfr IAP_CONTR = 0xC7;

sfr CCON = 0xD8;

sfr CMOD = 0xD9;

sfr CL = 0xE9;

sfr CH = 0xF9;

sfr CCAP0L = 0xEA;

sfr CCAP0H = 0xFA;

sfr CCAPM0 = 0xDA;

sfr CCAPM1 = 0xDB;

sbit CR = 0xDE;

sbit MCU_Start_Led = P1^7;

sbit S2_Interrupt_Receive_Led = P1^4;

//unsigned char self_command_array[4] = {0x22,0x33,0x44,0x55};

#define Self_Define_ISP_Download_Command 0x22

#define RELOAD_COUNT 0xfb //18432MHz,12T,SMOD=0,9600bps

void serial_port_one_initial();

void send_UART_one(unsigned char);

void UART_one_Interrupt_Receive(void);

void serial_port_two_initial();

void send_UART_two(unsigned char);

void UART_two_Interrupt_Receive(void);

void soft_reset_to_ISP_Monitor(void);

void delay(void);

void display_MCU_Start_Led(void);

void send_PWM(void);

void main(void)

{

unsigned int array_point = 0;

unsigned char xdata Test_array_one[512] =

{

0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,

0x08, 0x09, 0, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,

0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,

0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f,

0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27,

0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f,

0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37,

0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,

0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47,

0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f,

0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57,

0x58, 0x59, 0x5a, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f,

0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67,

0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f,

0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77,

0x78, 0x79, 0x7a, 0x7b, 0x7c, 0x7d, 0x7e, 0x7f,

0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,

0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f,

0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97,

0x98, 0x99, 0x9a, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f,

0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,

0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xaf,

0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7,

0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf,

0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,

0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,

0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7,

0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xdd, 0xde, 0xdf,

0xe0, 0xe1, 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7,

0xe8, 0xe9, 0xea, 0xeb, 0xec, 0xed, 0xee, 0xef,

0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7,

0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff,

0xff, 0xfe, 0xfd, 0xfc, 0xfb, 0xfa, 0xf9, 0xf8,

0xf7, 0xf6, 0xf5, 0xf4, 0xf3, 0xf2, 0xf1, 0xf0,

0xef, 0xee, 0xed, 0xec, 0xeb, 0xea, 0xe9, 0xe8,

0xe7, 0xe6, 0xe5, 0xe4, 0xe3, 0xe2, 0xe1, 0xe0,

0xdf, 0xde, 0xdd, 0xdc, 0xdb, 0xda, 0xd9, 0xd8,

0xd7, 0xd6, 0xd5, 0xd4, 0xd3, 0xd2, 0xd1, 0xd0,

0xcf, 0xce, 0xcd, 0xcc, 0xcb, 0xca, 0xc9, 0xc8,

0xc7, 0xc6, 0xc5, 0xc4, 0xc3, 0xc2, 0xc1, 0xc0,

0xbf, 0xbe, 0xbd, 0xbc, 0xbb, 0xba, 0xb9, 0xb8,

0xb7, 0xb6, 0xb5, 0xb4, 0xb3, 0xb2, 0xb1, 0xb0,

0xaf, 0xae, 0xad, 0xac, 0xab, 0xaa, 0xa9, 0xa8,

0xa7, 0xa6, 0xa5, 0xa4, 0xa3, 0xa2, 0xa1, 0xa0,

0x9f, 0x9e, 0x9d, 0x9c, 0x9b, 0x9a, 0x99, 0x98,

0x97, 0x96, 0x95, 0x94, 0x93, 0x92, 0x91, 0x90,

0x8f, 0x8e, 0x8d, 0x8c, 0x8b, 0x8a, 0x89, 0x88,

0x87, 0x86, 0x85, 0x84, 0x83, 0x82, 0x81, 0x80,

0x7f, 0x7e, 0x7d, 0x7c, 0x7b, 0x7a, 0x79, 0x78,

0x77, 0x76, 0x75, 0x74, 0x73, 0x72, 0x71, 0x70,

0x6f, 0x6e, 0x6d, 0x6c, 0x6b, 0x6a, 0x69, 0x68,

0x67, 0x66, 0x65, 0x64, 0x63, 0x62, 0x61, 0x60,

0x5f, 0x5e, 0x5d, 0x5c, 0x5b, 0x5a, 0x59, 0x58,

0x57, 0x56, 0x55, 0x54, 0x53, 0x52, 0x51, 0x50,

0x4f, 0x4e, 0x4d, 0x4c, 0x4b, 0x4a, 0x49, 0x48,

0x47, 0x46, 0x45, 0x44, 0x43, 0x42, 0x41, 0x40,

0x3f, 0x3e, 0x3d, 0x3c, 0x3b, 0x3a, 0x39, 0x38,

0x37, 0x36, 0x35, 0x34, 0x33, 0x32, 0x31, 0x30,

0x2f, 0x2e, 0x2d, 0x2c, 0x2b, 0x2a, 0x29, 0x28,

0x27, 0x26, 0x25, 0x24, 0x23, 0x22, 0x21, 0x20,

0x1f, 0x1e, 0x1d, 0x1c, 0x1b, 0x1a, 0x19, 0x18,

0x17, 0x16, 0x15, 0x14, 0x13, 0x12, 0x11, 0x10,

0x0f, 0x0e, 0x0d, 0x0c, 0x0b, 0, 0x09, 0x08,

0x07, 0x06, 0x05, 0x04, 0x03, 0x02, 0x01, 0x00

};

unsigned char i = 0;

serial_port_one_initial(); //串口1初始化

// serial_port_two_initial(); //串口2初始化

display_MCU_Start_Led(); //点亮发光二极管表示单片机开始工作

// send_UART_two(0x55); //串口2发送数据表示单片机串口正常工作

// send_UART_two(0xaa); //串口2发送数据表示单片机串口正常工作

/

for(array_point=0; array_point<512; array_point++)

{

send_UART_two(Test_array_one[array_point]);

}

/

send_UART_one(0x34); //串口1发送数据表示单片机串口正常工作

send_UART_one(0xa7); //串口1发送数据表示单片机串口正常工作

for(array_point=0; array_point<512; array_point++)

{

send_UART_one(Test_array_one[array_point]);

}

// send_PWM(); //6kHz PWM, 50% duty

while(1);

}

void serial_port_one_initial()

{

SCON = 0x50; //0101,0000 8位可变波特率,无奇偶校验位

// TMOD = 0x21; //0011,0001 设置顶时器1为8位自动重装计数器

// TH1 = RELOAD_COUNT; //设置定时器1自动重装数

// TL1 = RELOAD_COUNT;

// TR1 = 1; //开定时器1

BRT = RELOAD_COUNT;

// BRTR = 1, S1BRS = 1, EXTRAM = 1 ENABLE EXTRAM

AUXR = 0x11; // T0x12,T1x12,UART_M0x6,BRTR,S2SMOD,BRTx12,EXTRAM,S1BRS

ES = 1; //允许串口中断

EA = 1; //开总中断

}

void serial_port_two_initial()

{

//sfr SCON = 0x98;

//SM0,SM1,SM2,REN,TB8,RB8,TI,RI

//sfr S2CON = 0x9A;

//S2SM0,S2SM1,S2SM2,S2REN,S2TB8,S2RB8,S2TI,S2RI

//sfr S2BUF = 0x9B;

//sfr IE2 = 0xAF;

//X,X,X,X,X,X,ESPI,ES2

S2CON = 0x50; //0101,0000 8位可变波特率,无奇偶校验位,允许接收

BRT = RELOAD_COUNT;

// BRTR = 1, S1BRS = 1, EXTRAM = 0 ENABLE EXTRAM

AUXR = 0x11; // T0x12,T1x12,UART_M0x6,BRTR,S2SMOD,BRTx12,EXTRAM,S1BRS

// ES = 1; //允许串口1中断

// ES2 = 1

IE2 = 0x01; //允许串口2中断,ES2=1

EA = 1; //开总中断

}

void send_UART_one(unsigned char i)

{

ES = 0; //关串口中断

TI = 0; //清零串口发送完成中断请求标志

SBUF = i;

while(TI ==0); //等待发送完成

TI = 0; //清零串口发送完成中断请求标志

ES = 1; //允许串口中断

}

void send_UART_two(unsigned char i)

{

//sfr SCON = 0x98;

//SM0,SM1,SM2,REN,TB8,RB8,TI,RI

//sfr S2CON = 0x9A;

//S2SM0,S2SM1,S2SM2,S2REN,S2TB8,S2RB8,S2TI,S2RI

//sfr S2BUF = 0x9B;

//sfr IE2 = 0xAF;

//X,X,X,X,X,X,ESPI,ES2

unsigned char temp = 0;

// ES = 0; //关串口1中断

IE2 = 0x00; //关串口2中断,es2=0

// TI = 0; //清零串口1发送完成中断请求标志

S2CON = S2CON & 0xFD; //B'11111101,清零串口2发送完成中断请求标志

// SBUF = i;

S2BUF = i;

// while(TI ==0); //等待发送完成

do

{

temp = S2CON;

temp = temp & 0x02;

}while(temp==0);

// TI = 0; //清零串口发送完成中断请求标志

S2CON = S2CON & 0xFD; //B'11111101,清零串口2发送完成中断请求标志

// ES = 1; //允许串口1中断

// ES2 = 1

IE2 = 0x01; //允许串口2中断,ES2=1

}

void UART_one_Interrupt_Receive(void) interrupt 4

{

unsigned char k = 0;

if(RI==1)

{

RI = 0;

k = SBUF;

if(k==Self_Define_ISP_Download_Command) //是自定义下载命令

{

delay(); //延时1秒就足够了

delay(); //延时1秒就足够了

soft_reset_to_ISP_Monitor(); //软复位到系统ISP监控区

}

send_UART_one(k+1);

}

else

{

TI = 0;

}

}

void UART_two_Interrupt_Receive(void) interrupt 8

{

//sfr SCON = 0x98;

//SM0,SM1,SM2,REN,TB8,RB8,TI,RI

//sfr S2CON = 0x9A;

//S2SM0,S2SM1,S2SM2,S2REN,S2TB8,S2RB8,S2TI,S2RI

//sfr S2BUF = 0x9B;

//sfr IE2 = 0xAF;

//X,X,X,X,X,X,ESPI,ES2

unsigned char k = 0;

k = S2CON ;

k = k & 0x01;

//if(S2RI==1)

if(k==1)

{

//RI = 0;

S2CON = S2CON & 0xFE; //1111,1110

S2_Interrupt_Receive_Led = 0;

k = S2BUF;

if(k==Self_Define_ISP_Download_Command) //是自定义下载命令

{

delay(); //延时1秒就足够了

delay(); //延时1秒就足够了

soft_reset_to_ISP_Monitor(); //软复位到系统ISP监控区

}

send_UART_two(k+1);

}

else

{

//TI = 0;

S2CON = S2CON & 0xFD; //1111,1101

}

}

void soft_reset_to_ISP_Monitor(void)

{

IAP_CONTR = 0x60; //0110,0000 软复位到系统ISP监控区

}

void delay(void)

{

unsigned int j = 0;

unsigned int g = 0;

for(j=0;j<5;j++)

{

for(g=0;g<60000;g++)

{

_nop_();

_nop_();

_nop_();

_nop_();

_nop_();

}

}

}

void display_MCU_Start_Led(void)

{

//sbit MCU_Start_Led = P1^7;

unsigned char i = 0;

for(i=0;i<1;i++)

{

MCU_Start_Led = 0; //顶亮MCU开始工作指示灯

delay();

MCU_Start_Led = 1; //熄灭MCU开始工作指示灯

delay();

MCU_Start_Led = 0; //顶亮MCU开始工作指示灯

}

}

void send_PWM(void)

{

CMOD = 0x00; // CIDL - - - - CPS1 CPS0 ECF Setup PCA Timer

// CPS1 CPS0 = 00, Fosc/12 is PCA/PWM clock

// 18432000/12/256 = 6000

CL = 0x00;

CH = 0x00;

CCAP0L = 0x80; //Set the initial value same as CCAP0H

CCAP0H = 0x80; //50% Duty Cycle

CCAPM0 = 0x42; //0100,0010 Setup PCA module 0 in 8BIT PWM, P37

CR = 1; //启动 PCA/PWM 定时器

}

这里有个源码是串口发送接收数据的。

坐等悬赏分。

源码转自:《51单片机C语言创新教程》温子祺等著。

/实验名称:串口收发数据实验

描 述:在使用单片机的串口接收数据实验当中,

使用串口调试助手发送什么数据,

单片机采用查询法将接收到的数据返发到PC

作 者:温子祺

修改日期:2010/5/4

/

#include "stch" //加载"stch"

/

函数名称:UARTInit

输 入:无

输 出:无

功 能:串口初始化

/

void UARTInit(void) //定义串口初始化函数

{

SCON =0x50; //8位数据位,允许接收

T2CON=0x34; //由定时器2作为波特率发生器

RCAP2L=0xD9; //波特率为9600的低8位

RCAP2H=0xFF; //波特率为9600的高8位

}

/

函数名称:UARTSendByte

输 入:byte 要发送的字节

输 出:无

功 能:串口发送单个字节

/

void UARTSendByte(unsigned char byte)//定义串口发送数据函数

{

SBUF=byte; //缓冲区装载要发送的字节

while(TI==0); //等待发送完毕,TI标志位会置1

TI=0; //清零发送完成标志位

}

/

函数名称:main

输 入:无

输 出:无

功 能:函数主体

/

void main(void) //主函数

{

unsigned char recv; //声明变量recv

UARTInit(); //串口初始化

while(1) //进入死循环

{

if(RI) //检测接收完成标志位置1

{

RI=0; //清零接收完成标志位

recv=SBUF; //读取接收到的数据

UARTSendByte(recv); //返回接收到的数据

}

}

}

if(a&(1<<(i-1))) RW_SID=1;

表示1左移i-1位再于a进行与运算,i=8的情况下i-1=7,1左移7位就是0x80。再跟a与运算(全1出1有0出0)即可获得a的最高位。以此类推可以取出a的所有位。

if(RW_SID==1) dat|=(1<<(i-1));

当RW_SID端口为1时把1左移i-1位跟dat或运算。i=8的情况下1左移i-1位正好是0x80,再经过与运算保存最高位,循环移位再或运算就能读取到全部位保存在dat里面

可以写成

//写部分

if(a&0x80)//取出a的最高位

RW_SID=1;//如果是1则输出1

else

RW_SID=0;//否则输出0

a<<=1;//a整体左移,让第7位补到最高位的位置,循环取出

E_CLK=1;

delay(100);

E_CLK=0;

delay(100);

//读部分

E_CLK=1;

delay(100);

dat<<=1;//接收1次数据后左移。第一次为0的情况影响数据

if(RW_SID)//当端口为高的时候

dat++;//dat+1相当于dat|=1 当端口为0的时候默认左移最低位是补零的,所以不用管

E_CLK=0;//循环8次后第一次接受到的数据就在最高位了

delay(100);

效果是一样的相对来说比较好理解

给你个思路吧,不带通讯协议,不带中断的,你自己往上填

#include "regx52h"

#define 0x1 OPEN_LED

#define 0x2 CLOSE_LED

main()

{

TH1=0x;//设置波特率

//设置串口通讯方式,8位接收,1停止位

//启动T1

while(1)

{

if(RI)//如果接收到字符

{

switch(SBUF)

{

case OPEN_LED:P4_6=1;break;//如果接收到开灯命令,灯亮

case CLOSE+LED:P4_6=0;break;

default:;

}

RI=0;

}

}

}

以上就是关于51单片机 通过串口发送控制LED灯 闪烁频率 c代码 跪求!!全部的内容,包括:51单片机 通过串口发送控制LED灯 闪烁频率 c代码 跪求!!、C51单片机如何从PC机串口接收字符串、51单片机从电脑串口接收10字节的数据,程序用c语言等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9276885.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存