你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

蓝桥杯旧嵌入式板STM32F103RBT6驱动练习笔记

[复制链接]
STMCU小助手 发布时间:2021-8-10 13:58
LED
注意GPIO口的初始化 C口对应8——15Pin


锁存器:GPIOD_Pin_2


初始化函数后应使用LED_Control(0xff,0)配置led


LCD和LED冲突解决方案
  1. <font face="微软雅黑" size="3">void LCD _WriteReg(u8 LCD_ Reg, u16 LCD_ RegValue);
  2. void LCD_ WriteRAM_ Prepare(void);
  3. void LCD_ _WriteRAM(u16 RGB_ Code);</font>
复制代码
在以上函数 开头添加: u16 pcout = GPIOC->ODR;
结尾添加: GPIOC->ODR = pcout;


如果要用LED_Contronl()进行多次位移操作需要四次初始化
4*8 = 32位寄存器


记得改写lcd.c
u16 pcout = GPIOC->ODR;


GPIOC->GPIOC = pcout;


LED_Control()
当led_status!=0时 置位 R S R GPIO:C D D Pin led_ctrl<<8 2 2


led_status==0时 置位 S S R GPIO:C D D Pin led_ctrl<<8 2 2


led.h
对led.c的初始化函数和调用函数进行声明


Key
初始化两个GPIO A B


GPIOA对应Pin 0 8


GPIOB对应Pin 1 2



三行代码消抖法
  1. <font face="微软雅黑" size="3">void Key_Read()
  2. {
  3.     unsigned char ReadData = (KEYPORT)^0xff;
  4.     Trg=ReadData & (ReadData ^ Cont);
  5.     Cont=ReadData;
  6. }

  7. Trg 0x01 0x02 0x04 0x08对应RBT6平台的1——4独立按键
  8. </font>
复制代码


key.h
#define KB1 GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_0)


#define KB2 GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_8)


#define KB3 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_1)


#define KB4 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_2)


#define KEYPORT KB1|(KB2<<1)|(KB3<<2)|(KB4<<3)|0xf0


编写范围变化的函数应该注意范围变动的逻辑可行性例如最高电压和最低电压 最高液面和最低液面


读值函数


GPIO_ReadInputDataBit()


TIM4
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4,ENABLE); //使能时钟


NVIC第一句配置需要注意改为TIM4


中断函数里注意使用静态变量
  1. <font face="微软雅黑" size="3">void TIM4_Init(void)
  2. {
  3.         TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
  4.        
  5.         NVIC_InitTypeDef NVIC_InitStructure;
  6.        
  7.         NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;
  8.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority  = 0;
  9.         NVIC_InitStructure.NVIC_IRQChannelSubPriority  = 1;
  10.         NVIC_InitStructure.NVIC_IRQChannelCmd  = ENABLE;
  11.        
  12.         NVIC_Init(&NVIC_InitStructure);
  13.        
  14.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4,ENABLE);       
  15.        
  16.         TIM_TimeBaseStructure.TIM_Period = 1000-1;
  17.         TIM_TimeBaseStructure.TIM_Prescaler = 71;
  18.         TIM_TimeBaseStructure.TIM_ClockDivision = 0 ;
  19.         TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  20.        
  21.         TIM_TimeBaseInit(TIM4,&TIM_TimeBaseStructure);
  22.        
  23.         TIM_ITConfig(TIM4,TIM_IT_Update,ENABLE);
  24.        
  25.         TIM_Cmd(TIM4,ENABLE);
  26. }
  27. </font>
复制代码
timer.h默认


ADC
ADC GPIO结构体初始化 RCC时钟使能 APB2 ADC1 APB2 GPIOB ENABLE


初始化通道8 ADC_Channel8_Init()


对应的GPIO口 GPIOB


对应的Pin口 Pin_0


adc_value=ADC_GetConversionValue (ADC1)读值函数
  1. <font face="微软雅黑" size="3">void ADC_Channel8_Init()
  2. {
  3.         ADC_InitTypeDef ADC_InitStructure;
  4.         GPIO_InitTypeDef GPIO_InitStructure;
  5.        
  6.          RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOC, ENABLE);
  7.        
  8.           GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  9.           GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  10.           GPIO_Init(GPIOB, &GPIO_InitStructure);
  11.        
  12.           ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
  13.           ADC_InitStructure.ADC_ScanConvMode = ENABLE;
  14.           ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
  15.           ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
  16.           ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
  17.           ADC_InitStructure.ADC_NbrOfChannel = 1;
  18.           ADC_Init(ADC1, &ADC_InitStructure);
  19.        
  20.                   /* ADC1 regular channel14 configuration */
  21.           ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);

  22.           /* Enable ADC1 DMA */
  23.           ADC_DMACmd(ADC1, ENABLE);
  24.           
  25.           /* Enable ADC1 */
  26.           ADC_Cmd(ADC1, ENABLE);

  27.           /* Enable ADC1 reset calibration register */   
  28.           ADC_ResetCalibration(ADC1);
  29.           /* Check the end of ADC1 reset calibration register */
  30.           while(ADC_GetResetCalibrationStatus(ADC1));

  31.           /* Start ADC1 calibration */
  32.           ADC_StartCalibration(ADC1);
  33.           /* Check the end of ADC1 calibration */
  34.           while(ADC_GetCalibrationStatus(ADC1));
  35.                  
  36.           /* Start ADC1 Software Conversion */
  37.           ADC_SoftwareStartConvCmd(ADC1, ENABLE);
  38. }
  39. </font>
复制代码
adc.h默认


i2c
编写 写入和读取函数
  1. <font face="微软雅黑" size="3">//需要自己写的程序,读写AT24C02
  2. void Write_AT24c02(unsigned char add,unsigned char data1)
  3. {
  4.         I2CStart();
  5.         I2CSendByte(0xa0);
  6.         I2CWaitAck();
  7.         I2CSendByte(add);
  8.         I2CWaitAck();
  9.         I2CSendByte(data1);
  10.         I2CWaitAck();
  11.         I2CStop();
  12. }

  13. unsigned char Read_AT24c02(unsigned char add)
  14. {
  15.         unsigned char temp;
  16.         I2CStart();
  17.         I2CSendByte(0xa0);
  18.         I2CWaitAck();
  19.         I2CSendByte(add);
  20.         I2CWaitAck();
  21.         I2CStart();
  22.         I2CSendByte(0xa1);
  23.         I2CWaitAck();
  24.         temp=I2CReceiveByte();
  25.         I2CWaitAck();
  26.         I2CStop();
  27.         return temp;
  28. }
  29. </font>
复制代码
读值函数(I2CReceiveByte())


注意在i2c.h中声明新编写的函数
写入函数
  1. <font face="微软雅黑" size="3">Write_AT24c02(0x00,lcd_number /256);
  2. Delay_Ms(5);
  3. Write_AT24c02(0x01,lcd_number %256);
  4. Delay_Ms(5);</font>
复制代码
读取函数


lcd_record = Read_AT24c02 (0x00)*256 +Read_AT24c02 (0x01);


RTC
调整函数Time_Adjust()
RTC显示可以通过对THH,TMM,TSS赋值使得显示的初始值为期望值


如果出现59—>01的情况 则需要将rtc.c中的Time_Display(u32int TimeVar)中的


if(RTC_GetCounter()==0x0001517f)改为if(RTC_GetCounter()==0x00015180)


NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;


rtc.h中添加“stdio.h”方便.c文件中函数调用


中断函数结尾需要加上
RTC_WaitForLastTask();


当出现59->01时可能是因为晶振温度变化 可以改7f->80
LCD显示
调整颜色
  1. <font face="微软雅黑" size="3">LCD_Clear(Blue);//清屏颜色
  2. LCD_SetBackColor(Blue);//背景颜色
  3. LCD_SetTextColor(White);//文本颜色</font>
复制代码
个别字体颜色调节 从左到右为320个像素点(319——0)每十六个像素点为一个字符
  1. <font face="微软雅黑" size="3">LCD_SetTextColor(Red);
  2. LCD_DisplayChar(Line5,319-8*16,RTC_THH/10+'0');
  3. LCD_DisplayChar(Line5,319-9*16,RTC_THH%10+'0');
  4. LCD_SetTextColor(White);
  5. </font>
复制代码
uart配置
void STM_EVAL_COMInit( USART_InitTypeDef* USART_InitStruct);


void USART2_Init(void);


需要注意函数STM_EVAL_COMInit( & USART_InitStructure);的位置


一定放在USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);的前面


int fputc(int ch,FILE *f)//需要包含stdio.h头文件


中断函数需要添加USART_ClearITPendingBit(USART2, USART_IT_RXNE);
  1. <font face="微软雅黑" size="3">void STM_EVAL_COMInit(USART_InitTypeDef* USART_InitStruct)
  2. {
  3.        
  4.   GPIO_InitTypeDef GPIO_InitStructure;

  5.   /* Enable GPIO clock */
  6.   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);

  7.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);

  8.   /* Configure USART Tx as alternate function push-pull */
  9. //  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  10. //  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  11. //  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  12. //  GPIO_Init(GPIOA, &GPIO_InitStructure);

  13.   /* Configure USART Rx as input floating */
  14.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  15.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2 | GPIO_Pin_3;
  16.   GPIO_Init(GPIOA, &GPIO_InitStructure);

  17.   /* USART configuration */
  18.   USART_Init(USART2, USART_InitStruct);
  19.    
  20.   /* Enable USART */
  21.   USART_Cmd(USART2, ENABLE);
  22. }

  23. void USART2_Init(void)
  24. {
  25.         USART_InitTypeDef USART_InitStructure;
  26.         NVIC_InitTypeDef NVIC_InitStructure;
  27.           /* USARTx configured as follow:
  28.         - BaudRate = 115200 baud  
  29.         - Word Length = 8 Bits
  30.         - One Stop Bit
  31.         - No parity
  32.         - Hardware flow control disabled (RTS and CTS signals)
  33.         - Receive and transmit enabled
  34.         */
  35.         USART_InitStructure.USART_BaudRate = 9600;
  36.         USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  37.         USART_InitStructure.USART_StopBits = USART_StopBits_1;
  38.         USART_InitStructure.USART_Parity = USART_Parity_No;
  39.         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  40.         USART_InitStructure.USART_Mode =  USART_Mode_Tx | USART_Mode_Rx;
  41.         STM_EVAL_COMInit(&USART_InitStructure);
  42.        
  43.         /* Enable the USARTz Interrupt */
  44.         NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
  45.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  46.         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  47.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  48.         NVIC_Init(&NVIC_InitStructure);
  49.        
  50.         /* Enable the USARTz Receive Interrupt */
  51.         USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
  52. }

  53. void SendString(char *s)
  54. {
  55.         while(*s)
  56.         {
  57.                 USART_SendData(USART2,*s++);
  58.                 /* Loop until the end of transmission */
  59.                 while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET)//USART_FLAG_TC 表示传输完毕;USART_FLAG_TXE表示发送缓冲区空
  60.                 {}
  61.         }
  62. }

  63. /**
  64.   * @brief  Retargets the C library printf function to the USART.
  65.   * @param  None
  66.   * @retval None
  67.   */
  68. int fputc(int ch, FILE *f)
  69. {
  70.   /* Place your implementation of fputc here */
  71.   /* e.g. write a character to the USART */
  72.   USART_SendData(USART2, (uint8_t) ch);

  73.   /* Loop until the end of transmission */
  74.   while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET)
  75.   {}

  76.   return ch;
  77. }

  78. u8 rx_buf[15];
  79. u8 rx_count=0;
  80. u8 rx_ideltime=0;
  81. _Bool rx_flag=0;
  82. void USART2_IRQHandler(void)
  83. {
  84.         if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)
  85.         {
  86.                 USART_ClearITPendingBit(USART2,USART_IT_RXNE);
  87.                 rx_buf[rx_count]=USART_ReceiveData(USART2);
  88.                 if(rx_buf[rx_count]=='\n')
  89.                 {
  90.                         rx_flag=1;
  91.                         rx_count=0;
  92.                 }
  93.                         rx_count++;
  94.                         rx_ideltime=0;
  95.         }
  96. }
  97. </font>
复制代码
pwm
时钟频率(system clk) / 预分频(psc) /想要的pwm频率 = arr(重装值)


通过输出比较模式进行占空比调节
  1. <font face="微软雅黑" size="3">__IO uint16_t TIM2_CCR2_Val = 8192;
  2. __IO uint16_t TIM2_CCR3_Val = 4096;

  3. void TIM2_PWM_OCToggle(void)
  4. {
  5.   NVIC_InitTypeDef NVIC_InitStructure;
  6.   TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
  7.   TIM_OCInitTypeDef  TIM_OCInitStructure;
  8.   GPIO_InitTypeDef GPIO_InitStructure;
  9.   uint16_t PrescalerValue = 0;

  10.   /* System Clocks Configuration */
  11.   /* TIM2 clock enable */
  12.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);

  13.   /* GPIOA clock enable */
  14.   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB|
  15.                          RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO, ENABLE);

  16.   /* NVIC Configuration */
  17.   /* Enable the TIM2 global Interrupt */
  18.   NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
  19.   NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  20.   NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  21.   NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  22.   NVIC_Init(&NVIC_InitStructure);

  23.   /* GPIO Configuration */
  24.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_2;
  25.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  26.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  27.   GPIO_Init(GPIOA, &GPIO_InitStructure);
  28.   /* ---------------------------------------------------------------------------
  29.     TIM2 Configuration: Output Compare Toggle Mode:
  30.     TIM2CLK = SystemCoreClock / 2,
  31.     The objective is to get TIM2 counter clock at 12 MHz:
  32.      - Prescaler = (TIM2CLK / TIM2 counter clock) - 1
  33.     CC1 update rate = TIM2 counter clock / CCR1_Val = 366.2 Hz
  34.     CC2 update rate = TIM2 counter clock / CCR2_Val = 732.4 Hz
  35.     CC3 update rate = TIM2 counter clock / CCR3_Val = 1464.8 Hz
  36.     CC4 update rate = TIM2 counter clock / CCR4_Val = 2929.6 Hz
  37.   ----------------------------------------------------------------------------*/
  38.   /* Compute the prescaler value */
  39.   PrescalerValue = (uint16_t) (SystemCoreClock / 24000000) - 1;

  40.   /* Time base configuration */
  41.   TIM_TimeBaseStructure.TIM_Period = 65535;
  42.   TIM_TimeBaseStructure.TIM_Prescaler = PrescalerValue;
  43.   TIM_TimeBaseStructure.TIM_ClockDivision = 0;
  44.   TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;

  45.   TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);

  46.   /* Output Compare Toggle Mode configuration: Channel2 */
  47.   TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_Toggle;
  48.   TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  49.   TIM_OCInitStructure.TIM_Pulse = TIM2_CCR2_Val;
  50.   TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  51.   TIM_OC2Init(TIM2, &TIM_OCInitStructure);

  52.   TIM_OC2PreloadConfig(TIM2, TIM_OCPreload_Disable);

  53.   /* Output Compare Toggle Mode configuration: Channel3 */
  54.   TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  55.   TIM_OCInitStructure.TIM_Pulse = TIM2_CCR3_Val;

  56.   TIM_OC3Init(TIM2, &TIM_OCInitStructure);

  57.   TIM_OC3PreloadConfig(TIM2, TIM_OCPreload_Disable);

  58.   /* TIM enable counter */
  59.   TIM_Cmd(TIM2, ENABLE);
  60.   
  61.   /* TIM IT enable */
  62.   TIM_ITConfig(TIM2, TIM_IT_CC2 | TIM_IT_CC3 , ENABLE);
  63. }

  64. uint16_t TIM2_capture = 0;
  65. _Bool TIM2_CH2_flag=0, TIM2_CH3_flag=0;
  66. float TIM2_CH2_duty=0.3, TIM2_CH3_duty=0.7;
  67. void TIM2_IRQHandler(void)
  68. {
  69.         /* TIM2_CH2 toggling with frequency = 732.4 Hz */
  70.         if (TIM_GetITStatus(TIM2, TIM_IT_CC2) != RESET)
  71.         {
  72.                 TIM_ClearITPendingBit(TIM2, TIM_IT_CC2 );
  73.                 TIM2_capture = TIM_GetCapture2(TIM2);
  74.                 if(TIM2_CH2_flag==1)
  75.                 {
  76.                         TIM_SetCompare2(TIM2, TIM2_capture + (u16)(TIM2_CCR2_Val*TIM2_CH2_duty));
  77.                         TIM2_CH2_flag=0;
  78.                 }
  79.                 else
  80.                 {
  81.                         TIM_SetCompare2(TIM2, TIM2_capture + (u16)(TIM2_CCR2_Val*(1-TIM2_CH2_duty)));
  82.                         TIM2_CH2_flag=1;
  83.                 }
  84.         }

  85.   /* TIM2_CH3 toggling with frequency = 1464.8 Hz */
  86.   if (TIM_GetITStatus(TIM2, TIM_IT_CC3) != RESET)
  87.   {
  88.     TIM_ClearITPendingBit(TIM2, TIM_IT_CC3);
  89.     TIM2_capture = TIM_GetCapture3(TIM2);
  90.         if(TIM2_CH3_flag==1)
  91.         {
  92.                 TIM_SetCompare3(TIM2, TIM2_capture + (u16)(TIM2_CCR3_Val*TIM2_CH3_duty));
  93.                 TIM2_CH3_flag=0;
  94.         }
  95.         else
  96.         {
  97.                 TIM_SetCompare3(TIM2, TIM2_capture + (u16)(TIM2_CCR3_Val*(1-TIM2_CH3_duty)));
  98.                 TIM2_CH3_flag=1;
  99.         }
  100.   }
  101. }
  102. </font>
复制代码
烧录下载之后出现白屏现象
检查microusb的选项是否勾选

收藏 评论0 发布时间:2021-8-10 13:58

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版