数码管按键切换扫描代码 (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);
}
回复
| 有奖活动 | |
|---|---|
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
| 【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
| 送您一块开发板,2025年“我要开发板活动”又开始了! | |
我要赚赏金
