ADC例程我将脚位改成PB1后不管怎么量测就是电压数值没有反应

2019-07-21 02:37发布

请大神们帮忙看看
我用原子哥的ADC例程由LCD1602显示本来原子哥的ADC脚位是预设PA1
我将脚位改成PB1后不管怎么量测就是电压数值没有反应
(量測方法我將PB1用一條杜邦線去接GND和3.3V都沒反應)

请大神们帮忙看看是不是不只是要改红 {MOD}的部分
以下为main.c主程序

#include "led.h"
#include "delay.h"
#include "key.h"
#include "sys.h"
#include "lcd1602.h"
#include "usart.h"    
#include "can.h"
#include "adc.h"
 
 int main(void)
 {    
    u16 adcx;
    float temp;
    u8 key;
    u8 i=0,t=0;
    u8 cnt=0;
    u8 canbuf[8];
    u8 res;
    u8 mode=CAN_Mode_LoopBack;//CAN工作模式;CAN_Mode_Normal(0):普通模式,CAN_Mode_LoopBack(1):环回模式

    delay_init();             //延时函数初始化      
    NVIC_Configuration();      //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
    uart_init(9600);         //串口初始化为9600
    LED_Init();                  //初始化与LED连接的硬件接口
    LCD_Init();                   //初始化LCD    
    KEY_Init();                //按键初始化    
  Adc_Init();    
   
    CAN_Mode_Init(CAN_SJW_1tq,CAN_BS2_8tq,CAN_BS1_7tq,5,CAN_Mode_LoopBack);//CAN初始化环回模式,波特率450Kbps    

     //POINT_COLOR=RED;//设置字体为红 {MOD}
    //LCD_ShowString(60,50,200,16,16,"WarShip STM32");    
    //LCD_ShowString(60,70,200,16,16,"CAN TEST");    
    //LCD_ShowString(60,90,200,16,16,"ATOM@ALIENTEK");
    //LCD_ShowString(60,110,200,16,16,"2012/9/11");
    //LCD_ShowString(60,130,200,16,16,"LoopBack Mode");    
    //LCD_ShowString(60,150,200,16,16,"KEY0:Send WK_UP:Mode");//显示提示信息        
      //POINT_COLOR=BLUE;//设置字体为蓝 {MOD}      
    //LCD_ShowString(60,170,200,16,16,"Count:");            //显示当前计数值    
    //LCD_ShowString(60,190,200,16,16,"Send Data:");        //提示发送的数据    
    //LCD_ShowString(60,250,200,16,16,"Receive Data:");    //提示接收到的数据        
    
    LCD_Setpos_DisplayString(0,0,"LoopBack Mode");
     while(1)
    {
        
        adcx=Get_Adc_Average(ADC_Channel_1,10);
        //LCD_ShowxNum(156,130,adcx,4,16,0);//显示ADC的值-原本原子例程 显示
        LCD_Setpos_DisplayNum(13,1,adcx);//LCD1602用显示
        temp=(float)adcx*(3.3/4096);
        adcx=temp;
        //LCD_ShowxNum(156,150,adcx,1,16,0);//显示电压值-原本原子例程 显示
        LCD_Setpos_DisplayNum(6,1,adcx);//LCD1602用显示
        temp-=adcx;
        temp*=1000;
        //LCD_ShowxNum(172,150,temp,3,16,0X80);//原本原子例程 显示
        LCD_Setpos_DisplayNum(8,1,temp);//LCD1602用显示
        
        key=KEY_Scan(0);
        if(key==KEY_RIGHT)//KEY0按下,发送一次数据
        {
            for(i=0;i<8;i++)
            {
                canbuf=cnt+i;//填充发送缓冲区
                //if(i<4)LCD_ShowxNum(60+i*32,210,canbuf,3,16,0X80);    //显示数据
                LCD_Setpos_DisplayString(0,1,(u8 *)canbuf);
                //else LCD_ShowxNum(60+(i-4)*32,230,canbuf,3,16,0X80);    //显示数据
             }
            res=Can_Send_Msg(canbuf,8);//发送8个字节
            //if(res)LCD_ShowString(60+80,190,200,16,16,"Failed");        //提示发送失败
            if(res)LCD_Setpos_DisplayString(0,1,"Failed");
            //else LCD_ShowString(60+80,190,200,16,16,"OK    ");             //提示发送成功            
        else LCD_Setpos_DisplayString(0,1,"OK");            
        }else if(key==KEY_UP)//WK_UP按下,改变CAN的工作模式
        {       
            mode=!mode;
              CAN_Mode_Init(CAN_SJW_1tq,CAN_BS2_8tq,CAN_BS1_7tq,5,mode);//CAN普通模式初始化, 波特率450Kbps
            //POINT_COLOR=RED;//设置字体为红 {MOD}
            if(mode==0)//普通模式,需要2个开发板
            {
                //LCD_ShowString(60,130,200,16,16,"Nnormal Mode ");       
                  LCD_clear();
          LCD_Setpos_DisplayString(0,0,"Nnormal Mode ");                
            }else //回环模式,一个开发板就可以测试了.
            {
                 //LCD_ShowString(60,130,200,16,16,"LoopBack Mode");
                LCD_clear();
                LCD_Setpos_DisplayString(0,0,"LoopBack Mode");
            }
             //POINT_COLOR=BLUE;//设置字体为蓝 {MOD}
        }        
        key=Can_Receive_Msg(canbuf);
        if(key)//接收到有数据
        {            
            //LCD_Fill(60,270,130,310,WHITE);//清除之前的显示
            LCD_clear();
            
             for(i=0;i<key;i++)
            {                                        
                //if(i<4)LCD_ShowxNum(60+i*32,270,canbuf,3,16,0X80);    //显示数据
                  LCD_Setpos_DisplayString(0,1,(u8 *)canbuf);//canbuf or =canbuf
                //else LCD_ShowxNum(60+(i-4)*32,290,canbuf,3,16,0X80);    //显示数据
             }
        }
        t++;
        delay_ms(10);
        if(t==20)
        {
            LED0=!LED0;//提示系统正在运行    
            t=0;
            cnt++;
            //LCD_ShowxNum(60+48,170,cnt,3,16,0X80);    //显示数据
            LCD_Setpos_DisplayString(0,1,(u8 *)cnt);
        }           
    }
}

以下是adc.c

#include "adc.h"
 #include "delay.h"
//////////////////////////////////////////////////////////////////////////////////    
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//ALIENTEK战舰STM32开发板
//ADC 代码       
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2012/9/7
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 广州市星翼电子科技有限公司 2009-2019
//All rights reserved                                      
//////////////////////////////////////////////////////////////////////////////////
       
           
//初始化ADC
//这里我们仅以规则通道为例
//我们默认将开启通道0~3                                                                       
void  Adc_Init(void)
{     
    ADC_InitTypeDef ADC_InitStructure;
    GPIO_InitTypeDef GPIO_InitStructure;

    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB |RCC_APB2Periph_ADC1    , ENABLE );      //使能ADC1通道时钟
 

    RCC_ADCCLKConfig(RCC_PCLK2_Div6);   //设置ADC分频因子6 72M/6=12,ADC最大时间不能超过14M

    //PA1 作为模拟通道输入引脚                         
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;        //模拟输入引脚
    GPIO_Init(GPIOB, &GPIO_InitStructure);    

    ADC_DeInit(ADC1);  //复位ADC1,将外设 ADC1 的全部寄存器重设为缺省值

    ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;    //ADC工作模式:ADC1和ADC2工作在独立模式
    ADC_InitStructure.ADC_ScanConvMode = DISABLE;    //模数转换工作在单通道模式
    ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;    //模数转换工作在单次转换模式
    ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;    //转换由软件而不是外部触发启动
    ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;    //ADC数据右对齐
    ADC_InitStructure.ADC_NbrOfChannel = 1;    //顺序进行规则转换的ADC通道的数目
    ADC_Init(ADC1, &ADC_InitStructure);    //根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器   

 
    ADC_Cmd(ADC1, ENABLE);    //使能指定的ADC1
    
    ADC_ResetCalibration(ADC1);    //使能复位校准  
    
    while(ADC_GetResetCalibrationStatus(ADC1));    //等待复位校准结束
    
    ADC_StartCalibration(ADC1);     //开启AD校准
 
    while(ADC_GetCalibrationStatus(ADC1));     //等待校准结束
 
//    ADC_SoftwareStartConvCmd(ADC1, ENABLE);        //使能指定的ADC1的软件转换启动功能

}                  
//获得ADC值
//ch:通道值 0~3
u16 Get_Adc(u8 ch)   
{
      //设置指定ADC的规则组通道,一个序列,采样时间
    ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_239Cycles5 );    //ADC1,ADC通道,采样时间为239.5周期                      
 
    ADC_SoftwareStartConvCmd(ADC1, ENABLE);        //使能指定的ADC1的软件转换启动功能    
    
    while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待转换结束

    return ADC_GetConversionValue(ADC1);    //返回最近一次ADC1规则组的转换结果
}

u16 Get_Adc_Average(u8 ch,u8 times)
{
    u32 temp_val=0;
    u8 t;
    for(t=0;t<times;t++)
    {
        temp_val+=Get_Adc(ch);
        delay_ms(5);
    }
    return temp_val/times;
}     






























友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
9条回答
hack906447
1楼-- · 2019-07-21 07:23
回复【2楼】正点原子:
---------------------------------
谢谢原子哥回答
接线部分确定没问题
adcx=Get_Adc_Average(ADC_Channel_1,10);
这里是不是需要修改?
因为改成脚位PB1所以要改成ADC_Channel_9吗?
那么跟10有关联吗?
正点原子
2楼-- · 2019-07-21 13:14
 精彩回答 2  元偷偷看……
正点原子
3楼-- · 2019-07-21 13:34
回复【3楼】hack906447:
---------------------------------
对哦,要改成9才是。
hack906447
4楼-- · 2019-07-21 15:49
回复【4楼】正点原子:
---------------------------------
谢谢原子哥给方向看了很久不知到哪里还有错麻烦原子哥有空帮忙在看看
hack906447
5楼-- · 2019-07-21 21:30
回复【4楼】正点原子:
---------------------------------
原子哥我修改了也编辑多次不知道编辑成功为什么还是没办法侦查电压?有没有什么方法可以提供我检验?!
正点原子
6楼-- · 2019-07-22 02:15
 精彩回答 2  元偷偷看……

一周热门 更多>