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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6660|回復: 7
收起左側

關于15單片機兩個串口傳輸數據的使用

[復制鏈接]
回帖獎勵 10 黑幣 回復本帖可獲得 10 黑幣獎勵! 每人限 1 次(中獎概率 50%)
ID:200190 發表于 2017-7-23 21:34 | 顯示全部樓層 |閱讀模式
我是用的15單片機,串口一連接的藍牙模塊,串口二連接的紅外遙控模塊。
想實現,用手上的串口助手APP,給藍牙模塊發指令,串口一會接收到不同的六個指令,根據六個不同的指令,進而用串口二發出六組每組四個十六進制數的指令。下面是我的源代碼,不知道為什么一直不好用。
#include <STC15F2K60S2.H>
#include <intrins.h>

#include  <math.h>    //Keil library  
#include  <stdio.h>   //Keil library
#define uchar unsigned char
#define uint unsigned int
#define FOSC 11059200L //系統頻率
#define BAUD 9600 //串口2波特率
#define S2RI 0x01 //S2CON.0 不能進行位尋址
#define S2TI 0x02 //S2CON.1
int code table1[]={0xff,0x02,0x00,0xfe};
int code table2[]={0xff,0x02,0x01,0xfe};
int code table3[]={0xff,0x02,0x02,0xfe};
int code table4[]={0xff,0x02,0x03,0xfe};
int code table5[]={0xff,0x02,0x04,0xfe};
int code table6[]={0xff,0x02,0x05,0xfe};
bit flag_KG=0,flag_LF=0,flag_FS=0,flag_DS=0,flag_FL=0,flag_BF=0;  
bit busy;
uchar uart1_buff=0,uart2_buff=0,sending=1;
void Uart1_Init()
{
        SCON = 0x50;                //8位數據,可變波特率
        AUXR |= 0x40;                //定時器1時鐘為Fosc,即1T
        AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
        TMOD &= 0x0F;                //設定定時器1為16位自動重裝方式
        TL1 = 0xE0;                //設定定時初值
        TH1 = 0xFE;                //設定定時初值
        ET1 = 0;                //禁止定時器1中斷
        TR1 = 1;                //啟動定時器1              
    ES  = 1;       //開中斷.  
          EA  = 1;         
}
//----------------------------------------------  
void Uart2_Init(void)
{
        S2CON = 0x50; //8位可變波特率
        T2L = (65536 - (FOSC/4/BAUD)); //設置波特率重裝值
        T2H = (65536 - (FOSC/4/BAUD))>>8;
        AUXR = 0x14; //T2為1T模式, 并啟動定時器2
        IE2 = 0x01; //使能串口2中斷
        EA = 1;
}
void Out_Data(int Data[])
{
        uchar i;
        for (i=0;i<=3;i++)//
        {
                                              uart2_buff=Data[i];
                S2BUF = uart2_buff;
                if (S2CON & S2TI)
                                                                {
                             S2CON &= ~S2TI; //清除S2TI位
                                                                }
        }
                                sending=0;
}
void  serial() interrupt 4
{
   if(RI==1)
         {
                 RI = 0;                //清除串行接受標志位
     uart1_buff = SBUF;            //從串口緩沖區取得數據
                 switch(uart1_buff)
                 {
                                case 0x31:  flag_KG=1;break;         
                                case 0x32:  flag_LF=1;break;      
                                case 0x33:  flag_FS=1;break;        
                                case 0x34:  flag_DS=1;break;      
                                case 0x35:  flag_FL=1;break;            
                                case 0x36:  flag_BF=1;break;                           
                 }
         }

}
void main()
{
        Uart1_Init();
        Uart2_Init();
        while(1)
        {
                if(flag_KG==1)
                {
                        Out_Data(table1);
                        while(sending);
                        sending=1;
                        flag_KG=0;
                }
                if(flag_LF==1)
                {
                        Out_Data(table2);
                        while(sending);
                        sending=1;
                        flag_LF=0;
                }
                if(flag_FS==1)
                {
                        Out_Data(table3);
                        while(sending);
                        sending=1;
                        flag_FS=0;
                }
                if(flag_DS==1)
                {
                        Out_Data(table4);
                        while(sending);
                        sending=1;
                        flag_DS=0;
                }
                if(flag_FL==1)
                {
                        Out_Data(table5);
                        while(sending);
                        sending=1;
                        flag_FL=0;
                }
                if(flag_BF==1)
                {
                        Out_Data(table6);
                        while(sending);
                        sending=1;
                        flag_BF=0;
                }
        }
}

回復

使用道具 舉報

ID:164602 發表于 2017-7-24 08:17 | 顯示全部樓層
看了你的程序,我有以下想法:
第一:程序上的問題。
主程序中
                if(flag_KG==1)
                {
                        Out_Data(table1);
                        while(sending);
                        sending=1;
                        flag_KG=0;
                }
當Out_Data(table1);執行完畢時,sending=0;,那么while(sending);就沒有意義,又sending=1;是什么道理呢,我看不懂了。
第二:我認為,你的想法是——通過串口向紅外遙控接收器發送四個數據,就是相當于紅外遙控發射器發出的四個數據——是這個意思嗎?
資料上是這樣說的:“通常為了使信號能更好的被傳輸發送端將基帶二進制信號調制為脈沖串信號,通過紅外發射管發射”“載波波形使用 455KHz 晶體,經內部分頻電路,信號被調制在37.91KHz,占空比為3 分之1。”
也就是說,紅外遙控信號,是有調制、檢波過程的,而你直接將檢波后的數據給紅外接收器,是不能得到有用數據的。
在本站我看到有人設計了程序,可以模擬紅外遙控發射器,你可以去找找,看看。
回復

使用道具 舉報

ID:213173 發表于 2017-7-24 09:14 | 顯示全部樓層
本帖最后由 wulin 于 2017-7-24 10:42 編輯

這里修改一下試試
void Out_Data(int Data[])
{
        uchar i;
        ES=0;//關串口中斷,防止中斷干擾
        for (i=0;i<=3;i++)//
        {
                uart2_buff=Data;
                S2BUF = uart2_buff;
                while(!(S2CON & S2TI));        //等待發送中斷請求標志位為1
                S2CON &= ~S2TI;                //清除S2TI位
        }
        ES=1;                //開串口中斷
        sending=0;
}
回復

使用道具 舉報

ID:221926 發表于 2017-7-24 10:00 | 顯示全部樓層

 這里修改一下試試
void Out_Data(int Data[])
{
        uchar i;
        ES=0;//關串口中斷,防止中斷干擾
        for (i=0;i<=3;i++)//
        {
                uart2_buff=Data[i];
                S2BUF = uart2_buff;
                while(!S2TI);        //等待發送中斷請求標志位為1
                S2TI=0;                //清除S2TI位
        }
        ES=1;                //開串口中斷
        sending=0;
}
回復

使用道具 舉報

ID:222088 發表于 2017-7-24 17:30 | 顯示全部樓層
void Uart1_Init()
{
        SCON = 0x50;                //8位數據,可變波特率
        AUXR |= 0x40;                //定時器1時鐘為Fosc,即1T
        AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
        TMOD &= 0x0F;                //設定定時器1為16位自動重裝方式
        TL1 = 0xE0;                //設定定時初值
        TH1 = 0xFE;                //設定定時初值
        ET1 = 0;                //禁止定時器1中斷
        TR1 = 1;                //啟動定時器1              
    ES  = 1;       //開中斷.  
          EA  = 1;         
}
可以試試這里
回復

使用道具 舉報

ID:168165 發表于 2021-9-17 16:32 | 顯示全部樓層
哥們問題解決了嗎?
回復

使用道具 舉報

ID:514901 發表于 2021-9-18 13:38 | 顯示全部樓層
看了你的程序,你先初始化Uart2_Init()再初始化Uart1_Init(),基本可以解決問題
回復

使用道具 舉報

ID:529831 發表于 2021-9-18 15:43 | 顯示全部樓層
注意在 中斷函數里先關閉總中斷試試
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美精品在线看 | 91精品国产91久久综合桃花 | 一级毛片免费视频观看 | 亚洲精品第一国产综合野 | 亚洲一区二区三区视频在线 | 中文字幕日韩欧美一区二区三区 | 欧美男人天堂 | 亚洲福利网 | 操人网站 | 亚洲一二视频 | 天堂一区二区三区 | 老外几下就让我高潮了 | 日本一区二区三区免费观看 | 久久综合久久久 | 久久久精品 | 最新国产精品 | 麻豆精品国产91久久久久久 | 7777在线视频 | 999热视频 | 国产精品久久av | 伊人影院99 | 中文字幕在线电影观看 | 国产一区二区久久 | 盗摄精品av一区二区三区 | 国产精品国产三级国产aⅴ中文 | 久久久免费观看视频 | 一级片在线免费播放 | 麻豆视频在线免费观看 | 成年人在线观看视频 | 国产蜜臀97一区二区三区 | 91短视频网址 | av日韩一区 | 古典武侠第一页久久777 | 亚洲欧美综合 | 久草精品视频 | 亚洲中字在线 | 91国产精品| 久久99蜜桃综合影院免费观看 | 羞羞视频免费观 | 久久久久国产精品 | 国产精品国产成人国产三级 |