欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 8092|回復: 9
打印 上一主題 下一主題
收起左側

誰能教教我用RS485,max485,芯片 怎么和C52單片機建立通訊!程序怎么寫!

[復制鏈接]
回帖獎勵 50 黑幣 回復本帖可獲得 50 黑幣獎勵! 每人限 1 次
跳轉到指定樓層
樓主
如題
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:136633 發表于 2018-11-22 19:01 | 只看該作者
單片機的P30和P31接MAX485的RO和DI就完成建立了,具體通信協議就看軟件來實現了。
回復

使用道具 舉報

板凳
ID:429166 發表于 2018-11-22 20:51 | 只看該作者
RxD和TxD接RO和DI就好了,程序要慢慢來啊
回復

使用道具 舉報

地板
ID:211052 發表于 2018-11-22 21:48 | 只看該作者
單片機的P30和P31接MAX485的RO和DI就完成建立了,再用一個IO口控制RE/DE,程序就是串口發送接收,注意RE/DE的讀寫方向

485.png (21 KB, 下載次數: 123)

485.png

code.zip

2.53 KB, 下載次數: 124

回復

使用道具 舉報

5#
ID:431526 發表于 2018-11-22 22:52 | 只看該作者
片機的P30和P31接MAX485的RO和DI就完成建立
回復

使用道具 舉報

6#
ID:342197 發表于 2018-11-23 08:34 | 只看該作者
以下為具體實現通信的程序:
//RS485查詢接收到的數據
//buf:接收緩存首地址
//len:讀到的數據長度
void RS485_Receive_Data(u8 *buf,u8 *len)
{
        u8 rxlen=RS485_RX_CNT;
        u8 i=0;
        *len=0;                                //默認為0
        delay_ms(10);                //等待10ms,連續超過10ms沒有接收到一個數據,則認為接收結束
        if(rxlen==RS485_RX_CNT&&rxlen)//接收到了數據,且接收完成了
        {
                for(i=0;i<rxlen;i++)
                {
                        buf[ i]=RS485_RX_BUF[ i];                        }                                *len=RS485_RX_CNT;        //記錄本次數據長度                RS485_RX_CNT=0;                //清零        }}
回復

使用道具 舉報

7#
ID:214223 發表于 2018-11-23 10:15 | 只看該作者
正好最近做了一個
回復

使用道具 舉報

8#
ID:214223 發表于 2018-11-23 10:19 | 只看該作者
仿真圖如圖所示:程序:
#include <reg51.h>
#include <intrins.h>
#include "12864.c"

sbit REDE=P1^0;

//void delay(void)
//{
//     unsigned int i,j;
//         for(i=0;i<200;i++)
//           for(j=0;j<500;j++)  ;
//}
//
//void Send(unsigned char dat)
//{
//    SBUF=dat;
//        while(TI==0);
//        TI=0;
//}

void main(void)
{
    TMOD=0x20;
        SCON=0x50;
        PCON=0x00;
        TH1=0xFD;
        TR1=1;
        REN=1;
        EA=1;
        ES=1;
        LCD_Init();
        REDE=0;
    while(1);
// {
//         Send(0x23);
//        Send(0x31);
//        Send(0x32);
//        Send(0x0D);
//        delay();
// }
}

void Uart_Serve(void) interrupt 4 using 0
{
   if(RI==1)
   {
           RI=0;
        DisplayResult(SBUF);
   }
}


//12864的程序不需要贅述了吧

1.png (40.49 KB, 下載次數: 133)

1.png
回復

使用道具 舉報

9#
ID:279667 發表于 2018-11-23 10:58 | 只看該作者
根據RS485串口通訊協議,按照協議要求來操作TXD和RXD
回復

使用道具 舉報

10#
ID:609968 發表于 2020-3-12 14:53 | 只看該作者
原理圖按照三樓的那樣連接,程序如下:
#include <reg52.h>
#include <intrins.h>

sbit RS485_DIR = P1^7;  //RS485方向選擇引腳

bit flagFrame = 0;  //幀接收完成標志,即接收到一幀新數據
bit flagTxd = 0;    //單字節發送完成標志,用來替代TXD中斷標志位
unsigned char cntRxd = 0;   //接收字節計數器
unsigned char pdata bufRxd[64];  //接收字節緩沖區

extern void UartAction(unsigned char *buf, unsigned char len);

/* 串口配置函數,baud-通信波特率 */
void ConfigUART(unsigned int baud)
{
    RS485_DIR = 0; //RS485設置為接收方向
    SCON  = 0x50;  //配置串口為模式1
    TMOD &= 0x0F;  //清零T1的控制位
    TMOD |= 0x20;  //配置T1為模式2
    TH1 = 256 - (11059200/12/32)/baud;  //計算T1重載值
    TL1 = TH1;     //初值等于重載值
    ET1 = 0;       //禁止T1中斷
    ES  = 1;       //使能串口中斷
    TR1 = 1;       //啟動T1
}
/* 軟件延時函數,延時時間(t*10)us */
void DelayX10us(unsigned char t)
{
    do {
        _nop_();
        _nop_();
        _nop_();
        _nop_();
        _nop_();
        _nop_();
        _nop_();
        _nop_();
    } while (--t);
}
/* 串口數據寫入,即串口發送函數,buf-待發送數據的指針,len-指定的發送長度 */
void UartWrite(unsigned char *buf, unsigned char len)
{
    RS485_DIR = 1;  //RS485設置為發送
    while (len--)   //循環發送所有字節
    {
        flagTxd = 0;      //清零發送標志
        SBUF = *buf++;    //發送一個字節數據
        while (!flagTxd); //等待該字節發送完成
    }
    DelayX10us(5);  //等待最后的停止位完成,延時時間由波特率決定
    RS485_DIR = 0;  //RS485設置為接收
}
/* 串口數據讀取函數,buf-接收指針,len-指定的讀取長度,返回值-實際讀到的長度 */
unsigned char UartRead(unsigned char *buf, unsigned char len)
{
    unsigned char i;
   
    if (len > cntRxd)  //指定讀取長度大于實際接收到的數據長度時,
    {                  //讀取長度設置為實際接收到的數據長度
        len = cntRxd;
    }
    for (i=0; i<len; i++)  //拷貝接收到的數據到接收指針上
    {
        *buf++ = bufRxd[i];
    }
    cntRxd = 0;  //接收計數器清零
   
    return len;  //返回實際讀取長度
}
/* 串口接收監控,由空閑時間判定幀結束,需在定時中斷中調用,ms-定時間隔 */
void UartRxMonitor(unsigned char ms)
{
    static unsigned char cntbkp = 0;
    static unsigned char idletmr = 0;

    if (cntRxd > 0)  //接收計數器大于零時,監控總線空閑時間
    {
        if (cntbkp != cntRxd)  //接收計數器改變,即剛接收到數據時,清零空閑計時
        {
            cntbkp = cntRxd;
            idletmr = 0;
        }
        else                   //接收計數器未改變,即總線空閑時,累積空閑時間
        {
            if (idletmr < 30)  //空閑計時小于30ms時,持續累加
            {
                idletmr += ms;
                if (idletmr >= 30)  //空閑時間達到30ms時,即判定為一幀接收完畢
                {
                    flagFrame = 1;  //設置幀接收完成標志
                }
            }
        }
    }
    else
    {
        cntbkp = 0;
    }
}
/* 串口驅動函數,監測數據幀的接收,調度功能函數,需在主循環中調用 */
void UartDriver()
{
    unsigned char len;
    unsigned char pdata buf[40];

    if (flagFrame) //有命令到達時,讀取處理該命令
    {
        flagFrame = 0;
        len = UartRead(buf, sizeof(buf)-2); //將接收到的命令讀取到緩沖區中
        UartAction(buf, len);  //傳遞數據幀,調用動作執行函數
    }
}
/* 串口中斷服務函數 */
void InterruptUART() interrupt 4
{
    if (RI)  //接收到新字節
    {
        RI = 0;  //清零接收中斷標志位
        if (cntRxd < sizeof(bufRxd)) //接收緩沖區尚未用完時,
        {                            //保存接收字節,并遞增計數器
            bufRxd[cntRxd++] = SBUF;
        }
    }
    if (TI)  //字節發送完畢
    {
        TI = 0;   //清零發送中斷標志位
        flagTxd = 1;  //設置字節發送完成標志
    }
}
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表