本帖最后由 起个昵称都难 于 2022-10-30 19:50 编辑
根据CSDN上大佬写的,实现原理是改变PSC的值改变PWM的频率从而实现音调的变化,下面是详细代码,问题:蜂鸣器为什么不响
这是定时器4的初始化
void TIM4_PWM_Init(u16 arr,u16 psc)
{
RCC->APB1ENR|=1<<2;//定时器4使能
RCC->APB2ENR|=1<<3;//GPIOB使能
GPIOB->CRH&=0xfffffff0;
GPIOB->CRH|=0x0000000B;//PB8为蜂鸣器接口也是定时器4的3通道接口,此处设为复用输出
RCC->APB2ENR |=1<<0;
AFIO ->MAPR&=0xfffff7ff;//不重映射
TIM4->ARR=arr;
TIM4->PSC=psc;
TIM4->CCMR2|=7<<4;//CH3 PWM模式
TIM4->CCMR2|=1<<3;//CH3 预装载使能
TIM4->CCER|=1<<8;//OC3输出使能
TIM4->CR1=0x0080;
TIM4->CR1|=0x01;//使能定时器4
TIM4->CCR3=500;
}
这个函数就是改变PWM的频率来改变音调的,延时函数为控制节拍
void Solitary_brave(void)
{
int i=0;
int solitary_brave[]=
{
M6,50,M7,50,H1,50,H2,50,M7,50,H1,50,H1,100,Z0,10,
H1,50,M7,50,H1,50,H2,50,M7,50,H1,50,H1,100,Z0,10,
H1,50,H2,50,H3,50,H2,50,H3,50,H2,50,H3,100,H3,50,H3,50,H2,50,H3,100,H5,100,H3,100,Z0,10
};
int length = sizeof(solitary_brave)/sizeof(solitary_brave[0]);
for(i=0;i<(length/2);i++)
{
TIM4_PWM_Init(999,solitary_brave[i*2]);
delay_ms(solitary_brave[i*2+1]*5);
}
if (i==length/2) TIM4->CCR3 =0;
}
下面是主函数的调用
int main(void)
{
Stm32_Clock_Init(9); //系统时钟设置
delay_init(72); //延时初始化
LED_Init(); //初始化与LED连接的硬件接口
BEEP_Init();
KEY_Init();
//u16 led6pwmval=0;
//u16 led7pwmval=300;
//u8 dir=1;
TIM4_PWM_Init(999,0);
Solitary_brave();
|