⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 duijj.c~rf34498f.tmp

📁 单边带调幅对讲机程序 msp430单片机控制 实现无线数据传输
💻 TMP
字号:
#include "msp430x24x.h"
#include "Init.h"
#include "NOKIA_5110.H"
#include "scancodes.h"
#include "Modem.h"
#include "DS1302.h"
#include "ziku.h"

#define Key_Data P2IN&BIT0
#define Key_CLK  P2IN&BIT1
#define SIDval   P2IN&BIT0

#define uchar unsigned char
#define uint unsigned int
#define Buf_Dp 100

unsigned char IntNum = 0;     //中断次数计数
unsigned char KeyV;           //键值
unsigned char DisNum = 0;     //显示用指针
unsigned char Key_UP=0, Shift = 0;   //Key_UP是键松开标识,Shift是Shift键按下标识
unsigned char BF = 0;         //标识是否有字符被收到
unsigned char pebit=0xff;    //奇偶校验标志位
unsigned char recdata=0;     //接收到的数据
unsigned char bitcount=11;   //位计数变量
unsigned char x=0,y=0;
unsigned char count=0;
char UART_TX_BUF[Buf_Dp];
char UART_RX_BUF[Buf_Dp];
char Tshow_Puf[100];
char Rshow_Puf[100];
unsigned char RX1_Len_temp;
static unsigned char nRX_Len;
static unsigned char nTX_Len;
static char nRX_Flag;
static char nTX_Flag;
static char Write_Flag=0;
static char Rece_Flag=0;
char signal;

char RX_Flag;
const char TAB_f_Week[][4]={{' ','S','u','n'},
                            {' ','M','o','n'},
                            {' ','T','u','e'},
                            {' ','W','e','d'},
                            {' ','T','h','u'},
                            {' ','F','R','i'},
                            {' ','S','a','t'}
                                            };
char NYR[11]={'2','0','0','8','-','1','1','-','1','8','\0'};
char Xinq[5];
unsigned char SF[5] ={0,2,10,4,4};
unsigned char Setting_Time[7]={ //bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0
 0x08,    //--------十位-------|-------个位--------|年份(当前07年)
 0x02,    //                        |-----个位-----|星期(当前周日)
 0x11,    //              |十位|-------个位--------|月份(当前07月)
 0x24,    //         |--十位---|-------个位--------|日期(当前01号)
 0x16,    //-12H|    |--十位---|-------个位--------|小时(当前18点)
 0x27,    //    |-----十位-----|-------个位--------|分钟(当前20分)
 0x00    //    |-----十位-----|-------个位--------|秒钟(当前30秒)
};
unsigned char ReadingData[7];  //读出来的数据,同SettingData定义与格式
char A_PM,O_Tm;
char test;
//char test[]="cuit";
void Get_time(unsigned char *ReadingData);
void Tlotal_m(char k);

void delay(int n)
{  unsigned int i;
   for(;n>0;n--)		       
   for(i=0;i<1000;i++);
}  
void Decode(unsigned char ScanCode) //注意:如SHIFT+G为12H 34H F0H 34H F0H 12H,也就是说shift的通码+G的通码+shift的断码+G的断码
{
unsigned char TempCyc;	
 if (!Key_UP)                //当键盘松开时
 { 
     if(count==0) {DisNum=0;x=0;y=0; NOKIA5110_set_XY(6*x,y);}
        switch (ScanCode)
          {
	    case 0xF0 :	// 当收到0xF0,Key_UP置1表示断码开始
		      Key_UP = 1;
		      break;
	    case 0x12 :	// 左 SHIFT
		      Shift = 1;
		      break;
            case 0x59 :	// 右 SHIFT
		      Shift = 1;        
		      break;  
            case 0x76 ://退出
                      Write_Flag=0;
                      Rece_Flag =0;
                      break;
            case 0x66:  //back space                                               
                      if((x == 0) && (y != 0))//如果游标在第2行第1位
                          {
                             x = 13;y --; }                                                                                  
                       else if(x != 0) 
                          {  x--;   }                                                                                 
                       else                   //如果游标在第1行第1位
                           {;}           //0x20是空格的ASCII码
                           NOKIA5110_set_XY(6*x,y);
                           if(count!=0)  {count--;DisNum--;}
                           Tshow_Puf[count]='\0';
                           NOKIA5110_w_char(32);
                           NOKIA5110_set_XY(6*x,y);
                        break;             
              case 0x5a:
                        Tshow_Puf[count++]='*';
                         x=0;y=0;
                        NOKIA5110_set_XY(x,y);
                        nTX_Flag=1;
                        break;

		default:						
			if (DisNum >= 84)
                        break;          
			if(!Shift)	//如果SHIFT没按下
			  {
				for (TempCyc = 0;(UnShifted[TempCyc][0]!=ScanCode)&&(TempCyc<59); TempCyc++); //查表显示
				if (UnShifted[TempCyc][0] == ScanCode) NOKIA5110_w_char( UnShifted[TempCyc][1]);
                                Tshow_Puf[count++]=UnShifted[TempCyc][1];
                                DisNum++;
                                x++;
                                if(x>13) 
                                { x=0;y++;
                                  if(y>5){x=0;y=0;}                                     
                                }	
                                NOKIA5110_set_XY(6*x,y);
                           } 
			else  //按下SHIFT
			   {
				for(TempCyc = 0; (Shifted[TempCyc][0]!=ScanCode)&&(TempCyc<59); TempCyc++); //查表显示
				if (Shifted[TempCyc][0] == ScanCode) NOKIA5110_w_char( Shifted[TempCyc][1]);
                                Tshow_Puf[count++]=Shifted[TempCyc][1];
				DisNum++;
                                x++;
                                if(x>13) 
                                   { x=0;y++;
                                     if(y>5){ x=0;y=0;}
                                   }	
                                NOKIA5110_set_XY(6*x,y);
			    }
			break;
	        }
         }
 else
	{	
	      Key_UP = 0;
	      switch (ScanCode) //当键松开时不处理判码,如G 34H F0H 34H 那么第二个34H不会被处理
		{
		     case 0x12 :	// 左 SHIFT
			Shift = 0;break;
		     case 0x59 :	// 右 SHIFT
			Shift = 0;break;
		}                        
	}
 BF = 0; //标识字符处理完了
 KeyV=0;
} 


void main( )  
{  char i,j=0; 
   WDTCTL = WDTPW + WDTHOLD;          // Stop WDT
  // P6DIR |=BIT6+BIT7;
  // P6OUT |=BIT6+BIT7;
   P5DIR =0XFF;
   P5OUT =0XFF;
   P3DIR |=BIT4+BIT5;
   P4DIR =0xff;
   P4OUT =0xff;
   P2SEL = 0x00; 
   P2DIR &=~ BIT1;     //Clock接P1.7,设置为输入
   P2DIR &=~ BIT0;     //SID接P4.6,设置为输入
   P2IES |=  BIT1; 
   P1SEL = 0x00;       //P1口作为IO使用
   P1DIR &=~ (BIT3+BIT2);
   P1IES |= BIT2+BIT3;      //下降沿中断
   P1IFG = 0x00;            //中断标志清零
   P2IFG = 0x00; 
   
   P1IE  |= BIT2+BIT3;      //使能时钟端口中断
   nRX_Len=0;
   nTX_Len=0;
   nRX_Flag=0;
   nTX_Flag=0;
   RX_Flag=0;
   initSys();
   NOKIA5110_init();
   NOKIA5110_draw_bmp(0,0,Start_p,82,47);
   Uart_init();
   Timerb_init();
   DS1302_Reset();
   //DS1302_SettingData(Setting_Time);
   Set_mb1504_1(3700);
   Set_mb1504_2(4800);
   ADC12_init();
   _EINT();        //打开全局中断控制
   P3OUT |= 0x30;
   Rx_Mode();
   //test=0xff;
 while(1)
{ 
/*  P3OUT |= 0x30;
  Tx_Mode();
  delay(1000);
  usart_putchar(test);*/
  
  if((Write_Flag!=0)|(Rece_Flag!=0))
    { 
        TBCCTL0=0x00;
        NOKIA5110_clear();
        x=0;y=0;
        NOKIA5110_set_XY(6*x,y);
        count=0;
        P2IE |= BIT1;
        while(1)
        {                           
          if(nTX_Flag==1)
            { 
            P3OUT |= 0x30;
            Tx_Mode();
            delay(1000);
            nTX_Len=PackData(UART_TX_BUF,Tshow_Puf,count);  
            String_printf(UART_TX_BUF);
            for(i=0;i<=nTX_Len;i++)
            { Tshow_Puf[i]='\0'; 
            UART_TX_BUF[i]='\0';}  
             nTX_Flag=0;  
            //DisNum=0;
            count=0;
            delay(10);
            P3OUT |= 0x30;  
            Rx_Mode();
            j=0x01;}
              
           if(j==0x01){j=0x00; break;}
    
           if ( nRX_Flag==1 )
           { 
             NOKIA5110_clear();
             NOKIA5110_w_char_string(0,0,UART_RX_BUF);
             for(i=Buf_Dp-1;i!=0;i--)
             { UART_RX_BUF[i]='\0'; }
             RX1_Len_temp=0;
             nRX_Flag=0;
             Write_Flag=1;
           }    
          if( Rece_Flag==1&count!=0){Rece_Flag=0;count=0;NOKIA5110_clear();}
          if((Write_Flag==0)&(Rece_Flag==0)) 
            {   NOKIA5110_clear();
                 x=0;y=0; break;
            }
        }  
        TBCCTL0=CCIE;
      } 
  else  { P2IE &=~BIT1;}
  }
}
#pragma vector=PORT2_VECTOR
__interrupt void  PORT2_ISR(void)
{
    if(P2IFG & BIT1)            //如果是clock的中断
    {
        P2IFG &=~ BIT1;         //清除中断标志      
        if(bitcount == 11)      //接收第1位
        {
            if(SIDval)          //如果不是起始位
               return;
            else  
                bitcount--;
        } 
        else if(bitcount == 2)    //接收奇偶校验位
        {   
            if(SIDval)          //如果校验位等于1
                pebit = 1;
            else
                pebit = 0;
            bitcount--;
        }
        else if(bitcount == 1)    //接收停止位
        {
            if(SIDval)          //若停止位正确
            {
                bitcount = 11;    //复位位计数变量
                 IntNum = 0; //当中断11次后表示一帧数据收完,清变量准备下一次接收
		       BF = 1; //标识有字符输入完了
		      _DINT(); //关中断等显示完后再开中断 (注:如这里不用BF和关中断直接调Decode()则所Decode中所调用的所有函数要声明为再入函数)
                 Decode(recdata) ;   //解码获得此键值的ASCII值并保存
                //    LPM3_EXIT;           //退出低功耗模式
                recdata = 0;          //清除接收数据
                _EINT () ; //开中断
            }
            else                //如果出错
            {
                bitcount = 11;
                recdata = 0;    
            }
        }
        else                    //接收8个数据位
        {
            recdata >>= 1;
            if(SIDval)  recdata |= 0x80;
            bitcount--;
        }
    }
}
 #pragma vector=PORT1_VECTOR
__interrupt void  PORT1_ISR(void)
{
   if(P1IFG & BIT3)
   { delay(100);         //去抖
     P1IFG &=~ BIT3;
     Write_Flag=0x01;
   }
   if(P1IFG & BIT2)
   { delay(100);         //去抖
     P1IFG &=~ BIT2;
     Write_Flag=0x00;
     Rece_Flag=0;
     nRX_Flag=0x00;
   }
}

#pragma vector=USCIAB1RX_VECTOR
__interrupt void USCI1RX_ISR(void)
{  char Resv=0;
     _DINT();
    if(RX_Flag==1)                        //接收标志位是否为一,是将数据载入缓存
  {
       UART_RX_BUF[RX1_Len_temp] = UCA1RXBUF;
       if( RX1_Len_temp<100) RX1_Len_temp++;
       else  RX1_Len_temp=0;
       if(UART_RX_BUF[RX1_Len_temp-1]=='%')      //收到结束标志,接收完成。
      { 
        UART_RX_BUF[RX1_Len_temp-1]='\0';
        RX_Flag =0;                         //清除接收标志
        nRX_Flag =1;                        //接收完成标志
        Rece_Flag=1;
      }
  }
  else                                    //等待引导码
  { Resv = UCA1RXBUF;
    if(Resv =='!')
          RX_Flag=1;
    Resv = 0;   
  }
  _EINT();
}

#pragma vector=TIMERB0_VECTOR
__interrupt void Timer_B0(void)
{ int results[2];
  ADC12CTL0 &= ~ENC;
  
  results[0] =ADC12MEM0;
  results[1] =ADC12MEM1;
  
  if(results[0]>=2500){signal=3;}
  else if((results[0]<2500)&(results[0]>1000)){signal=2;}
  else  {signal=0;}
   
  Tlotal_m(signal);
  ADC12CTL0 |= ENC+ADC12SC;
}

void Get_time(unsigned char *ReadingData)
 {
   char i,k;
   DS1302_GetData(ReadingData);
   NYR[2]=(char)(((ReadingData[0]>>4)&0x0f)+48);//年
   NYR[3]=(char)((ReadingData[0]&0x0f)+48);  
   NYR[5]=(char)(((ReadingData[2]>>4)&0x0f)+48);//月
   NYR[6]=(char)((ReadingData[2]&0x0f)+48);   
   NYR[8]=(char)(((ReadingData[3]>>4)&0x0f)+48);//日
   NYR[9]=(char)((ReadingData[3]&0x0f)+48); 
   
   switch(ReadingData[1])
   {
   case  0x01:{k=0;break;}
   case  0x02:{k=1;break;}
   case  0x03:{k=2;break;}
   case  0x04:{k=3;break;}
   case  0x05:{k=4;break;}
   case  0x06:{k=5;break;}
   case  0x07:{k=6;break;}
   default:        break;
   }  
   for(i=0;i<4;i++)
   {  Xinq[i]=TAB_f_Week[k][i];}
   
   O_Tm =(char)((ReadingData[4]>>4)&0x08);
   A_PM =(char)((ReadingData[4]>>4)&0x02);//时
   
   if(O_Tm==0x08)
   {SF[0]=(char)((ReadingData[4]>>4)&0x01);}//时
   else 
   {SF[0]=(char)((ReadingData[4]>>4)&0x03);  }
   SF[1]=(char)(ReadingData[4]&0x0f);  
   SF[3]=(char)((ReadingData[5]>>4)&0x0f);//分
   SF[4]=(char)(ReadingData[5]&0x0f);  
}

void Tlotal_m(char k)
    {  char i;
    NOKIA5110_clear();
    NOKIA5110_draw_bmp(0,0,TX,8,8);
    for(i=0;i<=k;i++)
    NOKIA5110_w_Symbol(i);
    Get_time(ReadingData);
    NOKIA5110_w_char_string(0,1,"SSB interphone");
      for(i=0;i<5;i++)
    { Write_shuzi((i+2)*8,2,b[SF[i]]);}
    
    if(O_Tm==0x08)
    { if(A_PM==0x02) Write_hanzi(64,2,PM);
      else           Write_hanzi(64,2,AM);}
    
    NOKIA5110_w_char_string(0,4,NYR);
    NOKIA5110_w_char_string(10*6,4,Xinq);
    NOKIA5110_w_char_string(0,5,"Message");
    NOKIA5110_w_char_string(10*6,5,"Back");
    }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -