久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: modbus 30路晶體管可編程控制器上位機與單片機下位機源碼等全套資料下載 [打印本頁]

作者: zhangxinchun    時間: 2018-2-24 14:07
標題: modbus 30路晶體管可編程控制器上位機與單片機下位機源碼等全套資料下載
本30路晶體管可編程模塊的modbus上位機運行界面如圖(附件中有vb.net源碼下載)支持rs485與rs232通訊. 可做快遞柜 電磁閥的控制


完整版modbus30路完善版本(看門狗)232+485單片機源程序如下:
  1. /******************************
  2. 程序功能:    modbus RTU 模式設置讀取十六個繼電器狀態,以及內部保持寄存器的設置讀取
  3. 硬件測試環境:單片機stc89C52RC十六繼電器485接口控制板  
  4. 通信協議:    晶振:11.0592  波特率:9600  8位數據 1位停止位 偶校驗   485通位接口P3.7控制方向端
  5. 控制板地址:  修改localAddr(變量)
  6. 線圈個數:16個  線圈地址范圍:0x0000~0x000F
  7. 保持寄存器個數:16個(字節型) 寄存器地址:0x0000~0x000F
  8. \\******************************\\
  9. 功能碼簡介:
  10. 02:讀取單個線圈狀態
  11. 03:讀取多個保持寄存器
  12. 05:設置單個線圈狀態
  13. 06:設置單個寄存器值
  14. 0F:設置多個線圈
  15. 10:設置多個保持寄存器
  16. *******************************/
  17. #include "hader\\main.h"
  18. uint32        dwTickCount,dwIntTick;        //時鐘
  19. uint8        idata sendBuf[32],receBuf[16]; //發送接收緩沖區
  20. uint8        idata checkoutError;        // ==2 偶校驗錯  
  21. uint8        idata receTimeOut;                //接收超時
  22. uint8        idata c10ms;                        //10ms 計時
  23. uint8   idata c200ms;
  24. bit                b1ms,bt1ms,b10ms,bt10ms,b100ms,bt100ms;        //定時標志位


  25. //定時處理
  26. void timeProc(void)
  27. {        
  28.     b1ms = 0;
  29.         if(bt1ms)        //如果1ms到
  30.         {
  31.                 bt1ms = 0;
  32.                 b1ms = 1;
  33.         if(receTimeOut>0)        //如果接收超時值>0
  34.         {
  35.             receTimeOut--;        //接收超時-1(1ms減1次)
  36.             if(receTimeOut==0 && receCount>0)   //判斷通訊接收是否超時
  37.             {
  38.             //    b485Send = 0;       //將485置為接收狀態
  39.                 receCount = 0;      //將接收地址偏移寄存器清零
  40.                                 checkoutError = 0;
  41.             }
  42.         }
  43.         }
  44. }   // void TimerProc(void)
  45. //初始化
  46. void initInt(void)
  47. {
  48.     SCON = 0xd0;
  49.         TMOD = 0x21;
  50.         PCON = 0;
  51.         TH0 = TIMER_HIGHT;
  52.         TL0 = TIMER_LOW;
  53.         TH1=  0xfd;        
  54.         TL1 = 0xfd;                             //波特率 9600
  55.    
  56.         TR0 = 1;
  57.         TR1=1;                        
  58.     ET0 = 1;
  59.         ES = 1;
  60.         EA = 1;        

  61.         //串口2設置        
  62.         S2CON = 0xd0;                          //方式1,9位數據,波特率不可變  S2TB8 偶校驗位
  63.         BRT=0XFD;                                  //設置波特率9600
  64.         AUXR=0x10;                                 //啟動串口1波特率發生器
  65.         IP=0x00;                                 //優先級默認                                         //開串口1中斷
  66.         IE2=0x01;                                 //開串口2中斷               
  67. }
  68. //初始化
  69. void initProg(void)
  70. {        

  71.    P4SW|=0x20;                   //配置P4.5為IO口
  72.    P4M0|=0x10;                   //配置P4.4為IO口
  73.    P4M1|=0x10;
  74.    P0=P1=P2=P3=0xff;
  75.    P4|=0x30;
  76.         initInt(); //初始化定時器
  77. //        b485Send = 0;
  78. }
  79. //上電時讀取上次線圈狀態,并設置
  80. void forceMultipleCoils1()
  81. {
  82.         uint8 tempAddr;
  83.         uint8 i,k;
  84.     uint8 Data;
  85.         uint8  exit = 0;                                                        
  86.         for(k=0;k<4;k++)
  87.         {
  88.            switch(k)
  89.           {        
  90.             case 0:Data=coilreg1; break;
  91.                 case 1:Data=coilreg2; break;
  92.                 case 2:Data=coilreg3; break;
  93.                 case 3:Data=coilreg4; break;
  94.            }
  95.                 for(i=0;i<8;i++)
  96.                 {
  97.                     if(        Data &0x01==1)
  98.                            setCoilVal(tempAddr,0);
  99.                         else
  100.                            setCoilVal(tempAddr,1);

  101.                         Data=Data>>1;        
  102.                         tempAddr++;
  103.                         if(tempAddr >=32)
  104.                         {
  105.                                 exit = 1;
  106.                                 break;
  107.                         }        
  108.                 }
  109.                 if(exit==1)
  110.                         break;
  111.         }
  112.         }
  113. void main(void)
  114. {
  115.    
  116.         initProg();
  117.         localAddr=EEPROMReadByte(0);     //從EERPOM的相對0地址讀取數據
  118.     coilreg1=EEPROMReadByte(1);
  119.         coilreg2=EEPROMReadByte(2);
  120.         coilreg3=EEPROMReadByte(3);
  121.         coilreg4=EEPROMReadByte(4);
  122.         forceMultipleCoils1();
  123.         if(localAddr>=10)
  124.         {
  125.           localAddr=1;
  126.           EEPROMSectorErase(0);       //從EEPROM的相對0地址扇區擦除
  127.       EEPROMWriteByte(0,localAddr);
  128.           EEPROMWriteByte(1,coilreg1);
  129.           EEPROMWriteByte(2,coilreg2);
  130.           EEPROMWriteByte(3,coilreg1);
  131.           EEPROMWriteByte(4,coilreg2);
  132.         
  133.         }
  134.         WDT_CONTR =0x32;   //大概284.4ms
  135.         while(1)
  136.         {
  137.                 timeProc();
  138.                 checkComm0Modbus();
  139.         }
  140. }
  141. //定時器0 1ms 中斷
  142. void timer0IntProc() interrupt 1
  143. {
  144.         TL0 = TIMER_LOW;
  145.     TH0 = TIMER_HIGHT;
  146.     dwIntTick++;
  147.         bt1ms = 1;
  148.     c10ms++;
  149.         c200ms++;
  150.     if(c10ms >= 10)
  151.     {
  152.         c10ms = 0;      //20ms計時器清零
  153.         bt10ms = 1;
  154.             WDT_CONTR =0x32;        //   
  155.     }
  156. }   // void Timer0IntProc()
  157. // 串行中斷1程序
  158. void commIntProc() interrupt 4
  159. {
  160.         if(TI)
  161.         {
  162.                 TI = 0;
  163.                 if(sendPosi < sendCount) //如果發送位置小于發送計數,那么繼續發送
  164.                 {
  165.                         sendPosi++;
  166.                         ACC = sendBuf[sendPosi];
  167.                         TB8 = P;        //加上校驗位
  168.                         SBUF = sendBuf[sendPosi];
  169.                 }
  170.                 else //否則發送完畢,置接收狀態
  171.                 {
  172.                 //        b485Send = 0;    //發送完后將485置于接收狀態
  173.                         receCount = 0;   //清接收地址偏移寄存器
  174.                         checkoutError = 0;
  175.                 }
  176.         }
  177.         else if(RI)
  178.         {
  179.                 RI = 0;
  180.                 receTimeOut = 10;    //通訊超時值
  181.                 receBuf[receCount] = SBUF;
  182.                 ACC = receBuf[receCount];
  183.                 if(P != RB8)
  184.                         checkoutError = 2;        //偶校驗出錯
  185.                 receCount++;          //接收地址偏移寄存器加1
  186.                 receCount &= 0x0f;    //最多一次只能接收16個字節
  187.         }
  188. }   // void CommIntProc()
  189. //串口2中斷
  190. void uart2_isr()  interrupt 8
  191. {
  192.   
  193.         if( S2CON & 0x02 )
  194.         {
  195.                 S2CON &= ~0x02;
  196.                    if(sendPosi<receCount) //如果發送位置小于發送計數,那么繼續發送
  197.                 {
  198.                         sendPosi++;
  199.                         ACC = receBuf[sendPosi];
  200.                         if(P)
  201.                            S2CON|=0x08;         //                                7      6      5      4      3      2     1     0        Reset Value
  202.                              //sfr S2CON = 0x9A; //S2 Control  S2SM0  S2SM1  S2SM2  S2REN  S2TB8  S2RB8  S2TI  S2RI      00000000B
  203.                         else
  204.                            S2CON&=0xf7;
  205.                         S2BUF =receBuf[sendPosi];
  206.                 }
  207.                 else //否則發送完畢,置接收狀態
  208.                 {
  209. //                        b485Send = 0;    //發送完后將485置于接收狀態
  210.                         receCount = 0;   //清接收地址偏移寄存器
  211.                         checkoutError = 0;
  212.                 }
  213.          }
  214.         else if( S2CON & 0x01)//接收
  215.         {
  216.             S2CON &= ~0x01;
  217.                 receTimeOut = 10;    //通訊超時值
  218.                 receBuf[receCount] =S2BUF;
  219.                 ACC = receBuf[receCount];
  220. //                if(P != RB8)
  221. //                        checkoutError = 2;        //偶校驗出錯
  222.                 receCount++;          //接收地址偏移寄存器加1
  223.                 receCount &= 0x0f;    //最多一次只能接收16個字節
  224.         }
  225. }
復制代碼

簡要說明:
一、 尺寸:長180mmX110mmX22mm
二、 主要芯片:STC12C60S2支持雙串口(支持51系列DIP40封裝單片機
三、 工作電壓:直流6~24供電可控制負載6~24V
四、 串口1COM1)下載程序,(RS485口使用單機機內部串口2均可與上位機通訊)
五、輸入輸出采用獨立供電,也可以公用一個電源,獨立供電可減少負載對單片機電路的影響
六、 特點:
             1、具有電源指示。
             2、三十路帶光電隔離輸出控制場效應管。
              3、標準的11.0592M晶振。(便于設置串口波特率)
             4、具有上電復位和手動復位。
             5、支持51系列DIP40封裝單片機。  
       5、輸出三十路場效應管的供電采用獨立供電 (可避免主控電路與被控電路干擾)        
             6、輸出三十路具有LED指示。
              7、三十路IRF1205場效應管
             8、可控制直流36V以內 50W負載設備。最大輸出電流6A
             9、具有RS232和RS485通信功能(可以同時和上位機通信)。
             10、單片機無加密,可插拔更換,可隨意更改程序。
使用說明:
【標注說明】

【接線圖】


【應用舉例接線圖】



全部資料51hei下載地址vb.net上位機與單片機下位源程序與電路原理圖等全套開發資料

0.png (56.57 KB, 下載次數: 62)

0.png

30路晶體管可編程模塊485及232產品使用手冊.doc

4.95 MB, 下載次數: 50, 下載積分: 黑幣 -5

GYJ-0077_30路場效應管可編程模塊485及232.rar

11.91 MB, 下載次數: 63, 下載積分: 黑幣 -5

定時發送命令30路源碼安裝包下位機.7z

17.22 MB, 下載次數: 62, 下載積分: 黑幣 -5






歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 成人在线免费网站 | 亚洲视频在线看 | 午夜在线观看免费 | 成人欧美 | 国产精产国品一二三产区视频 | 日韩激情网| 狠狠干狠狠操 | 一区二区三区四区在线视频 | 91精品久久久 | 国产成人自拍av | 中文字幕日韩欧美 | 久久久av中文字幕 | 亚洲福利精品 | 91久久久www播放日本观看 | 综合久久久久久久 | 午夜精品视频在线观看 | 欧美一区两区 | 天天综合久久 | 手机在线一区二区三区 | 一区二区三区在线电影 | 成人一区二区在线 | 在线中文字幕视频 | 亚洲视频在线观看 | 午夜成人免费视频 | 精品成人一区二区 | 91美女在线观看 | 欧美三级三级三级爽爽爽 | 欧美色综合一区二区三区 | 天天干天天谢 | 亚洲一区二区三区免费在线 | 午夜精品三区 | 亚洲国产欧美国产综合一区 | 亚洲品质自拍视频网站 | 日韩美香港a一级毛片免费 国产综合av | 国产精品欧美精品 | 成人影音 | 国偷自产av一区二区三区 | 欧美1区2区 | 久久国产精品免费 | 天天干国产 | 丁香久久|