找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1572|回复: 1
收起左侧

单片机+SIM900防幼儿误锁车内装置程序PCB设计

[复制链接]
ID:713392 发表于 2020-3-22 14:52 | 显示全部楼层 |阅读模式
供大家参考内附有电路图,棒棒
Altium Designer画的原理图和PCB图如下:(51hei附件中可下载工程文件)
51hei.png 51hei.png

单片机源程序如下:
  1. /************************************************************
  2. 程序说明:
  3. 1.将自己的51单片机的串口1连接到GSM 232上
  4. 2.找到程序中前面的#define处,根据说明修改好自己的单片机配置,编译程序
  5. 2.下载程序
  6. 3.等待发送成功
  7. *************************************************************/
  8. #include <REG51.H>
  9. #define uchar unsigned char
  10. #define uint unsigned int
  11. #define FOSC_110592M
  12. //#define FOSC_12M
  13. //无论接收到信号还是发送完信号,都会进中断服务程序的
  14. /*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/
  15. void SerialInti()//初始化程序(必须使用,否则无法收发)
  16. {
  17.         TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

  18. #ifdef FOSC_12M                   //在这里根据晶振大小设置不同的数值初始化串口
  19.         TH1=0xf3;//装入初值,波特率2400
  20.         TL1=0xf3;       
  21. #else        
  22.         TH1=0xfd;//装入初值,波特率9600
  23.         TL1=0xfd;
  24. #endif //end of SOC_12M
  25.        
  26.         TR1=1;//打开定时器
  27.         SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
  28.         SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
  29.         REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
  30.         EA=1;//开总中断
  31.         ES=1;//开串行口中断       
  32. }

  33. /*串行通讯中断,收发完成将进入该中断*/
  34. void Serial_interrupt() interrupt 4
  35. {
  36. //        a=SBUF;
  37.         P2=SBUF;
  38.         RI=0;//接收中断信号清零,表示将继续接收
  39. //        flag=1;//进入中断的标志符号
  40. }


  41. void Uart1Send(uchar c)
  42. {
  43.         SBUF=c;
  44.         while(!TI);//等待发送完成信号(TI=1)出现
  45.         TI=0;       
  46. }

  47. //串行口连续发送char型数组,遇到终止号/0将停止
  48. void Uart1Sends(uchar *str)
  49. {
  50.         while(*str!='\0')
  51.         {
  52.                 SBUF=*str;
  53.                 while(!TI);//等待发送完成信号(TI=1)出现
  54.                 TI=0;
  55.                 str++;
  56.         }
  57. }

  58. //延时函数大概是1s钟,不过延时大的话不准...
  59. void DelaySec(int sec)
  60. {
  61.         uint i , j= 0;

  62.         for(i=0; i<sec; i++)
  63.         {
  64.                 for(j=0; j<65535; j++)
  65.                 {       
  66.                 }
  67.         }
  68. }
  69. void main()
  70. {
  71.         uchar i = 0;
  72.         SerialInti();  
  73.         //程序执行到这里,模块已经注册到了网络,可以将让模块开机,等待模块注册到网络,然后开单片机电源。
  74.         Uart1Sends("AT+CMGF=1\r\n");
  75.         DelaySec(3);//延时3秒        //延时不准,此处加了这么长的延时 就是单纯为了 能让模块执行此条指令,实际中最好加判断,判断模块是否执行成功
  76.         Uart1Sends("AT+CSCS=\"UCS2\"\r\n");
  77.         DelaySec(3);//延时3秒                 
  78.         Uart1Sends("AT+CSCA?\r\n");
  79.         DelaySec(3);//延时3秒
  80.         Uart1Sends("AT+CSMP=17,167,0,25\r\n");
  81.         DelaySec(3);//延时3秒       
  82.         //下面的短信号,短信内容都为UNICON编码,可以用UNICON编码工具来获取
  83.         Uart1Sends("AT+CMGS=\"00310033003800310038003200370030003000360039\"");//此处修改为对方的电话号 注意此条指令后不要加回车换行
  84.         DelaySec(5);//延时3秒
  85.         Uart1Sends("4F60597D00680065006C006C006F");
  86.         Uart1Send(0x1a);
  87.         DelaySec(15);//延时20秒
  88.        
  89. }
复制代码
  1. /************************************************************
  2. 程序说明:
  3. 本程序运行后如果gprs模块找到服务商信号可实现接打电话发送短信等功能


  4. *************************************************************/
  5. #include <REG51.H>
  6. #include <string.H>
  7. #define uchar unsigned char
  8. #define uint unsigned int
  9. //以下是板子上LED的配置,把Px_x改成自己对应的脚。
  10. sbit P10=P1^0;
  11. sbit P11=P1^1;
  12. sbit P12=P1^2;
  13. sbit P13=P1^3;
  14. sbit P14=P1^4;
  15. sbit P15=P1^5;
  16. sbit P16=P1^6;   //rst for sim900a
  17. #define FOSC_110592M
  18. //#define FOSC_12M
  19. //以下是开机后拨打的手机号,改成自己想要打的号码即可。
  20. uchar num[] = "ATD10086;\r\n";
  21. //以下是GSM模块返回数据
  22. uchar rec_data[50];
  23. uchar rec_num;
  24. //注意,无论接收到信号还是发送完信号,都会进中断服务程序的
  25. /*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/
  26. void SerialInti()//初始化程序(必须使用,否则无法收发)
  27. {
  28.         TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

  29. #ifdef FOSC_12M                   //在这里根据晶振大小设置不同的数值初始化串口
  30.         TH1=0xf3;//装入初值,波特率2400
  31.         TL1=0xf3;       
  32. #else        
  33.         TH1=0xfd;//装入初值,波特率9600
  34.         TL1=0xfd;
  35. #endif //end of SOC_12M
  36.        
  37.         TR1=1;//打开定时器
  38.         SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
  39.         SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
  40.         REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
  41.         EA=1;//开总中断
  42.         ES=1;//开串行口中断       
  43. }

  44. /*串行通讯中断,收发完成将进入该中断*///如:+CMTI:"SM",2
  45. void Serial_interrupt() interrupt 4
  46. {

  47.         uchar temp;
  48.         temp=SBUF;
  49.         rec_data[rec_num++]=temp;
  50.         if(rec_num>=50)
  51.                 rec_num=0;
  52.         else
  53.                 ;
  54.         RI=0;//接收中断信号清零,表示将继续接收

  55. }

  56. //串行口连续发送char型数组,遇到终止号/0将停止
  57. void Uart1Sends(uchar *str)
  58. {
  59.         while(*str!='\0')
  60.         {
  61.                 SBUF=*str;
  62.                 while(!TI);//等待发送完成信号(TI=1)出现
  63.                 TI=0;
  64.                 str++;
  65.         }
  66. }
  67. void Uart1BYTE(uchar temp)
  68. {
  69.                 SBUF=temp;
  70.                 while(!TI);//等待发送完成信号(TI=1)出现
  71.                 TI=0;

  72. }

  73. uchar hand(uchar *ptr)
  74. {
  75.         if(strstr(rec_data,ptr)!=NULL)
  76.                 return 1;
  77.         else
  78.                 return 0;
  79. }

  80. void clear_rec_data()
  81. {
  82.         uchar i;
  83.         for(i=0;i<strlen(rec_data);i++)
  84.         {
  85.                 rec_data[i]='0';
  86.        
  87.         }
  88.         rec_num=0;


  89. }
  90. //延时函数大概是1s钟,不过延时大的话不准...
  91. void DelaySec(int sec)
  92. {
  93.         uint i , j= 0;

  94.         for(i=0; i<sec; i++)
  95.         {
  96.                 for(j=0; j<65535; j++)
  97.                 {       
  98.                 }
  99.         }
  100. }

  101. void Delayms(int sec)
  102. {
  103.         uint i , j= 0;

  104.         for(i=0; i<sec; i++)
  105.         {
  106.                 for(j=0; j<30000; j++)
  107.                 {       
  108.                 }
  109.         }
  110. }
  111. void main()
  112. {
  113.         uchar i = 0;
  114.         uint rst_time;
  115.         SerialInti();

  116.         //Uart1Sends(num);
  117.         //建议在单片机控制GSM模块前,加上两条 AT 指令,用来同步模块与单片机的波特率
  118.        
  119.         Uart1Sends("ATI\r\n"); //握手
  120.         /*
  121.         while(!hand("OK"))
  122.         {
  123.                 clear_rec_data();
  124.                 i++;
  125.                 Uart1Sends("ATI\r\n");//
  126.                 DelaySec(1);//延时
  127.                 if(i>=5)
  128.                 {
  129.                         break;
  130.                         //return;
  131.                 }
  132.                 else
  133.                         ;
  134.         }
  135.         P10=0;
  136.         clear_rec_data();//删除存储的GSM模块返回的数据,以便于以后继续判断
  137.         Delayms(1);
  138.         Uart1Sends("AT+CSQ\r\n");//信号质量
  139.         DelaySec(1);//延时
  140.         i=0;
  141.         while(!hand("OK")) //检测此条指令GSM模块是否执行OK
  142.         {
  143.                 clear_rec_data();
  144.                 i++;
  145.                 Uart1Sends("AT+CSQ\r\n");//
  146.                 DelaySec(1);//延时
  147.                 if(i>=5)
  148.                 {
  149.                         break;
  150.                         //return;
  151.                 }
  152.                 else
  153.                         ;
  154.         }
  155.         P11=0;
  156.         clear_rec_data();
  157.         Delayms(1);
  158.         Uart1Sends("AT+CPIN?\r\n");//查看是否读到手机卡
  159.         DelaySec(1);//延时
  160.         i=0;
  161.         while(!hand("READY")) //检测SIM模块是否收到SIM卡READY
  162.         {
  163.                 clear_rec_data();
  164.                 i++;
  165.                 Uart1Sends("AT+CPIN?\r\n");//是否注册到网络
  166.                 DelaySec(1);//延时
  167.                 if(i>=5)
  168.                 {
  169.                         break;
  170.                         //return;
  171.                 }
  172.                 else
  173.                         ;               
  174.         }
  175.         P12=0;
  176.         Uart1Sends("AT+COPS?\r\n");//是否注册到网络
  177.         DelaySec(1);//延时
  178.         i=0;
  179.         while(!hand("CHINA")) //检测是否收到模块返回的CHINA
  180.         {
  181.                 clear_rec_data();
  182.                 i++;
  183.                 Uart1Sends("AT+COPS?\r\n");//是否注册到网络
  184.                 DelaySec(1);//延时
  185.                 if(i>=5)
  186.                 {
  187.                         break;
  188.                         //return;
  189.                 }
  190.                 else
  191.                         ;               
  192.         }
  193.         P13=0;
  194.         clear_rec_data();
  195.         Delayms(1);
  196.         Uart1Sends("AT+CMMI=2,1\r\n"); //开回显
  197.         DelaySec(1);//延时
  198.         Uart1Sends("AT+CMGF=1\r\n");  //方式1
  199.         DelaySec(1);//延时
  200.         Uart1Sends("AT+CMGD=1\r\n");//删除SIM卡中的内容

  201.         //以下内容没有实际测试,仅供参考
  202.         */
  203.         while(1)
  204.         {
  205.                 if(hand("CMTI"))
  206.                 {
  207.                         P13=0;
  208.                         clear_rec_data();
  209.                         Delayms(1);
  210.                         Uart1Sends("AT+CMGR=1\r\n");//
  211.                         Delayms(10);
  212.                         //DelaySec(1);//延时
  213.                         i=0;
  214.                         while(!hand("OK"))
  215.                         {
  216.                                 clear_rec_data();
  217.                                 i++;
  218.                                 Uart1Sends("AT+CMGR=1\r\n");//
  219.                                 Delayms(10);
  220.                                 if(i>=4)   //chucuo
  221.                                 {
  222.                                         break;
  223.                                         //return;
  224.                                 }
  225.                                 else
  226.                                         ;               
  227.                         }
  228.                         for(i=0;i<2;i++) //读两次命令内容
  229.                         {
  230.                                 Delayms(1);
  231.                                 if(hand("relay on"))
  232.                                 {
  233.                                         P16=~P16;
  234.                                         break;
  235.                                 }
  236.                                 else if(hand("relay off"))
  237.                                 {
  238.                                        
  239.                                         P16=~P16;
  240.                                         break;
  241.                                 }
  242.                                 else
  243.                                 {
  244.                                         //break;
  245.                                 }
  246.                         }
  247.                         Uart1Sends("AT+CMGD=1\r\n");//删除短信,释放内存
  248.                         DelaySec(1);//延时
  249.                         clear_rec_data();
  250.                         Delayms(1);

  251.                
  252.                 }
  253.                 else if(hand("RING")) //电话进来 挂断电话
  254.                 {
  255.                        
  256.                         Uart1Sends("ATH\r\n");//
  257.                         Delayms(10);
  258.                         i=0;
  259.                         while(!hand("OK"))
  260.                         {
  261.                                 clear_rec_data();
  262.                                 i++;
  263.                                 Uart1Sends("ATH\r\n");//
  264.                                 Delayms(10);
  265.                                 if(i>=2)
  266.                                 {
  267.                                         break;
  268.                                         //return;
  269.                                 }
  270.                                 else
  271.                                         ;               
  272.                         }
  273.                         clear_rec_data();
  274.        
  275.                 }
  276.                 else
  277.                 {
  278.                        
  279.                         Delayms(1);//延时
  280.                         rst_time++;
  281.                         i=0;
  282.                         if(rst_time>=200)
  283.                         {
  284.                                 rst_time=0;
  285.                                 Uart1Sends("ATI\r\n");//
  286.                                 Delayms(10);
  287.                                 Uart1Sends("AT+CMGD=1\r\n");//
  288.                                 DelaySec(1);//延时
  289.                                 while(!hand("OK"))
  290.                                 {
  291.                                         clear_rec_data();
  292.                                         i++;
  293.                                         Uart1Sends("ATI\r\n");//
  294.                                         Delayms(10);
  295.                                         Uart1Sends("AT+CMGD=1\r\n");//
  296.                                         DelaySec(1);//延时
  297.                                         if(i>=2)   //超过四次无正确返回,模块可能死机,复位一下
  298.                                         {
  299.                                                 P16=0; //复位
  300.                                                 DelaySec(1);//延时
  301.                                                 DelaySec(1);//延时
  302.                                                 DelaySec(1);//延时
  303.                                                 DelaySec(1);//延时长些,确保复位有效
  304.                                                 P16=1; //复位
  305.                                                 DelaySec(1);//延时
  306.                                                 break;
  307.                                                 //return;
  308.                                         }
  309.                                         else
  310.                                                 ;               
  311.                                 }
  312.                         }
  313.                
  314.                 }
  315.         }

  316. }
复制代码

所有资料51hei提供下载:
防幼儿误锁车内装置设计(含电路图原理图,程序).7z (1.49 MB, 下载次数: 38)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:894266 发表于 2021-3-20 13:25 | 显示全部楼层
谢谢分享,可以把主要元器件和功能说一下嘛,有些小白

回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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