如何使用STM8S单片机的多通道AD转换

 我来答
time陌言成殇
推荐于2017-12-16 · TA获得超过8.4万个赞
知道大有可为答主
回答量:1.4万
采纳率:91%
帮助的人:9520万
展开全部
#include "adc.h"
 u16  TempADC;
void ADC_Config(void) 
{
    ADC_CR1 |= 0x01;    //开始启动初始化必须启动一次
                        //第一次写1,ADC从低功耗唤醒,第二次写1,启动ADC转换
   //ADC_CR1 |= 0x20; //使能转换结束中断,本例中采用的查询方式。
}
 
uint16_t Get_ADCCH_Value(ADC1_Channel_TypeDef ADC_Channel)

  ADC1_Init(ADC1_CONVERSIONMODE_CONTINUOUS,ADC_Channel, ADC1_PRESSEL_FCPU_D2,
     ADC1_EXTTRIG_TIM, DISABLE, ADC1_ALIGN_RIGHT, ADC1_SCHMITTTRIG_ALL, DISABLE);
    //你也可以用操作寄存器的方式代码如下,但未验证。
#if 0
ADC_CR2 = 0x00;             // A/D结果数据左对齐
CLK_PCKENR2 |= 0x08;        // 使能fMASTER与ADC的连接
ADC_CR1 = 0x00;// ADC时钟=主时钟/2=8MHz,单次转换模式
ADC_CSR = 0x01;             // 选择通道2
ADC_TDRL = 0x01;            // 禁止施密特触发功能 
ADC_TDRH = 0x01;
ADC_CR1 = 0x03; //2分频,连续转换,启动ADC
ADC_CR2 = 0x31; //外部事件保留,数据右对齐,禁止扫描模式,
ADC_CSR|= 0x01; //选择通道1
#endif
 ADC1_ConversionConfig(ADC1_CONVERSIONMODE_CONTINUOUS, ADC_Channel,ADC1_ALIGN_RIGHT);
     ADC_CR1 |= 0x01;      //开始启动转换
     while(!(ADC_CSR & 0x80));   //等待转换结束
    return ADC1_GetConversionValue(); //返回ADC结果
}
//这个初始化代码很重要,不能省,每次切换通道都要初始化一次!
在main函数中直接调用即可:
  TempADC=Get_ADCCH_Value(ADC1_CHANNEL_1); //获取AD转化值
  WetADC=Get_ADCCH_Value(ADC1_CHANNEL_3; //获取AD转化值
Bettermi99
推荐于2016-11-11 · TA获得超过3.8万个赞
知道小有建树答主
回答量:5742
采纳率:92%
帮助的人:227万
展开全部
  过置位ADC_CR1寄存器的 ADON位来开启ADC。当首次置位ADON位时,ADC从低功耗模式唤醒。为了启动转换必须第二次使用写指令来置ADC_CR1寄存器的ADON 位。在转换结束时ADC会保持在上电状态,用户只需要置位ADON位一次来启动下一次的转换。
  如果长时间没有使用ADC,推荐将ADC模块切换到低功耗模式来降低功耗,这可以通过清零 ADON 位来实现。ADC模块上电后,所选通道对应的I/O口输出模块是被禁用的。因此推荐在ADC上电之前要选择合适的ADC转换通道。
  如果单次模式在单次转换模式中,ADC仅在由ADC_CSR寄存器的CH[3:0]选定的通道上完成一次转换。该模式是在当CONT位为0时通过置位ADC_CR1寄存器的ADON位来启动的。
  一旦转换完成,转换后的数据存储在ADC_DR寄存器中,EOC(转换结束)标志被置EOCIE 被置位将产生一个中断。
  代码如下:
  #include "adc.h"
  u16 TempADC;
  void ADC_Config(void)
  {
  ADC_CR1 |= 0x01; //开始启动初始化必须启动一次
  //第一次写1,ADC从低功耗唤醒,第二次写1,启动ADC转换
  //ADC_CR1 |= 0x20; //使能转换结束中断,本例中采用的查询方式。
  }
  
  uint16_t Get_ADCCH_Value(ADC1_Channel_TypeDef ADC_Channel)
  {
  ADC1_Init(ADC1_CONVERSIONMODE_CONTINUOUS,ADC_Channel, ADC1_PRESSEL_FCPU_D2,
  ADC1_EXTTRIG_TIM, DISABLE, ADC1_ALIGN_RIGHT, ADC1_SCHMITTTRIG_ALL, DISABLE);
  //你也可以用操作寄存器的方式代码如下,但未验证。
  #if 0
  ADC_CR2 = 0x00; // A/D结果数据左对齐
  CLK_PCKENR2 |= 0x08; // 使能fMASTER与ADC的连接
  ADC_CR1 = 0x00;// ADC时钟=主时钟/2=8MHz,单次转换模式
  ADC_CSR = 0x01; // 选择通道2
  ADC_TDRL = 0x01; // 禁止施密特触发功能
  ADC_TDRH = 0x01;
  ADC_CR1 = 0x03; //2分频,连续转换,启动ADC
  ADC_CR2 = 0x31; //外部事件保留,数据右对齐,禁止扫描模式,
  ADC_CSR|= 0x01; //选择通道1
  #endif
  ADC1_ConversionConfig(ADC1_CONVERSIONMODE_CONTINUOUS, ADC_Channel,ADC1_ALIGN_RIGHT);
  ADC_CR1 |= 0x01; //开始启动转换
  while(!(ADC_CSR & 0x80)); //等待转换结束
  return ADC1_GetConversionValue(); //返回ADC结果
  }
  //这个初始化代码很重要,不能省,每次切换通道都要初始化一次!
  在main函数中直接调用即可:
  TempADC=Get_ADCCH_Value(ADC1_CHANNEL_1); //获取AD转化值
  WetADC=Get_ADCCH_Value(ADC1_CHANNEL_3; //获取AD转化值
  
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式