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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索

單片機從機檢測溫度并使用rs485發送數據,主機數碼管不顯示的問題

查看數: 1971 | 評論數: 6 | 收藏 1
關燈 | 提示:支持鍵盤翻頁<-左 右->
    組圖打開中,請稍候......
發布時間: 2024-3-11 23:09

正文摘要:

新手求解答 如圖所示,從機檢測溫度正常并顯示正常,發送時,無論是接收端還是發送端都一樣,但主機接收后,無法轉成正常數字并使用數碼管顯示,我在網上找到不到相關的案例,不知道是哪里出錯了。 發送端代 ...

回復

ID:1111674 發表于 2024-3-13 18:20
lkc8210 發表于 2024-3-13 09:00
Display()函數的代碼呢?
還有,誰教你在中斷里用delay的?

都是自己翻普中的資料文檔的,有什么資料或書籍可以推薦嗎?有時覺得代碼邏輯沒問題,但就是不行,也不確定有什么規則是不清楚的,有些坑進了也不知道錯在哪里。
ID:1111674 發表于 2024-3-13 18:17
lkc8210 發表于 2024-3-13 09:00
Display()函數的代碼呢?
還有,誰教你在中斷里用delay的?
  1. int gsmg_code[17]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};

  2. void SMG_DisChar(unsigned char place, unsigned char num)
  3. {
  4.                    switch(place)//位選
  5.                 {
  6.                         case 3: LED1=1;LED2=0;LED3=0;LED4=0;break;
  7.                         case 2: LED1=0;LED2=1;LED3=0;LED4=0;break;
  8.                         case 1: LED1=0;LED2=0;LED3=1;LED4=0;break;
  9.                         case 0: LED1=0;LED2=0;LED3=0;LED4=1;break;
  10.                 }
  11.                 SMG_A_DP_PORT=gsmg_code[num];//傳送段選數據
  12.                 delay_10us(200);//延時一段時間,等待顯示穩定

  13. }

  14. void Display(unsigned int temp)
  15. {
  16.                         SMG_DisChar(3,temp/1000);  //千
  17.                         SMG_DisChar(2,temp%1000/100);//百
  18.                         SMG_DisChar(1,temp%1000%100/10);//十
  19.                   SMG_DisChar(0,temp%1000%100%10);//個
  20. }
復制代碼
ID:213173 發表于 2024-3-13 15:49
本帖最后由 wulin 于 2024-3-14 06:08 編輯
[url=forum.php?mod=redirect&goto=findpost&pid=1194908&ptid=234782][/url]

給你寫一個示例


  1. //發送端
  2. #include <reg51.h>
  3. #include <intrins.h>

  4. sbit DIR=P3^7;

  5. typedef unsigned char uchar;
  6. typedef unsigned int uint;
  7. uchar code table[]={
  8.         0x3f,0x06,0x5b,0x4f,
  9.         0x66,0x6d,0x7d,0x07,
  10.         0x7f,0x6f,0x77,0x7c,
  11.         0x39,0x5e,0x79,0x71};
  12. uchar data dis_buf[10];
  13. uint count;//計數
  14. uint sec;//秒
  15. bit flag;//標志

  16. void Timer0_Init(void)                //5毫秒@11.0592MHz
  17. {
  18.         TMOD |= 0x01;                        //設置定時器模式
  19.         TL0 = 0x00;                                //設置定時初始值
  20.         TH0 = 0xEE;                                //設置定時初始值
  21.         TF0 = 0;                                //清除TF0標志
  22.         TR0 = 1;                                //定時器0開始計時
  23.         EA = 1;
  24.         ET0 = 1;
  25. }

  26. void InitUART(void)//9600
  27. {
  28.     TMOD |= 0x20;
  29.     SCON = 0x50;
  30.     TH1 = 0xFD;
  31.     TL1 = 0xFD;
  32.     PCON = 0x00;
  33. //    EA = 1;
  34. //    ES = 1;
  35.     TR1 = 1;
  36. }
  37. void SendOneByte(uchar c)
  38. {
  39.     SBUF = c;
  40.     while(!TI);
  41.     TI = 0;
  42. }

  43. void Display()
  44. {
  45.         static uchar i;
  46.         dis_buf[0]=table[sec/1000%10];
  47.         dis_buf[1]=table[sec/100%10];
  48.         dis_buf[2]=table[sec/10%10];
  49.         dis_buf[3]=table[sec%10];
  50.         P0=0x00;
  51.         P1&=0xc3;
  52.         P1|=~(0x04<<i);
  53.         P0=dis_buf[i];
  54.         i=++i%4;
  55. }

  56. void main()
  57. {
  58.         Timer0_Init();
  59.         InitUART();
  60.         DIR=1;
  61.         while(1)
  62.         {
  63.                 if(flag)
  64.                 {
  65.                         flag=0;

  66.                         Display();
  67.                         if(++count>=200)
  68.                         {
  69.                                 count=0;
  70.                                 if(++sec>9999)sec=0;
  71.                                 SendOneByte(0xff);//數據頭
  72.                                 SendOneByte(sec>>8);//高8位
  73.                                 SendOneByte(sec);//低8位
  74.                         }
  75.                 }
  76.         }
  77. }
  78. void Timer0Interrupt(void) interrupt 1
  79. {
  80.     TH0 = 0xEE;
  81.     TL0 = 0x00;
  82.     flag=1;
  83. }
復制代碼
  1. //接收端
  2. #include <reg51.h>
  3. #include <intrins.h>

  4. sbit DIR=P3^7;

  5. typedef unsigned char uchar;
  6. typedef unsigned int uint;
  7. uchar code table[]={
  8.         0x3f,0x06,0x5b,0x4f,
  9.         0x66,0x6d,0x7d,0x07,
  10.         0x7f,0x6f,0x77,0x7c,
  11.         0x39,0x5e,0x79,0x71};
  12. uchar data dis_buf[4];
  13. uchar data rec_buf[3];

  14. uint count;//計數
  15. uint sec;//秒
  16. bit flag;//標志
  17. bit sign;//標志

  18. void Timer0_Init(void)                //5毫秒@11.0592MHz
  19. {
  20.         TMOD |= 0x01;                        //設置定時器模式
  21.         TL0 = 0x00;                                //設置定時初始值
  22.         TH0 = 0xEE;                                //設置定時初始值
  23.         TF0 = 0;                                //清除TF0標志
  24.         TR0 = 1;                                //定時器0開始計時
  25.         EA = 1;
  26.         ET0 = 1;
  27. }

  28. void InitUART(void)//9600
  29. {
  30.     TMOD |= 0x20;
  31.     SCON = 0x50;
  32.     TH1 = 0xFD;
  33.     TL1 = 0xFD;
  34.     PCON = 0x00;
  35. //  EA = 1;
  36.     ES = 1;
  37.     TR1 = 1;
  38. }
  39. /*
  40. void SendOneByte(uchar c)
  41. {
  42.     SBUF = c;
  43.     while(!TI);
  44.     TI = 0;
  45. }*/

  46. void Display()
  47. {
  48.         static uchar i;
  49.         dis_buf[0]=table[sec/1000%10];
  50.         dis_buf[1]=table[sec/100%10];
  51.         dis_buf[2]=table[sec/10%10];
  52.         dis_buf[3]=table[sec%10];
  53.         P0=0x00;
  54.         P1&=0xc3;
  55.         P1|=~(0x04<<i);
  56.         P0=dis_buf[i];
  57.         i=++i%4;
  58. }

  59. void main()
  60. {
  61.         Timer0_Init();
  62.         InitUART();
  63.         DIR=0;
  64.         while(1)
  65.         {
  66.                 if(flag)
  67.                 {
  68.                         flag=0;
  69.                         Display();
  70.                         if(sign)
  71.                         {
  72.                                 sign=0;
  73.                                 sec=rec_buf[1]<<8|rec_buf[2];
  74.                                 rec_buf[0]=rec_buf[1]=rec_buf[2]=0;
  75.                         }
  76.                 }
  77.         }
  78. }
  79. void Timer0Interrupt(void) interrupt 1
  80. {
  81.     TH0 = 0xEE;
  82.     TL0 = 0x00;
  83.     flag=1;
  84. }

  85. void Serial_ISR() interrupt 4
  86. {
  87.         static uchar i;                    //靜態計數變量
  88.         RI=0;                                        //接收中斷請求標志位清0
  89.         rec_buf[i]=SBUF;                //接收到的數據串保存在緩存數組
  90.         if(rec_buf[0]==0xff)        //驗證數據頭(起始位)
  91.         {
  92.                 i++;
  93.                 if(i>=3)
  94.                 {
  95.                         sign=1;                        //接收完成標志置1
  96.                         i=0;                        //計數變量清0
  97.                 }
  98.         }
  99. }
復制代碼



ID:161164 發表于 2024-3-13 09:00
Display()函數的代碼呢?
還有,誰教你在中斷里用delay的?
ID:1111674 發表于 2024-3-13 00:11
Hephaestus 發表于 2024-3-12 14:42
接收端main()里面你都寫了些啥?
  1. void main() {
  2.      Serial_Init();  
  3.              RS485_DIR = 0;
  4.     while(1)
  5.                 {
  6.       
  7.                         delay_ms(500);//延時一段時間,等待顯示穩定
  8.                 }                       
  9.         }
復制代碼
ID:883242 發表于 2024-3-12 14:42
接收端main()里面你都寫了些啥?

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产视频一区二区 | 成人免费一区二区 | 911网站大全在线观看 | 亚洲精品黄 | 国产一区二区三区视频在线观看 | 中文字幕在线不卡播放 | 91资源在线观看 | 久久在线 | 久久不卡 | 亚洲精品免费观看 | 国产精品视频网 | 久久久精品网 | 国产大片一区 | av综合站 | 国产精品99久久久久久动医院 | 天天操网 | 一区二区在线 | 欧日韩不卡在线视频 | 天天色天天射天天干 | 成人免费视频网站在线观看 | 香蕉久久久 | 三级黄色片在线 | 亚洲成人一区 | 国产97视频在线观看 | av毛片在线播放 | 在线一区视频 | 超碰av人人 | 日韩欧美中文 | 一区在线播放 | 不卡的av电影 | 国产黄视频在线播放 | 国产日韩免费观看 | www.性色 | 日本不卡在线视频 | 国产一区久久精品 | 国产色99精品9i | 国产在线观看一区二区 | 精品久久久久久久久久久久久久 | 免费观看一级特黄欧美大片 | 一级国产精品一级国产精品片 | 羞羞视频在线观免费观看 |