数码管按键切换扫描代码 (s1、s2按键计数,s3切换扫描速度)
默默地表示C语言学的真的很烂。
/** ****************************************************************************** * @file GPIO/IOToggle/main.c * @author MCD Application Team * @version V3.5.0 * @date 08-April-2011 * @brief Main program body. ****************************************************************************** * @attention * * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. * * ? COPYRIGHT 2011 STMicroelectronics ****************************************************************************** */ /* Includes ------------------------------------------------------------------*/ #include "stm32f10x.h" #include "stm32_eval.h" uint16_t Dis_tab[]={GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14|GPIO_Pin_13|GPIO_Pin_8,//0 GPIO_Pin_9|GPIO_Pin_12,//1 GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_14|GPIO_Pin_13|GPIO_Pin_5,//2 GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14|GPIO_Pin_5,//3 GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_8|GPIO_Pin_5,//4 GPIO_Pin_7|GPIO_Pin_12|GPIO_Pin_14|GPIO_Pin_8|GPIO_Pin_5,//5 GPIO_Pin_7|GPIO_Pin_12|GPIO_Pin_14|GPIO_Pin_13|GPIO_Pin_8|GPIO_Pin_5,//6 GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12,//7 GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14,//8 GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14//9 }; GPIO_InitTypeDef GPIO_InitStructure; void RCC_Configuration(void) { RCC_DeInit(); RCC_HSICmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET); RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI); RCC_HSEConfig(RCC_HSE_OFF); RCC_LSEConfig(RCC_LSE_OFF); RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); // 72HMz RCC_PLLCmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); RCC_ADCCLKConfig(RCC_PCLK2_Div4); RCC_PCLK2Config(RCC_HCLK_Div1); RCC_PCLK1Config(RCC_HCLK_Div2); RCC_HCLKConfig(RCC_SYSCLK_Div1); RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); while(RCC_GetSYSCLKSource() != 0x08); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE); GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOD, &GPIO_InitStructure); GPIO_ResetBits(GPIOD,GPIO_Pin_2); } void GPIO_INIT() { //GPIOB(数码管)初始化 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOB, &GPIO_InitStructure); //按键初始化 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOC, &GPIO_InitStructure); } //微秒延时 void delay_us(u32 n) { u8 j; while(n--) for(j=0;j<10;j++); } //毫秒延时 void delay_ms(u32 n) { while(n--) delay_us(1000); } /** * @brief Main program. * @param None * @retval None */ int main(void) { int i,j; RCC_Configuration(); GPIO_INIT(); GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);//关闭数码管 while(1){ if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_10))//S3键按下 {delay_ms(80); if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_10)){j++;}}//延时后S3处于按下状态,j++ if(j%2==0){ //如果i是偶数 if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_9))//S2键按下 {delay_ms(80); if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_9)){i++;} }}//延时后S2处于按下状态,j++ else{//如果i是奇数 if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))//S1键按下 {delay_ms(80); if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8)){i++;}} }//延时后S1处于按下状态,j++ if(i>30){i=0;} GPIO_ResetBits(GPIOB,GPIO_Pin_1); GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14); switch(i){ case 0 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 1 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 2 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 3 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 4 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 5 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 6 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 7 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 8 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 9 : GPIO_SetBits(GPIOB,GPIO_Pin_1); GPIO_ResetBits(GPIOB,Dis_tab[i%10]); break; case 10 : GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 11 : GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 12 : GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 13: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 14: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 15: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 16: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 17: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 18: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 19: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12); delay_ms(10); break; case 20: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 21: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 22: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 23: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 24: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 25: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 26: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 27: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 28: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 29: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; case 30: GPIO_ResetBits(GPIOB,GPIO_Pin_15);//PB15 off GPIO_SetBits(GPIOB,GPIO_Pin_1);//PB1 on GPIO_ResetBits(GPIOB,Dis_tab[i%10]); delay_ms(10); GPIO_SetBits(GPIOB,Dis_tab[i%10]); //off GPIO_ResetBits(GPIOB,GPIO_Pin_1);//PB1 off GPIO_SetBits(GPIOB,GPIO_Pin_15);//PB15 on delay_ms(10); GPIO_ResetBits(GPIOB,Dis_tab[i/10]); delay_ms(10); break; } } }
串口发送信息控制LED闪烁速度作业
从买回jlink学习调试。遇到了各种很多问题。这两天才开始写代码。代码的写入也是曲折重重。不过总算是写好了。总算是对C语言有那么一丁点感觉了。代码写的比较丑。望大神们指导改良。写的过程中我想实现在输入指令后使我的了LED 灯一直循环亮着的,等下一次输入的时候再关闭,然后开始新延迟时间循环点亮LED灯。但是结果是一直在循环。只有Rese后才能够重新输入新的LED 灯延迟时间。
然后我就放弃了这一想法。现在我的循环是数据输入一次就可以按输入的延迟时间,点亮LED灯。依次亮一次后需要下一次的输入才能够再次亮起来。
我的代码如下:
#include "stm32f10x.h" #include "stm32_eval.h" #include "stdio.h" #include "math.h" #define buff_size 16; /** * @brief Main program. * @param None * @retval None */ char rx_buff[], rx_buff_count=0; GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; USART_ClockInitTypeDef USART_ClockInitStructure; void RCC_Configuration(void) { RCC_DeInit(); RCC_HSICmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET); RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI); RCC_HSEConfig(RCC_HSE_OFF); RCC_LSEConfig(RCC_LSE_OFF); RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); // 72HMz RCC_PLLCmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); RCC_ADCCLKConfig(RCC_PCLK2_Div4); RCC_PCLK2Config(RCC_HCLK_Div1); RCC_PCLK1Config(RCC_HCLK_Div2); RCC_HCLKConfig(RCC_SYSCLK_Div1); RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); while(RCC_GetSYSCLKSource() != 0x08); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE); GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOD, &GPIO_InitStructure); GPIO_ResetBits(GPIOD,GPIO_Pin_2);//关闭蜂鸣器 } void GPIO_INIT() { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);//使能PC时钟 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;//PC0-PC7 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//推挽输出 GPIO_Init(GPIOC, &GPIO_InitStructure);//初始化PC } void USART_int(long BaudRate) { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);//使能PA USART1 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;//TX位于PA9 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //推挽输出 GPIO_Init(GPIOA, &GPIO_InitStructure);//TX初始化 PA9 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;//RX位于PA10 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//悬空输入 GPIO_Init(GPIOA, &GPIO_InitStructure);//RX初始化 PA10 /* USARTx configured as follow: - BaudRate = 115200 baud - Word Length = 8 Bits - One Stop Bit - No parity - Hardware flow control disabled (RTS and CTS signals) - Receive and transmit enabled */ USART_InitStructure.USART_BaudRate = BaudRate;//传输速率 USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长8比特 USART_InitStructure.USART_StopBits = USART_StopBits_1;//停止位1 USART_InitStructure.USART_Parity = USART_Parity_No;// USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//流控位none USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//接收和发送模式 USART_ClockInitStructure.USART_Clock = USART_Clock_Disable; USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low; USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge; USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable; USART_ClockInit(USART1, &USART_ClockInitStructure);//初始化USART1时钟 USART_Init(USART1, &USART_InitStructure);//初始化USART1 USART_Cmd(USART1, ENABLE); USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); USART_Cmd(USART1, ENABLE); /* Configure four bit for preemption priority */ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);//优先级 /* Enable the USART1 Interrupt */ NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //选择USART1中断通道 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 15; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure);//初始化中断 } /*delay_us*/ void delay_us(u32 n) { u8 j; while(n--) for(j=0;j<10;j++); } /*delay_ms*/ void delay_ms(u32 n) { while(n--) delay_us(1000); } void USART_SendStr(char *str)//发送字符串 { while((*str)!='\0')//到字符串的末尾才停止发送数据 { USART_SendData(USART1,*str++); while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); } } unsigned int translate(char *S,char j)//将字符串组成的数字转换成整型数据 { unsigned int a[4],sum=0; char i; for(i=0;i<j;i++) { a[i]=S[5+j-1-i]-48;//将字符转成整型数据 sum+=a[i]*pow(10,i);//按照每一位的权值相乘再相加,还原data=n的本来面貌 } return sum;//sum保存目标整型数据 } void func(char *S,char LEN) { char count;// unsigned int sum,i,j; if((LEN!=6)&(LEN!=7)&(LEN!=8)&(LEN!=9))//data=1~999 {USART_SendStr("\r\n Erro input!!!\r\n");}//如果输入格式错误,发送提示 else { count=LEN-5;//从“=”后面开始是目标数据 sum = translate(S,count);//count记录“=”后有多少位,传递到translate中 GPIO_SetBits(GPIOC,0x000000ff);//all LED off GPIO_SetBits(GPIOA,GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3);//RGB熄灭 { GPIO_SetBits(GPIOC,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);//LED全部熄灭 delay_ms(sum); GPIO_ResetBits(GPIOC,GPIO_Pin_3);//点亮D4 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_3);//熄灭D4 GPIO_ResetBits(GPIOC,GPIO_Pin_2);//点亮D3 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_2);//熄灭D3 GPIO_ResetBits(GPIOC,GPIO_Pin_1);//点亮D2 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_1);//熄灭D2 GPIO_ResetBits(GPIOC,GPIO_Pin_0);//点亮D1 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_0);//熄灭D1 GPIO_ResetBits(GPIOC,GPIO_Pin_4);//点亮D5 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_4);//熄灭D5 GPIO_ResetBits(GPIOC,GPIO_Pin_5);//点亮D6 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_5);//熄灭D6 GPIO_ResetBits(GPIOC,GPIO_Pin_6);//点亮D7 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_6);//熄灭D7 GPIO_ResetBits(GPIOC,GPIO_Pin_7);//点亮D8 delay_ms(sum); GPIO_SetBits(GPIOC,GPIO_Pin_7);//熄灭D8 } } } void input_ASK() { char j; func(rx_buff,rx_buff_count); rx_buff_count=0; for (j=0;j<rx_buff_count;j++) {rx_buff[j]='\0';}//判断读入信息是否结束,如果结束则准备下一次读入 USART_SendStr("\n>"); } int main(void) { RCC_Configuration(); GPIO_INIT(); USART_int(9600); GPIO_ResetBits(GPIOC,0x000000ff);//led全亮,提示程序开始 delay_ms(200); GPIO_SetBits(GPIOC,0x000000ff);//led全灭 USART_SendStr("SyStem booting......\r\n");// USART_SendStr("\n>");// while(1) {} } void USART1_IRQHandler(void) { while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET) { } if(USART_ReceiveData(USART1)==0x0d)//如果输入完毕,按下了回车 {input_ASK();} else { USART_SendData(USART1,USART_ReceiveData(USART1)); rx_buff[rx_buff_count]= USART_ReceiveData(USART1); rx_buff_count++; } USART_ClearFlag(USART1, USART_FLAG_RXNE); }
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |