STM32 软件触发 DAC

/*    DAC.c
    用于DAC的初始化和配置
*/

#include "includes.h"
                       
void DAC_Config(void); 
void DAC_Task(void* prg);

void DAC_Task(void* prg)
{
    DAC_SetChannel1Data(DAC_Align_12b_R,1028);    //设置数据右对齐,转换值设置为1028
    DAC_SoftwareTriggerCmd(DAC_Channel_1,ENABLE);    //软件触发通道1 开始转换

    DAC_SetChannel2Data(DAC_Align_12b_R,2047);    //设置数据右对齐,转换值设置为2047
    DAC_SoftwareTriggerCmd(DAC_Channel_2,ENABLE);    //软件触发通道2 开始转换

//    while(1)
//    {
        OSTimeDlyHMSM(0,0,1,0);
//    }
}

void DAC_Config(void)
{
    DAC_InitTypeDef DAC_InitStructure;                  //DAC库函数结构体
    GPIO_InitTypeDef GPIO_InitStructure;            //GPIO结构体

    RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC , ENABLE);   //DAC 时钟使能
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA , ENABLE);   //GPIO 时钟使能

    //将GPIO配置为DAC的模拟复用功能
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4|GPIO_Pin_5;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
    GPIO_Init(GPIOA,&GPIO_InitStructure);  //A4为通道1 A5为通道2

    //DAC通道1、通道2配置
    DAC_InitStructure.DAC_Trigger = DAC_Trigger_Software;       //设置触发方式为软件触发
    DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None;     //无波形产生
    DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Enable;    //DAC输出缓冲使能
    DAC_Init(DAC_Channel_1 ,&DAC_InitStructure); //使能以上设置到DAC1                
    DAC_Init(DAC_Channel_2 ,&DAC_InitStructure); //使能以上设置到DAC2

    DAC_Cmd(DAC_Channel_1 ,ENABLE);      //最后的开关
    DAC_Cmd(DAC_Channel_2 ,ENABLE);    //最后的开关

    DAC_Task(0);
                  
}
/*    DAC.h
    用于定义和扩展DAC.c中的函数
*/

#ifndef __DAC_H__
#define __DAC_H__    

void DAC_Config(void); 
void DAC_Task(void* prg);

#endif

转载于:https://my.oschina.net/mummy108/blog/113169

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先需要初始化定时器和DAC模块,然后在定时器的中断函数中将DAC输出值更新为预设值。 下面是一个基本的示例代码: ```c #include "stm32f10x.h" void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { // 更新DAC输出值为预设值 DAC_SetChannel1Data(DAC_Align_12b_R, 2048); TIM_ClearITPendingBit(TIM2, TIM_IT_Update); } } int main(void) { // 初始化定时器 RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct; TIM_TimeBaseInitStruct.TIM_Period = 35999; TIM_TimeBaseInitStruct.TIM_Prescaler = 0; TIM_TimeBaseInitStruct.TIM_ClockDivision = 0; TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseInitStruct); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); NVIC_InitTypeDef NVIC_InitStruct; NVIC_InitStruct.NVIC_IRQChannel = TIM2_IRQn; NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0; NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStruct); // 初始化DAC RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE); DAC_InitTypeDef DAC_InitStruct; DAC_InitStruct.DAC_Trigger = DAC_Trigger_T2_TRGO; DAC_InitStruct.DAC_WaveGeneration = DAC_WaveGeneration_None; DAC_InitStruct.DAC_OutputBuffer = DAC_OutputBuffer_Enable; DAC_Init(DAC_Channel_1, &DAC_InitStruct); // 启动定时器 TIM_Cmd(TIM2, ENABLE); while (1) { // do something } } ``` 在本示例中,定时器TIM2的周期设置为36000(即每秒触发一次中断),并且启用了中断功能。在中断处理函数中,更新DAC的输出值为预设值2048,这个值可以根据实际需求进行修改。 同时,在DAC初始化时,将其触发源设置为定时器2的触发输出TRGO,这样每次定时器触发时,DAC会输出相应的电压值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值