基本信息
源码名称:STM8S003透传
源码大小:8.59KB
文件格式:.c
开发语言:C/C++
更新时间:2021-12-14
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 3 元 
   源码介绍
通过STM8S003单片机使用蓝牙透传实现简单物联网

 void main(void)
{  
  CLK_DeInit(); 
  CLK_HSIPrescalerConfig(CLK_PRESCALER_HSIDIV1);
  CLK_SYSCLKConfig(CLK_PRESCALER_CPUDIV1);
  TIM4_DeInit();
  GPIO_Config();  
  TIM1_DeInit();       
  TIM1_PWMSTOP();
  TIM4_Config();       
  uart_init(); 
  asm("rim");    //开总中断
  GPIO_Init(GPIOA, GPIO_PIN_2, GPIO_MODE_OUT_PP_HIGH_FAST);
  t=1;
  arand=10;
  GetBAT();
  GUA_ADC1_ReadAverage();
  value2=value1;
  while (1)
  {
    Charge();
    if(tt)
    {  
      TIM1_PWMSTOP(); 
      time_cnt=0;   GetBAT();
      GPIO_Init(GPIOA, GPIO_PIN_3, GPIO_MODE_OUT_PP_HIGH_SLOW);
      GPIO_Init(GPIOB, GPIO_PIN_5, GPIO_MODE_OUT_PP_HIGH_SLOW);
      GPIO_Init(GPIOA, GPIO_PIN_2, GPIO_MODE_OUT_PP_LOW_FAST);
      if(limadd<20)
      {lastadd=0;  arand ; if(arand>=100){arand=10;} }
      else 
      { 
        limadd=0; GPIO_Init(GPIOA, GPIO_PIN_2, GPIO_MODE_OUT_PP_LOW_FAST); 
      } 
      if(GPIOC->IDR & GPIO_PIN_7){ t=1;  }    
      if(!(GPIOA->IDR & GPIO_PIN_1)){CHRG=0;}
      else {CHRG=1;}
      if(!(GPIOD->IDR & GPIO_PIN_4)){STDBY=0;}
      else {STDBY=1;}   
      break;
 
    }
      
    
     static uint16_t count_i=0 ,ad0,ad0_max, ad0_last,ad0_min =0;
     int ad0_buf_number=1000, power_off_remain_timer = 0;
     
     static uint16_t ad1, ad1_last, ad1_min = 0 , ad1_max = 0;
     
     power_off_remain_timer=7000 - lastaddPower;
     pwm_out();
     GetAD3();
     count_i ;
     ad0 =value;
     ad0_max = ad0 > ad0_last?ad0:ad0_last;
     ad0_min = ad0 < ad0_last?ad0:ad0_last;
     ad0_last = ad0;
     
     ad1 = value1;
     ad1_max = ad1 > ad1_last?ad1:ad1_last;
     ad1_min = ad1 < ad1_last?ad1:ad1_last;
     ad1_last = ad1;
     
     if(count_i >= ad0_buf_number)
     {
        // 
       if(ad0_max - ad0_min >=45) 
       {lastadd = 0; flaga=30;lastaddPower=0;}
       else 
       {
         flaga=0;
         if( power_off_remain_timer > ad0_buf_number)
         {power_off_remain_timer -= ad0_buf_number;}
         else
         { tt=1; limadd=0;  }    
       }  
       ad0 = ad0_last =( ad0_last   ad0) >> 1;
       ad1 = ad1_last =( ad1_last   ad1) >> 1;
       count_i=0;
       //data_flame[9]= ad1_max-ad1_min;
     }
     
     
     if(!(GPIOA->IDR & GPIO_PIN_1)){CHRG=0;}
     else {CHRG=1;}
     if(!(GPIOD->IDR & GPIO_PIN_4)){STDBY=0;}
     else {STDBY=1;} 
     //GetBAT(); 
     //Battery();          
     GUA_ADC1_ReadAverage();
     ConvertSend();                       
     GPIO_Init(GPIOA, GPIO_PIN_2, GPIO_MODE_OUT_PP_HIGH_FAST);
     GPIO_Config();            
     if(!(GPIOA->IDR & GPIO_PIN_1)){CHRG=0;}
     else {CHRG=1;}
     if(!(GPIOD->IDR & GPIO_PIN_4)){STDBY=0;}
     else {STDBY=1;}                  

       if(time_cnt>=308000){t=0; while(c>0){uart_write(data_flame);c--;} }
       else
       {                   
         if(m>800)
         { 
           if(flaga>=30)                                  
           {   
             for(acnt=3;acnt<9;acnt )
             { 
               divide=308000/acount[acnt];
               if(time_cnt>=divide){timeadd=time_cnt/divide;}
               data_flame[acnt]=timeadd;  
               if(data_flame[acnt]>=acount[acnt])
               {data_flame[acnt]=acount[acnt]; }
             }    
           } 
           uart_write(data_flame);
           m=0;  
         }
       }
       if(t==0){break;}
       if(CHRG==0 && STDBY==1){t=0;break;}    


  }
}