单片机论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7254|回复: 23
收起左侧

单片机检测空气质量PM2.5与温湿度的设计 含源码PCB和仿真论文等全套资料

  [复制链接]
wc420418 发表于 2018-5-10 17:14 | 显示全部楼层 |阅读模式
基于stc89c52单片机检测pm2.5和温湿度,最后显示在lcd1602液晶屏幕上。

空气质量温湿度检测仪系统仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png

Altium Designer画的空气质量温湿度检测仪系统原理图和PCB图如下:(51hei附件中可下载工程文件)
0.png

元件清单:
0.png

总体方案设计
本设计采用由STC89C52单片机最小系统、GP2Y1010AU粉尘传感器、ADC0832模数转换器模块、LCD1602液晶模块、电源模块、温湿度传感器HDT11、蜂鸣器报警模块和按键模块模块组成。单片机实时通过ADC0832转换芯片采集GP2Y1010AU粉尘传感器的粉尘的浓度,通过单片机的数据转换处理后在液晶屏上显示空气中的质量,当测量空间中的粉尘浓度大于设置粉尘浓度时,蜂鸣器和发光二极管发出声光报警。同时检测室内温湿度传感器上温度,湿度的测量值,当温度湿度的测量值大设置值上限或者小于设置值的下限值发出声光报警。粉尘的浓度报警值,温湿度的上下限报警值可以通过按键进行设置。系统总体框图如图2-1所示:
0.png

总结
经过了两个月的学习和工作,我终于完成了《空气质量温湿度检测仪系统》的论文。从开始到论文题目导系统的实现,再到论文文章的完成,每走一步对我说都是新的尝试与挑战,这也是我在大学期间独立完成的最大的项目。这段时间里,我学到了很多知识也有很多感受,从对单片机的一无所知很不了解的状态,我开始了独立的学习和试验,查看相关的资料和书籍,让我自己头脑中模糊的概念逐渐清晰,使自己非常雅嫩的作品一步一步完善起来,每一次改进都是我学习的收获,每一次试验的成功都会让我兴奋好一段时间。从中我也充分认识到了单片机在现今这个世界还是有很重要地位的。
虽然我的论文作品还有很多的不足之处,但我很自豪,因为这是我自己的劳动所获,当我看着自己的程序,我真的很开心,我相信其中的酸甜苦辣最终都会化为甜美的甘泉。
这次做论文的经历也会使我终身受益,我感受到做论文是要真真正正用心去做的一件事情,是正真的自己学习的过程和研究的过程,没有学习就不可能与研究的能力,没有自己的研究,就不会有所突破,那这也就就不交论文了。希望这次的经历能让我在以后的学习中激励我继续进步。

PM2.5+DHT11上下限报警单片机源程序如下:

  1. #include"LCD1602.h"  //添加LCD1602头文件
  2. #include"dht11.h"          //添加DHT11头文件
  3. #include"adc0832.h"
  4. #include<math.h>
  5. sbit BUZZER = P1^3;         //蜂鸣器驱动端口==P1^3
  6. sbit Reduc  = P3^2;         //按键键输入端口==P1^7
  7. sbit Add = P3^3;         //按键加输入端口==P3^1
  8. sbit Mode = P3^4;         //按键加输入端口==P3^1
  9. sbit LED1=P2^0;
  10. sbit LED2=P2^1;
  11. uchar Rx_buf[4],Rxnum=0;
  12. uchar T1L=15,T1H=35,R1L=30,R1H=80;
  13. void InitUART(void)                         //这是串口的基本配置,配置他的波特率是9600.这些参数都是标准的。
  14. {
  15.     TMOD = 0x20;
  16.     SCON = 0x50;
  17.     TH1 = 0xFD;
  18.     TL1 = TH1;
  19.     PCON = 0x00;
  20.     EA = 1;
  21.     ES = 1;
  22.     TR1 = 1;
  23. }

  24. /*
  25. * UART 发送一字节
  26. */
  27. void UART_send_byte(char dat)
  28. {
  29.         SBUF = dat;
  30.         while (TI == 0);
  31.         TI = 0;
  32. }

  33. /*
  34. * UART 发送字符串
  35. */
  36. void UART_send_string(unsigned char *buf)
  37. {
  38.         while (*buf != '\0')
  39.         {
  40.                 UART_send_byte(*buf++);
  41.         }
  42. }
  43. /************************************************
  44. ** 函数名称 : void main(void)
  45. ** 函数功能 : 主函数
  46. ** 输    入 : 无
  47. ** 输    出 : 无
  48. ** 说    明 :
  49. ************************************************/
  50. void main(void)
  51. {
  52.         double PM,pm1,pm2;
  53.         int PMVAL=0,HPM=200,PM_count=0,pm1_count=0;
  54.         uchar T1_data=0,R1_data=0,T2_data=0,R2_data=0;//温度、湿度变量
  55.         uchar shezhi_flag=1,Mode_flag=1,n=1;//设置变量
  56.         uchar bueezr_flag=0,count=0,buzzer_time=9;//蜂鸣器报警变量
  57.         uint Mode_count=0;
  58.         uchar disp[16]  ={"PM2.5:0000ug/m3 "};
  59.         uchar disp1[16]= {"T :00C    RH:00%"};
  60.         uchar Tx_Buf[15];
  61.          InitUART();                        //初始化串口                                          
  62.         LCD_Init();
  63.     WriteChar(1,0,16,disp); //在第一行显示‘内容’
  64.         WriteChar(2,0,16,disp1); //在第二行显示‘内容’
  65.         while(1)
  66.         {
  67.                
  68.                 T1_data=Read_TRH(0,0);//温度
  69.                 disp1[3]=T1_data/10+0x30;//十位
  70.                 disp1[4]=T1_data%10+0x30;//个位

  71.                 R1_data=Read_TRH(1,0);//湿度
  72.                 disp1[13]=R1_data/10+0x30;//十位
  73.                 disp1[14]=R1_data%10+0x30;//个位
  74.                                                                           
  75.                 pm1+=read_data(1);
  76.                 if(++PM_count>=20)
  77.                 {
  78.                           PM_count=0;
  79.                            pm1=pm1/20;
  80.                         pm2+=pm1;
  81.                         pm1=0;
  82.                         if(++pm1_count>=5)
  83.                         {
  84.                                 pm1_count=0;
  85.                                 PM=pm2/5;
  86.                                 PM=PM*50/255;
  87.                                 PM-=4;
  88.                             PM/=5;
  89.                                 PM*=1000;
  90.                                 PMVAL=PM;
  91.                                 PMVAL+=235;        PMVAL=PMVAL/9;
  92.                                 if(PMVAL>=9999)PMVAL=9999;
  93.                                 WriteCOMDATA(0x86,0);
  94.                                 if(PMVAL<0)//PMVAL=0;
  95.                                 {WriteCOMDATA(0+0x30,1);PMVAL=abs(PMVAL);}
  96.                                 else WriteCOMDATA(PMVAL/1000+0x30,1);
  97.                                 WriteCOMDATA(PMVAL/100%10+0x30,1);
  98.                                 WriteCOMDATA(PMVAL/10%10+0x30,1);
  99.                                 WriteCOMDATA(PMVAL%10+0x30,1);
  100.                                 PM=pm1=pm2=0;
  101.                         }
  102.                 }

  103.                 /*调用报警函数,温湿度是否在设定范围内*/
  104.                 //温度值与报警值比较
  105.                 if(T1_data<T1L)
  106.                 {
  107.                         bueezr_flag=1;//报警标志位置1
  108.                 }
  109.                 else if(T1_data>T1H)
  110.                 {
  111.                         bueezr_flag=1;//报警标志位置1
  112.                 }
  113.                 //湿度值与报警值比较
  114.                 if(R1_data<R1L)
  115.                 {
  116.                         bueezr_flag=1;//报警标志位置1
  117.                 }
  118.                 else if(R1_data>R1H)
  119.                 {
  120.                         bueezr_flag=1;//报警标志位置1
  121.                 }
  122.                 //PM值与报警值比较
  123.                 if(PMVAL>HPM)
  124.                 {        
  125.                         bueezr_flag=1;
  126.                 }
  127.                 if(T1_data>T1L&&T1_data<T1H  && R1_data>R1L&&R1_data<R1H  &&  PMVAL<HPM)
  128.                 {
  129.                         bueezr_flag=0;
  130.                         BUZZER=1;
  131.                 }
  132.                 /*******蜂鸣器报警********/
  133.                 count++;if(count>buzzer_time*10)count=buzzer_time+1;
  134.                 if(count%buzzer_time==0 && bueezr_flag)
  135.                 {
  136.                         BUZZER=~BUZZER;//蜂鸣器取反  发出声音提示
  137.                 }
  138.                
  139.                 /*******Mode键设置报警参数********/
  140.                 if(Mode==0 && Mode_flag)
  141.                 {         
  142.                         WriteCOMDATA(0x0F,0);//LCD显示光标
  143.                         Delay(100);
  144.                         if(Mode==0)
  145.                         {
  146.                                 BUZZER=1;
  147.                                 bueezr_flag=0;

  148.                                 Mode_flag=0;
  149.                                 shezhi_flag=1;
  150.                                 n=1;
  151.                                 while(1)                  
  152.                                 {                                                                        
  153.                                         switch(shezhi_flag)
  154.                                         {
  155.                                                 case 1:
  156.                                                 if(n)
  157.                                                 {
  158.                                                         n=0;
  159.                                                         WriteChar(1,0,16,"T1L:00C  T1H:00C");//在第一行显示内容                                 
  160.                                                         WriteChar(2,0,16,"R1L:00%  R1H:00%");//在第二行显示内容
  161.                                                         WriteCOMDATA(0x8D,0);WriteCOMDATA(T1H/10+0x30,1);
  162.                                                         WriteCOMDATA(0x8E,0);WriteCOMDATA(T1H%10+0x30,1);
  163.                                                         WriteCOMDATA(0xC4,0);WriteCOMDATA(R1L/10+0x30,1);
  164.                                                         WriteCOMDATA(0xC5,0);WriteCOMDATA(R1L%10+0x30,1);
  165.                                                         WriteCOMDATA(0xCD,0);WriteCOMDATA(R1H/10+0x30,1);
  166.                                                         WriteCOMDATA(0xCE,0);WriteCOMDATA(R1H%10+0x30,1);
  167.                                                 }
  168.                                                         WriteCOMDATA(0x84,0);WriteCOMDATA(T1L/10+0x30,1);
  169.                                                         WriteCOMDATA(0x85,0);WriteCOMDATA(T1L%10+0x30,1);
  170.                                                         WriteCOMDATA(0x85,0);
  171.                                                 break;
  172.                                                 case 2:
  173.                                                         WriteCOMDATA(0x8D,0);WriteCOMDATA(T1H/10+0x30,1);
  174.                                                         WriteCOMDATA(0x8E,0);WriteCOMDATA(T1H%10+0x30,1);
  175.                                                         WriteCOMDATA(0x8E,0);
  176.                                                 break;
  177.                                                 case 3:
  178.                                                         WriteCOMDATA(0xC4,0);WriteCOMDATA(R1L/10+0x30,1);
  179.                                                         WriteCOMDATA(0xC5,0);WriteCOMDATA(R1L%10+0x30,1);
  180.                                                         WriteCOMDATA(0xC5,0);
  181.                                                 break;
  182.                                                 case 4:
  183.                                                         WriteCOMDATA(0xCD,0);WriteCOMDATA(R1H/10+0x30,1);
  184.                                                         WriteCOMDATA(0xCE,0);WriteCOMDATA(R1H%10+0x30,1);
  185.                                                         WriteCOMDATA(0xCE,0);
  186.                                                 break;

  187.                                                 case 5:
  188.                                                 if(n)
  189.                                                 {
  190.                                                         n=0;
  191.                                                         WriteChar(1,0,16,"    PM2.5 SET   ");//在第一行显示内容                                 
  192.                                                         WriteChar(2,0,16,"HPM2.5:    ug/m3");//在第二行显示内容                                                        
  193.                                                 }
  194.                                                 WriteCOMDATA(0xC7,0);
  195.                                                 WriteCOMDATA(HPM/1000+0x30,1);
  196.                                                 WriteCOMDATA(HPM/100%10+0x30,1);
  197.                                                 WriteCOMDATA(HPM/10%10+0x30,1);
  198.                                                 WriteCOMDATA(HPM%10+0x30,1);
  199.                                                 WriteCOMDATA(0xCA,0);
  200.                                                 break;                                                
  201.                                         }
  202.                                         Delay(200);
  203.                                         //加
  204.                                         if(Reduc==0)
  205.                                         {
  206.                                                 Delay(200);
  207.                                                 //while(Reduc==0);
  208.                                                 switch(shezhi_flag)
  209.                                                 {         
  210.                                                         case 1:T1L+=1;break;
  211.                                                         case 2:T1H+=1;break;
  212.                                                         case 3:R1L+=1;break;
  213.                                                         case 4:R1H+=1;break;
  214.                                                         case 5:HPM+=1;break;
  215.                                                 }               
  216.                                         }
  217.                                         //减
  218.                                         if(Add==0)
  219.                                         {
  220.                                                 Delay(200);
  221.                                                 //while(Add==0);
  222.                                                 switch(shezhi_flag)
  223.                                                 {
  224.                                                         case 1:T1L-=1;break;
  225.                                                         case 2:T1H-=1;break;
  226.                                                         case 3:R1L-=1;break;
  227.                                                         case 4:R1H-=1;break;
  228.                                                         case 5:HPM-=1;break;
  229.                                                 }               
  230.                                         }
  231.                                         //短按切换设置项目   长按退出设置页面
  232.                                         if(Mode==0)
  233.                                         {
  234.                                                 Delay(300);
  235.                                                 while(Mode==0)
  236.                                                 {
  237.                                                         Delay(300);
  238.                                                         Mode_count++;
  239.                                                         if(Mode_count>6)
  240.                                                         {
  241.                                                             WriteChar(1,0,16,"PM2.5:0000ug/m3 ");//在第一行显示内容
  242.                                                                 WriteCOMDATA(0x86,0);
  243.                                                 if(PMVAL<0)//PMVAL=0;
  244.                                                {WriteCOMDATA(0+0x30,1);PMVAL=abs(PMVAL);}
  245.                                                else WriteCOMDATA(PMVAL/1000+0x30,1);
  246.                                                WriteCOMDATA(PMVAL/100%10+0x30,1);
  247.                                                WriteCOMDATA(PMVAL/10%10+0x30,1);
  248.                                                WriteCOMDATA(PMVAL%10+0x30,1);
  249.                                                                 WriteChar(2,0,16,disp1); //在第二行显示内容
  250.                                                         }
  251.                                                 }
  252.                                                 if(Mode_count>6)
  253.                                                 {
  254.                                                         Mode_count=0;shezhi_flag=0;
  255.                                                         //当下限值大于上限值时,蜂鸣器鸣叫1S提示,参数设置有误
  256.                                                         if(T1L>T1H || R1L>R1H)
  257.                                                         {
  258.                                                                 BUZZER=0;Delay(1000);BUZZER=1;
  259.                                                         }
  260.                                                         //否则退出设置页面,返回主页面
  261.                                                         else
  262.                                                         {               

  263.                                                                 WriteCOMDATA(0x0C,0);//关闭LCD光标
  264.                                                                 Delay(10);
  265.                                                                 n=0;
  266.                                                                 break;                                                
  267.                                                         }
  268.                                                 }
  269.                                                 else Mode_count=0;
  270.                                                 shezhi_flag++;
  271.                                                 if(shezhi_flag>5)shezhi_flag=1;
  272.                                                 if(shezhi_flag==1 || shezhi_flag==5)n=1;
  273.                 pm1+=read_data(1);
  274.                 if(++PM_count>=20)
  275.                 {
  276.                           PM_count=0;
  277.                            pm1=pm1/20;
  278.                         pm2+=pm1;
  279.                         pm1=0;
  280.                         if(++pm1_count>=15)
  281.                         {
  282.                                 pm1_count=0;
  283.                                 PM=pm2/15;
  284.                                 PM=PM*50/255;
  285.                                 PM-=4;
  286.                             PM/=5;
  287.                                 PM*=1000;
  288.                                 PMVAL=PM;
  289.                                 PMVAL-=480;        PMVAL=PMVAL/3;
  290.                                 if(PMVAL>=9999)PMVAL=9999;
  291.                                 PM=pm1=pm2=0;
  292.                         }
  293.                 }               
  294.                                         }
  295.                                 }        
  296.                         }
  297.                 }               
  298.                 /********LCD1602显示********/                                            
  299.                 //WriteChar(1,0,16,disp); //在第一行显示‘内容’
  300.                 WriteChar(2,0,16,disp1); //在第二行显示‘内容’
  301.                 if(Mode_flag==0){Mode_count++;if(Mode_count>20){Mode_count=0;Mode_flag=1;}}
  302.                 Tx_Buf[0]='T';        //帧头
  303.             Tx_Buf[1]=T1_data/10%10+0x30;                 //将温湿度数据送往发送数组,送给蓝牙模块让手机APP显示
  304.             Tx_Buf[2]=T1_data%10+0x30;               
  305.             Tx_Buf[3]=R1_data/10%10+0x30;
  306.             Tx_Buf[4]=R1_data%10+0x30;
  307.             Tx_Buf[5]=PMVAL/1000+0x30;                 //将温湿度数据送往发送数组,送给蓝牙模块让手机APP显示
  308.             Tx_Buf[6]=PMVAL/100%10+0x30;               
  309.             Tx_Buf[7]=PMVAL/10%10+0x30;
  310.             Tx_Buf[8]=PMVAL%10+0x30;
  311.             Tx_Buf[9]=0;//结束符
  312.                 Tx_Buf[10]=0;//结束符
  313.                 Tx_Buf[11]=0;//结束符
  314.           UART_send_string(        Tx_Buf);          //串口发送温湿度数据出去
  315.         }
  316. }

  317. /*****************串口接收中断函数,接收蓝牙模块的数据*********************/
  318. void UARTInterrupt(void) interrupt 4
  319. {        
  320.         ES=0;        //关闭中断
  321.     if(RI)          //接收到数据
  322.     {

  323. ……………………

  324. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码
0.png 0.png
1、单片机是通用的STC89C51、STC89C52、AT89C51、AT89C52、AT89S51、AT89S52这六种,他们都统称51单片机,只是生产厂家和后缀不一样,无论stc还是at他们引脚排序,功能都一样,程序也是一样的。只是后缀为52的单片机比后缀为51的单片机的内存要大4k。
  
2、原理图中的“99se格式.SchDoc”是要用protel99se打开的,没有软件的不要紧,我已帮您转换成word格式和pdf格式的了。
3、程序中的.c和.h文件可以用记事打开,就是程序了。其他的是写程序是自动
   生成的,没什么用的。
4、可以按照正面布局,不要按照实物的背面焊接,要按照原理图焊接。

所有资料51hei提供下载:

PM2.5 温湿度.rar (8.94 MB, 下载次数: 520)
回复

使用道具 举报

 楼主| wc420418 发表于 2018-5-11 14:21 | 显示全部楼层
不错啊
回复

使用道具 举报

无效楼层,该帖已经被删除
ndyilu 发表于 2018-5-19 16:13 | 显示全部楼层
感觉不错
回复

使用道具 举报

xiaopangxie 发表于 2018-5-20 20:27 | 显示全部楼层
单片机怎么读取编码器的数据啊~~
回复

使用道具 举报

944747635 发表于 2018-12-4 21:22 | 显示全部楼层
挺好的,我们最近正在做
回复

使用道具 举报

azi1974 发表于 2019-1-18 10:55 | 显示全部楼层
这个非常那个详细,足以能够认真学习了
回复

使用道具 举报

omer 发表于 2019-1-18 11:41 | 显示全部楼层
不错,毕业设计。。。学的电子、我当年的毕业设计和这个毛关系都没有..
回复

使用道具 举报

9#
无效楼层,该帖已经被删除
Ai_Junguang 发表于 2019-2-28 13:55 | 显示全部楼层
这个非常那个详细,足以能够认真学习了
回复

使用道具 举报

zhzzz 发表于 2019-3-11 09:01 | 显示全部楼层
真的很有用
回复

使用道具 举报

zhzzz 发表于 2019-3-11 09:02 | 显示全部楼层
真的很有用 对自己学习相关知识更进了一步
回复

使用道具 举报

zqbx123 发表于 2019-4-9 15:16 | 显示全部楼层
感谢分享  太棒了
回复

使用道具 举报

fly1215544395 发表于 2019-4-18 11:23 | 显示全部楼层
我下载好了  我想问下 这里面有温湿度和PM2.5合在一起的仿真呢
回复

使用道具 举报

IKnown 发表于 2019-4-18 21:04 | 显示全部楼层
最近在做空气质量检测,感谢楼主的分享,很有帮助
回复

使用道具 举报

单刀桔子 发表于 2019-4-22 22:28 | 显示全部楼层
请问源程序里是不是缺少GP2Y1010AU0F传感器的源码???
回复

使用道具 举报

机智的愚人 发表于 2019-4-23 09:40 | 显示全部楼层
这个分享的确实挺全的
回复

使用道具 举报

眉宇倾城。。。 发表于 2019-5-8 17:58 来自手机 | 显示全部楼层
请问这个仿真部分为什么没有温湿度部分,
回复

使用道具 举报

眉宇倾城。。。 发表于 2019-5-8 17:59 来自手机 | 显示全部楼层
fly1215544395 发表于 2019-4-18 11:23
我下载好了  我想问下 这里面有温湿度和PM2.5合在一起的仿真呢

你好。我也需要这个合在一起的仿真,请问你找到了吗
回复

使用道具 举报

王明浩7 发表于 2019-5-16 17:22 | 显示全部楼层
单刀桔子 发表于 2019-4-22 22:28
请问源程序里是不是缺少GP2Y1010AU0F传感器的源码???

对呀,我也是这么觉得,没整明白
回复

使用道具 举报

王明浩7 发表于 2019-5-16 17:27 | 显示全部楼层
944747635 发表于 2018-12-4 21:22
挺好的,我们最近正在做

兄弟,加个好友讨论一下白。有的地方不明白
回复

使用道具 举报

大滑稽 发表于 2019-5-19 23:47 来自手机 | 显示全部楼层
单刀桔子 发表于 2019-4-22 22:28
请问源程序里是不是缺少GP2Y1010AU0F传感器的源码???

我也觉得
回复

使用道具 举报

ARTORIUS 发表于 2019-5-21 17:51 | 显示全部楼层
请问这段程序为什么是这么写的呢
pm1+=read_data(1);
                if(++PM_count>=20)
                {
                          PM_count=0;
                           pm1=pm1/20;
                        pm2+=pm1;
                        pm1=0;
                        if(++pm1_count>=5)
                        {
                                pm1_count=0;
                                PM=pm2/5;
                                PM=PM*50/255;
                                PM-=4;
                            PM/=5;
                                PM*=1000;
                                PMVAL=PM;
                                PMVAL+=235;        PMVAL=PMVAL/9;
                                if(PMVAL>=9999)PMVAL=9999;
                                WriteCOMDATA(0x86,0);
                                if(PMVAL<0)//PMVAL=0;
                                {WriteCOMDATA(0+0x30,1);PMVAL=abs(PMVAL);}
                                else WriteCOMDATA(PMVAL/1000+0x30,1);
                                WriteCOMDATA(PMVAL/100%10+0x30,1);
                                WriteCOMDATA(PMVAL/10%10+0x30,1);
                                WriteCOMDATA(PMVAL%10+0x30,1);
                                PM=pm1=pm2=0;
                        }
                }
回复

使用道具 举报

YURI-X 发表于 2019-5-22 18:43 | 显示全部楼层
王明浩7 发表于 2019-5-16 17:22
对呀,我也是这么觉得,没整明白

大哥,问题解决了吗,我自己在仿真图上加了温湿度检测,但是烧录程序之后显示度数一直是0
回复

使用道具 举报

hrdd 发表于 2019-5-27 14:27 | 显示全部楼层
感觉很不错,期待下载
回复

使用道具 举报

ARTORIUS 发表于 2019-6-9 23:26 | 显示全部楼层
YURI-X 发表于 2019-5-22 18:43
大哥,问题解决了吗,我自己在仿真图上加了温湿度检测,但是烧录程序之后显示度数一直是0

我也感觉这个温湿度的程序有问题,我做好的实物烧入程序也是显示0,然后重新找了一个温湿度的程序改到主程序后就好了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|单片机论坛 |51黑电子论坛单片机 联系QQ:125739409;技术交流QQ群582644647

Powered by 单片机教程网

快速回复 返回顶部 返回列表