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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機串口發送數據有問題,加了一個沒有調用的數組后串口通信就有問題了

[復制鏈接]
跳轉到指定樓層
樓主
ID:99434 發表于 2016-3-30 19:33 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
程序如下,如果加了ucha FP_Save_Finger[9]這個數組會出問題,但我根本沒有調用過那個數組,沒加這個數組時串口通信正常
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit CS=P0^7; //串行寫入,液晶借接口
sbit SID=P0^6;
sbit SCLK=P0^5;
sbit  RST=P0^3;
sbit  PSB=P0^4;

uchar buffer[18];
//指紋識別通信協議
uchar code  FP_pack_head[6]={0xef,0x01,0xff,0xff,0xff,0xff};//協議包頭
unsigned char code FP_Get_Img[6] = {0x01,0x00,0x03,0x01,0x0,0x05};    //獲取指紋圖像
code unsigned char FPMXX_Get_Templete_Count[6] ={0x01,0x00,0x03,0x1D,0x00,0x21 }; //獲取模板總數
code unsigned char FP_Search[11]={0x01,0x0,0x08,0x04,0x01,0x0,0x0,0x03,0xA1,0x0,0xB2}; //搜索指紋范圍0-929
code unsigned char FP_Search_0_9[11]={0x01,0x0,0x08,0x04,0x01,0x0,0x0,0x0,0x13,0x0,0x21}; //搜索0-9號指紋
code unsigned char FP_Img_To_Buffer1[7]={0x01,0x0,0x04,0x02,0x01,0x0,0x08}; //將圖像放進buffer1
code unsigned char FP_Img_To_Buffer2[7]={0x01,0x0,0x04,0x02,0x02,0x0,0x09}; //將圖像放進buffer2
code unsigned char FP_Reg_Model[6]={0x01,0x0,0x03,0x05,0x0,0x09}; //將buffer1和buffer2合成特征模板
code unsigned char FP_Delet_All_Model[6]={0x01,0x0,0x03,0x0d,0x00,0x11};//刪除指紋模塊里的所有模板
/*
uchar  FP_Save_Finger[9]={0x01,0x00,0x06,0x06,0x01,0x00,0x0b,0x00,0x19};
*/

//延時程序
void delay_1ms(uint m)
{
        uchar t,j;
        for(t=0;t<m;t++)
        {
                for(j=0;j<110;j++);
        }
}

//////////////串口發送,接收
void UART_init_57600()
{
         SCON = 0x50; // 1010000   工作方式一,允許接收
         TMOD = 0x20; //8位自動重裝 ,T1工作方式2,
         TH1 = 250;        //自動重裝,波特率為57600
         TL1 = 250;
         PCON = 0x80; //波特率加倍
         RI = 0;        //中斷標志位
         TI = 0;
         TR1 = 1; //啟動定時器1
         EA = 1; //全局中斷允許位
         ES = 1; //打開串口中斷
                 //T1定時器為串口通信的波特率設置位
}


void UART_Send_Byte(uchar d)//串口發送
{
        SBUF = d;
        while(!TI);
        TI = 0;
}

unsigned char UART_Receive_Byte()//串口接收
{       
        uchar dat;
        while(!RI);
        RI = 0;
        dat = SBUF;
        return (dat);
}
//////////////////
void FP_cmd_head()//協議包頭
{
        uchar i;
        for(i=0;i<6;i++)
        {
                UART_Send_Byte(FP_pack_head[i]);
        }
}

void FPMXX_Cmd_Get_Img(void)//獲取指紋圖像
{
    uchar i;

    FP_cmd_head();
       
    for(i=0;i<6;i++)
                {
      UART_Send_Byte(FP_Get_Img[i]);
                }
               
                for(i=0;i<12;i++)
    buffer[i]=UART_Receive_Byte();
}
//將圖像轉換為特征碼存儲在特征文件緩沖區1
void FINGERPRINT_Cmd_Img_To_Buffer1(void)
{
            unsigned char i;

               FP_cmd_head();

                      for(i=0;i<7;i++)
             {
                         UART_Send_Byte(FP_Img_To_Buffer1[i]);
                        }
                        for(i=0;i<12;i++)
      buffer[i]=UART_Receive_Byte();
}

//將圖像轉換為特征碼存儲在特征文件緩沖區2
void FINGERPRINT_Cmd_Img_To_Buffer2(void)
{
     unsigned char i;
     for(i=0;i<6;i++)   
           {
                   UART_Send_Byte(FP_pack_head[i]);   
            }

            for(i=0;i<7;i++)  
     {
                         UART_Send_Byte(FP_Img_To_Buffer2[i]);
            }
                 for(i=0;i<12;i++)
     buffer[i]=UART_Receive_Byte();
}

//將Buffer1和buffer2合并成指紋模板
void FINGERPRINT_Cmd_Reg_Model(void)
{
    unsigned char i;   

    for(i=0;i<6;i++)
    {
      UART_Send_Byte(FP_pack_head[i]);   
    }

    for(i=0;i<6;i++)
    {
      UART_Send_Byte(FP_Reg_Model[i]);   
    }
                for(i=0;i<12;i++)
    buffer[i]=UART_Receive_Byte();

}



/////液晶函數
void send_command(uchar command_data) //把命令寫進去函數 液晶
{
        uchar i;
        uchar i_data;
        i_data=0xf8;
        CS=1;
        SCLK=0;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;
                }
        i_data=command_data;
        i_data&=0xf0;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;
                }
        i_data=command_data;
        i_data<<=4;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;
                }
        CS=0;
        delay_1ms(10);
}
void send_data(uchar command_data)  //把數據寫進去函數  液晶
{
        uchar i;
        uchar i_data;
        i_data=0xfa;  
        CS=1;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;  
                }
        i_data=command_data;
        i_data&=0xf0;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;
                }
        i_data=command_data;
        i_data<<=4;
        for(i=0;i<8;i++)
                {
                        SID=(bit)(i_data&0x80);
                        SCLK=0;
                        SCLK=1;
                        i_data=i_data<<1;
                }
        CS=0;
        delay_1ms(10);  
}
void lcd_init()
{
        RST=1; //不復位,串行方式
        PSB=0;
        delay_1ms(100);
        send_command(0x30); /*設置8位數據接口,基本指令模式。*/
        send_command(0x02); /*清DDRAM*/
        send_command(0x06); /*游標及顯示右移一位*/  
        send_command(0x0c); /*整體顯示開,游標關,反白關*/
        send_command(0x01); /*寫入空格清屏幕*/
        send_command(0x80); /*設定首次顯示位置*/       
}
//////////////////////////////////////
void main()
{
        uchar i,shi,ge;
        delay_1ms(200);
        UART_init_57600();//波特率初始化
        lcd_init();//液晶顯示初始化
        do
        {
        FPMXX_Cmd_Get_Img();
        }while(buffer[9]!=0x0);//等待接收指紋模塊反饋的數據是否正確
       
        send_command(0x80);//把接收到的數據顯示在液晶上
        for(i=0;i<12;i++)
        {
                shi=buffer[i]/0x10;
                ge=buffer[i]%0x10;
                if(shi>9)
                {
                        send_data(shi+0x37);
                }
                else
                        send_data(shi+0x30);
               
                if(ge>9)
                {
                        send_data(ge+0x37);
                }
                else
                        send_data(ge+0x30);
        }
        while(1);
}


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:111494 發表于 2016-3-30 21:12 | 只看該作者
是否編譯時候出錯了,變量太多,超標了
回復

使用道具 舉報

板凳
ID:99434 發表于 2016-3-30 22:04 | 只看該作者
編譯沒錯,而且如果把多加的那個數組改成code的話就可以了,但是由于新加的數組需要改變所以不能加code,現在束手無策
回復

使用道具 舉報

地板
ID:97438 發表于 2016-3-31 00:07 | 只看該作者
因為你的程序超出了內存吧,換塊性能好一點的芯片就行了
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲一区二区三区久久 | 99在线免费观看视频 | 国产成人精品一区二区三区视频 | 最新国产福利在线 | 日韩视频在线观看中文字幕 | 在线亚洲精品 | 91亚洲欧美 | 一区精品视频 | 久久久久久久久久久久亚洲 | 日韩图区 | 日韩一区二区福利 | 久热久热| 欧美一区二区三区免费在线观看 | 午夜三级在线观看 | 精品国产乱码久久久久久影片 | 亚洲人精品 | 中文字幕在线免费观看 | 99久久婷婷国产综合精品首页 | 毛片网络 | 老司机午夜性大片 | 最新黄色在线观看 | 午夜三区 | 国产精品九九九 | 视频一区二区三区四区五区 | 亚洲精品国产成人 | 国产精品福利网 | 无码日韩精品一区二区免费 | 亚洲一区二区三区四区五区中文 | 欧美日韩视频网站 | 国产精品一区二区视频 | 国产一级片在线观看视频 | 人人人干 | 麻豆精品国产91久久久久久 | 91视频在线 | 日本aⅴ中文字幕 | 日韩成人在线网站 | 91视频网 | 黄色网毛片| 成人免费视频在线观看 | 欧美午夜剧场 | 一区二区三区在线电影 |