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

標題: 單片機驅動液晶顯示屏的控制系統設計(資料) [打印本頁]

作者: gzyixian    時間: 2014-5-22 11:07
標題: 單片機驅動液晶顯示屏的控制系統設計(資料)
介紹單片機驅動控制液晶顯示器(帶觸摸屏)的控制系統設計實例,支持modbus通訊協議,采用的是51單片機,驅動控制19寸液晶顯示器(可以是15寸,17寸,19寸,30寸,52寸,55寸顯示器或電視機)。支持單片機TTL電平串口,RS232串口,RS485串口,以太網連接. 液晶顯示控制器系統軟件使用人機界面組態軟件HMImaker開發,主要有操作畫面、參數設置畫面、參數修改、系統登錄畫面、狀態監控畫面等功能,界面可以自由設計開發,組態軟件開發顯示與操作界面,“0”編程、"所見即所得"、"0"代碼、如"制作PPT"一樣簡單,快速!。
本設計以51單片機作為LCD液晶顯示系統控制器為主線,基于單片機8051,采用單片機的C語言來進行軟件設計,指令的執行速度快,節省存儲空間。為了便于擴展和更改,軟件的設計根據單片機的串口通信協議(易顯單片機協議),支持modbus通訊協議。采用模塊化結構,使程序設計的邏輯關系更加簡潔明了。使硬件在軟件的控制下協調運作。其次闡述了部分程序的流程圖和實現過程。本文撰寫的主導思想是軟、硬件相結合,以硬件為基礎,來進行各功能模塊的編寫。以下對所開發的用單片機實現LCD液晶顯示器控制原理的設計思想和軟、硬件調試作了詳細的論述。

以下是單片機8051的通訊協議和程序介紹:
#include<Atmel/AT89x52.H>
//定義數據類型(可以是數據結構)
//*************************************************************
void InitUART(void)         //串口初始化使用22.1184M晶體
{
       SCON= 0x50;                 //選擇模式18位數據格式,使能UART
      PCON|= 0x80;                 //波特率加倍
      TMOD=TMOD| 0x20;                //定時器1:模式2 ,自動裝載初值      
         //波特率計算公式:TH1=TL1=256-(2*22.1184*1000000)/(32*12*baud)
         //若選115200波特率則TH1=TL1=256-(2*22.1184*1000000)/(32*12*115200)=0xff
         //若選19200波特率則TH1=TL1=256-(2*22.1184*1000000)/(32*12*19200)=0xfa
      TH1= 0xfa;                     
      TL1= 0xfa;
         TR1 = 1;                          //定時器1計數使能
         REN = 1;                //允許串口接受使能
}
/*
******************************************************************
* 名稱:    write_byte()
* 功能:    向串口發送一個字節的數據
* 入口參數:i為待發送的字節數據
******************************************************************
*/
voidUART_SendByte(unsigned char i)
{
         SBUF=i;          //發送本次數據
         while(TI==0){}//等待發送完畢
    TI=0;
}
#define   m_ReadVarAdr       48          //類型:unsignedint   初始值:40   解釋:待讀 變量地址
#define   m_WriteAdr         52          //類型:unsignedint   初始值:28   解釋:待寫變量地址
/////////////////////////////////本文件如有不明白的地方,咨詢熱線:13829764765. QQ252631158 /////////
//////////////////////////////////////////////////////////////////////////////////
//unsigned int adr表示需要設置的HMI變量的地址,
//unsigned shortnBytes表示需要設置的HMI變量占一個字節的空間,如果是int變量就占4個字節,如果是short變量就占2個字節,如果是char變量就占1個字節
//unsigned char*m_VarP表示你要設置的HMI變量數據源的的指針,指針所指向的內容就是在HMI變量的將要被設置成的內容
//小技巧:有的時候希望通過調用一次SetVariable一次性設置3int變量的HMI變量,只要這3int變量的地址是連續的,那么只要讓nBytes=3*4=12個字節就OK
voidSetVariable(unsigned int adr,unsigned short nBytes,unsigned char *m_VarP)
{
    unsigned char temp;
    unsigned short m_CheckCRC;//命令校驗
         UART_SendByte(0x81);       //開始,固定,一個字節
         UART_SendByte(0x0);                  //命令類型,設置變量
         UART_SendByte(0x2);                  //接收方的設備號
         m_CheckCRC=0x81+0x0+0x2;//前面三個字節的校驗和
         temp=adr&0xff;
         UART_SendByte(temp);      //地址1
         m_CheckCRC=m_CheckCRC+temp;//每發送一個字節,計算一次校驗和
         temp=(adr>>8)&0xff;
         UART_SendByte(temp);      //地址2
         m_CheckCRC=m_CheckCRC+temp;
         temp=0;
         UART_SendByte(temp);      //地址3      固定為0
         m_CheckCRC=m_CheckCRC+temp;
         temp=0;
         UART_SendByte(temp);      //地址4      固定為0
         m_CheckCRC=m_CheckCRC+temp;     
         temp=(nBytes)&0xff;
         UART_SendByte(temp);      //個數低8
         m_CheckCRC=m_CheckCRC+temp;                        
         temp=(nBytes>>8)&0xff;
         UART_SendByte(temp);      //個數高8
         m_CheckCRC=m_CheckCRC+temp;     
         while(nBytes!=0)
         {
            temp=*m_VarP;
                   UART_SendByte(temp);      
                   m_CheckCRC=m_CheckCRC+temp;     
            nBytes--;
            m_VarP++;
         }
         UART_SendByte(m_CheckCRC);
         UART_SendByte(m_CheckCRC>>8);
}
//unsigned int adr表示需要查詢的HMI變量的地址,
//unsigned shortnBytes表示需要查詢的HMI變量占多少個字節的空間,如果是int變量就占4個字節,如果是short變量就占2個字節,如果是char變量就占1個字節
//小技巧:有的時候希望通過調用一次ReadVariable一次性讀取3int變量的HMI變量,只要這3int變量的地址是連續的,那么只要讓nBytes=3*4=12個字節就OK
void ReadVariable(unsignedint adr,unsigned short nBytes)
{
    unsigned char temp;
    unsigned short m_CheckCRC;//命令校驗
         UART_SendByte(0x81);       //開始,固定,一個字節
         UART_SendByte(0x1);                  //命令類型,查詢變量
         UART_SendByte(0x2);                  //接收方的設備號
         m_CheckCRC=0x81+0x1+0x2;//前面三個字節的校驗和
         temp=adr&0xff;
         UART_SendByte(temp);      //地址1
         m_CheckCRC=m_CheckCRC+temp;     //每發送一個字節,計算一次校驗和
         temp=(adr>>8)&0xff;
         UART_SendByte(temp);      //地址2
         m_CheckCRC=m_CheckCRC+temp;
         temp=0;
         UART_SendByte(temp);      //地址3       固定為0
         m_CheckCRC=m_CheckCRC+temp;
         temp=0;
         UART_SendByte(temp);      //地址4       固定為0
         m_CheckCRC=m_CheckCRC+temp;     
         temp=(nBytes)&0xff;
         UART_SendByte(temp);      //個數低8
         m_CheckCRC=m_CheckCRC+temp;                        
         temp=(nBytes>>8)&0xff;
         UART_SendByte(temp);      //個數高8
         m_CheckCRC=m_CheckCRC+temp;     
         UART_SendByte(m_CheckCRC);
         UART_SendByte(m_CheckCRC>>8);
}
unsigned charmIndex=0;           //定義一個數據索引
unsigned charmCmdAdrBuf[4];    //定義一個緩沖區用于緩沖HMI變量地址
unsigned charmCmdnBytesBuf[2]; //定義一個緩沖區用于緩沖HMI變量字節數量
unsigned charmHmiVarBuf[4];    //定義一個緩沖區用于緩沖HMI變量m_ReadVarAdr內容,因為該變量是4個字節的int變量
unsigned charmHmiVarCheck[2];
unsigned charmReceiveFlag=0;   //串口中斷成功接收到一個HMI變量設置命令標志
unsigned charmState=0;                //命令接收狀態
unsigned shortmCheckHe;
unsigned intdelay=0;//延時變量
void main(void)
{
     InitUART();
          EA=1; //打開中斷總開關,
          ES=1; //打開串口中斷
          //ET0=1;//打開定時器中斷,每隔50MS中斷一次
          while(1) //進入不斷循環
          {
            delay++;
                   if(delay>=65535)//延時一段時間(300MS)
                   {
                       delay=0;
                            ReadVariable(m_ReadVarAdr,4);//讀取HMI變量命令發出去。本例子中m_ReadVarAdr的地址是48,是一個unsigned int 變量,占4個字節
                   }
                   if(mReceiveFlag==1)//如果接收到數據
                   {
                            mReceiveFlag=0;
                            SetVariable(m_WriteAdr,4,mHmiVarBuf);
                   }
          }
}
unsigned charbufcom1;
void uart(void)interrupt 4
{
         if(RI==0)    return;
                    RI=0;
                    bufcom1=SBUF;//讀串口一的上的數據
                    if(mState==0)//階段0,等待接收0x81,命令開始
                    {     
                       mCheckHe=0x81;
                            if(bufcom1==0x81)//如果收到0x81,就進入階段1
                            {
                               mState=1;
                            }
                            else mState=0;//接收錯誤,跳回階段0
                    }
                    else if(mState==1)//階段1,等待接收0x0,是否是工控機發過來的“設置變量命令”
                    {
                       mCheckHe=mCheckHe+bufcom1;
                            if(bufcom1==0x0)// 是工控機發過來的“設置變量命令”,就進入階段2
                            {
                               mState=2;
                            }
                            else mState=0;//接收錯誤,跳回階段0
                    }
                    else if(mState==2)      //階段2,等待接收0x2,是否是工控機發過來的設備號
                    {
                       mCheckHe=mCheckHe+bufcom1;
                            if(bufcom1==0x2)
                            {
                               mState=3;
                               mIndex=0;// 先清0索引,為階段3做準備
                            }
                            else mState=0; //接收錯誤,跳回階段0
                    }
                    else if(mState==3)      //階段3,等待接收地址,4個字節
                    {
                           mCheckHe=mCheckHe+bufcom1;
                            mCmdAdrBuf[mIndex]=bufcom1;
                            mIndex++;
                            if(mIndex==4)  //已經接完4個字節的地址
                            {
                               mState=4;
                               mIndex=0;// 先清0索引,為階段4做準備
                            }
                    }
                    else if(mState==4)      //階段4,等待接收字節數,2個字節
                    {
                       mCheckHe=mCheckHe+bufcom1;
                            mCmdnBytesBuf[mIndex]=bufcom1;
                            mIndex++;
                            if(mIndex==2)  //已經接完2個字節
                            {
                              if((mCmdnBytesBuf[0]==4)&&(mCmdnBytesBuf[1]==0))//如果收到的是4個字節數據
                               {
                                        mState=5;
                                        mIndex=0;// 為階段5做準備
                               }
                               else mState=0; //接收錯誤,跳回階段0
                            }
                    }
                    else if(mState==5)      //階段5,等待接收4個數據
                    {
                       mCheckHe=mCheckHe+bufcom1;
                            mHmiVarBuf[mIndex]=bufcom1;
                            mIndex++;
                            if(mIndex==4)  //已經接完4個字節
                            {
                                     mState=6;
                                     mIndex=0;//為階段6做準備
                            }
                    }
                    else if(mState==6)      //階段6,接收2個數據校驗和
                    {
                            mHmiVarCheck[mIndex]=bufcom1;
                            mIndex++;
                            if(mIndex==2)  //已經接完2個字節
                            {
                                     mState=0;  //接收完畢,從頭開始
                                     if(mHmiVarCheck[0]==(mCheckHe%256))      //比較校驗和低字節
                                        if(mHmiVarCheck[1]==(mCheckHe/256))  //比較校驗和高字節
                                          if(mCmdAdrBuf[0]==m_ReadVarAdr%256)  //比較HMI變量地址第0個字節
                                                    if(mCmdAdrBuf[1]==(m_ReadVarAdr/256))  //比較HMI變量地址第1個字節
                                                           if(mCmdAdrBuf[2]==0x0)       //比較HMI變量地址第2個字節
                                                              if(mCmdAdrBuf[3]==0x0) //比較HMI變量地址第3個字節
                                                                  {
                                                                       mReceiveFlag=1;//如果地址和校驗和沒問題,表示已經成功讀到了工控機的m_ReadVarAdr變量
                                                              }
                            }
                    }
                    else mState=0;

}





單片機驅動液晶顯示屏的控制系統設計(資料).zip (966.77 KB, 下載次數: 90)


作者: 娃娃魚翅膀    時間: 2014-6-20 13:53
厲害。
作者: ddyy2266    時間: 2014-9-28 11:30

謝謝樓主!!
作者: 邊緣人    時間: 2014-11-1 17:08
流程圖及電路連接圖?
作者: 4258036    時間: 2014-12-2 11:25
謝謝分享
作者: abczzy2012    時間: 2015-1-10 23:21
學習了。。。。。
作者: 101寢室長    時間: 2015-4-26 21:52
很給力
作者: 101寢室長    時間: 2015-4-26 21:52
不錯的
作者: 一只菜鳥2015    時間: 2015-6-5 09:11

作者: 黃士兵    時間: 2015-12-2 17:53
厲害,來學習一下
作者: 牛牛塞納    時間: 2017-3-26 23:33
不錯,謝謝樓主!
作者: cdh44    時間: 2017-9-1 14:51
真是很及時
作者: cdh44    時間: 2017-9-1 14:52
回復好像沒好處
作者: cdh44    時間: 2017-9-1 14:52
厲害了   來學習一下
作者: 楊瑞華    時間: 2017-11-11 18:17
下載!!!!!!!!!!!!!




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1