这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 高校专区 » 漓东e学堂 » 【11.15更新】34号 STM 作业

共9条 1/1 1 跳转至

【11.15更新】34号 STM 作业

菜鸟
2015-11-15 22:52:39     打赏

作业一:Keil的安装:http://forum.eepw.com.cn/thread/277263/1#2

作业二:流水灯:http://forum.eepw.com.cn/thread/277590/1#3

作业三:0~99按键计数:http://forum.eepw.com.cn/thread/277771/1#4

作业四:双号uart控制LED流水灯转速:http://forum.eepw.com.cn/thread/277772/1#5

作业五:定时器控制LED灯:http://forum.eepw.com.cn/thread/278218/1#6

作业六:计算机开机次数:http://forum.eepw.com.cn/thread/279078/1#7

作业七:DS18B20温度使灯的颜色变化:http://forum.eepw.com.cn/thread/279079/1#8



菜鸟
2015-11-15 23:00:39     打赏
2楼


【10.26】34号更新作业,迟交的作业,keil 的安装


1.双击应用程序

2.固定的模式安装

3.打开软件破解

这就是整个软件的安装过程咯!


菜鸟
2015-11-15 23:01:31     打赏
3楼

【11.9更新】34 不熟练的流水灯作业

作业二:流水灯


#include "stm32f10x.h"
#include "stm32_eval.h"
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 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)
{ unsigned char flag=0;
RCC_Configuration();
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
 GPIO_Init(GPIOC, &GPIO_InitStructure);
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;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
while(1)
{
GPIO_SetBits(GPIOC,GPIO_Pin_0);
GPIO_SetBits(GPIOC,GPIO_Pin_1);
GPIO_SetBits(GPIOC,GPIO_Pin_2);
GPIO_SetBits(GPIOC,GPIO_Pin_3);
GPIO_SetBits(GPIOC,GPIO_Pin_4);
GPIO_SetBits(GPIOC,GPIO_Pin_5);
GPIO_SetBits(GPIOC,GPIO_Pin_6);
GPIO_SetBits(GPIOC,GPIO_Pin_7);
 
 delay_ms(100);
    GPIO_ResetBits(GPIOC,GPIO_Pin_0);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_0);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_1);
delay_ms(100);
    GPIO_SetBits(GPIOC,GPIO_Pin_1);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_2);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_2);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_3);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_3);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_4);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_4);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_5);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_5);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_6);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_6);
delay_ms(100);
GPIO_ResetBits(GPIOC,GPIO_Pin_7);
delay_ms(100);
GPIO_SetBits(GPIOC,GPIO_Pin_7);
delay_ms(100);
}
}

虽然不怎么懂,但是通过借鉴和参考还是可以完成作业的,我承认我是菜鸟,哎,没办法呀!


菜鸟
2015-11-15 23:11:18     打赏
4楼

作业三:34号 0~99按键计数

  1. #include "stm32f10x.h"    
  2.   
  3. GPIO_InitTypeDef GPIO_InitStructure; // 声明一个结构体  
  4.   
  5. void RCC_Configuration(void);   
  6. void GPIO_INIT(void) ;  
  7. void Function(void) ;  
  8.   
  9. int main(void)     
  10. {      
  11.     RCC_Configuration();     
  12.     GPIO_INIT();  
  13.     Function();     
  14. }      
  15.         
  16. void RCC_Configuration(void)    //复位所有的RCC外围设备寄存器  
  17. {     
  18.         ErrorStatus HSEStartUpStatus;   //  设置错误标志量  
  19.     RCC_DeInit();                       //*将外设寄存器RCC重设为初始值   
  20.     RCC_HSEConfig(RCC_HSE_ON);//*打开外部高速时钟晶振HSE:  
  21.   HSEStartUpStatus = RCC_WaitForHSEStartUp();  //*等待外部高速时钟晶振工作:   
  22.   if(HSEStartUpStatus==SUCCESS)  
  23.     {  
  24.         RCC_HCLKConfig(RCC_SYSCLK_Div1);//*AHB使用系统时钟,负责外部存储器的时钟   
  25.         RCC_PCLK1Config(RCC_HCLK_Div2);//*APB1 负责DA,USB,SPI,I2C,CAN,串口2345,普通TIM  
  26.         RCC_PCLK2Config(RCC_HCLK_Div1);//*APB2负责AD,I/O,高级TIM,串口1   
  27.         RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);//*设置PLL输入时钟源72M  
  28.         RCC_PLLCmd(ENABLE);//*打开PLL:            
  29.         while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);//*等待PLL工作:  
  30.         RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//*设置系统时钟  
  31.         while(RCC_GetSYSCLKSource() != 0x08);//* 判断PLL是否是系统时钟:      
  32.     }  
  33.       
  34.     GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//改变管脚的映射SWJ使能,禁用JTAG,选择用于事件输出的GPIO端口  
  35.       
  36.     /*蜂鸣器*/  
  37.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE); //# 使能被重新映射到GPIOD时钟和使能复用时钟功能  
  38.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;       //#管脚号  关闭蜂鸣器  
  39.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;         //#输出速度   
  40.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;      //#推挽输出    
  41.   GPIO_Init(GPIOD, &GPIO_InitStructure);     //#初始化   
  42.     GPIO_ResetBits(GPIOD,GPIO_Pin_2);  
  43. }   
  44.   
  45. void delay_us(u32 n)        //延时函数     
  46. {     
  47.     u8 j;     
  48.     while(n--)     
  49.             for(j=0;j<10;j++);     
  50. }      
  51. void  delay_ms(u32 n)       //延时函数     
  52. {     
  53.    while(n--)     
  54.    delay_us(1000);     
  55. }  
  56.    
  57. void GPIO_INIT(void)     
  58. {       
  59.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOB, ENABLE);    
  60.       
  61.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11;  
  62.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;   //输出速度     
  63.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;     
  64.         GPIO_Init(GPIOC, &GPIO_InitStructure);  //初始化     
  65.        
  66.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5|GPIO_Pin_1|GPIO_Pin_15|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14;//数码管  
  67.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;       
  68.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  
  69.         GPIO_Init(GPIOB, &GPIO_InitStructure);    
  70. }     
  71.     
  72.   
  73. void Number(int a)  //数码管显示数字  
  74. {  
  75.     switch(a)    
  76.             {    
  77.         case 0 : GPIO_ResetBits(GPIOB,GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
  78.         case 1 : GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12);break;    
  79.         case 2 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_13|GPIO_Pin_14);break;    
  80.         case 3 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14);break;    
  81.         case 4 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12);break;    
  82.         case 5 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_12|GPIO_Pin_14);break;    
  83.         case 6 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
  84.         case 7 : GPIO_ResetBits(GPIOB,GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12);break;    
  85.         case 8 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
  86.         case 9 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14); break;    
  87.             }    
  88. }    
  89.     
  90.      
  91. void Function(void)   
  92. {       
  93.         int i=0,j=0;          //i被按下的次数,n延时变量    
  94.   
  95.         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);       
  96.         delay_ms(50); //关闭数码管      
  97.   
  98.         while(1)    
  99.         {                   
  100.                 GPIO_SetBits(GPIOB,GPIO_Pin_1);         //打开个位数码管    
  101.                 Number(i);                                //用switch函数显示00    
  102.                 delay_ms(t);                              
  103.                 GPIO_ResetBits(GPIOB,GPIO_Pin_1);        //关闭个位         
  104.                 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);    
  105.   
  106.                 GPIO_SetBits(GPIOB,GPIO_Pin_15);           //打开十位    
  107.                 Number(j);      
  108.                 delay_ms(t);    
  109.                 GPIO_ResetBits(GPIOB,GPIO_Pin_15);      //关掉十位数码管       
  110.                 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);    
  111.   
  112.                 if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))   //判断按键是s1否被按下    
  113.                 {       
  114.                     delay_ms(50);            //延时消抖    
  115.                     if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))  //再次判断按键是s1否被按下      
  116.                     {     
  117.                         i++;                     //按键被按下,个位+1    
  118.                         if(i==10)       
  119.                         {    
  120.                             j++;                 
  121.                             i=0;                   
  122.                         }  
  123.                         if(j==10)  
  124.                         {  
  125.                              j=0;  
  126.                                                  i=0;  
  127.                         }  
  128.                     }  
  129.                 }     

虽然是借助大神的,还是勉强完成了!


菜鸟
2015-11-15 23:18:45     打赏
5楼

【11.15更新】34号 双号uart控制LED流水灯转速 【没有办法的办法,你懂的】

作业四:uart控制LED流水灯转速


  1. #include "stm32f10x.h"
  2. #include    "stdio.h"
  3. GPIO_InitTypeDef GPIO_InitStructure; // 声明结构体
  4. NVIC_InitTypeDef  NVIC_InitStructure;
  5. USART_InitTypeDef  USART_InitStructure;
  6. USART_ClockInitTypeDef  USART_ClockInitStructure;
  7. #define buff_size  16;
  8. char rx_buff[],rx_buff_count=0;
  9. void RCC_Configuration(void) ;
  10. void GPIO_INIT(void)  ;
  11. void USART_int(long BaudRate);
  12. void USART_SendStr(char *str);
  13. void delay_ms(u32 n)  ;
  14. void delay_us(u32 n);
  15. /****主函数 ****/
  16. int main()
  17. {
  18. RCC_Configuration();
  19. GPIO_INIT();
  20. USART_int(9600);
  21. GPIO_ResetBits(GPIOC,0xffff);//led全亮,提示程序开始
  22. delay_ms(200);
  23. GPIO_SetBits(GPIOC,0xffff);//led全灭
  24. USART_SendStr("USART Led Speed\r\n");//
  25. USART_SendStr("\n>");//
  26. while(1);
  27. }
  28. /****   配置RCC ****/
  29. void RCC_Configuration(void)
  30. {
  31. ErrorStatus HSEStartUpStatus; //  设置错误标志量
  32. RCC_DeInit(); //*将外设寄存器RCC重设为初始值
  33. RCC_HSEConfig(RCC_HSE_ON);//*打开外部高速时钟晶振HSE:
  34. HSEStartUpStatus = RCC_WaitForHSEStartUp(); //*等待外部高速时钟晶振工作:
  35. if(HSEStartUpStatus==SUCCESS)
  36. {
  37. RCC_HCLKConfig(RCC_SYSCLK_Div1);//*AHB使用系统时钟,负责外部存储器的时钟
  38. RCC_PCLK1Config(RCC_HCLK_Div2);//*APB1 负责DA,USB,SPI,I2C,CAN,串口2345,普通TIM
  39. RCC_PCLK2Config(RCC_HCLK_Div1);//*APB2负责AD,I/O,高级TIM,串口1
  40. RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);//*设置PLL输入时钟源72M
  41. RCC_PLLCmd(ENABLE);//*打开PLL:
  42. while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);//*等待PLL工作:
  43. RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//*设置系统时钟
  44. while(RCC_GetSYSCLKSource() != 0x08);//* 判断PLL是否是系统时钟:
  45. }
  46. GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);
  47. /*蜂鸣器*/
  48. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);
  49. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  50. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  51. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  52. GPIO_Init(GPIOD, &GPIO_InitStructure);
  53. GPIO_ResetBits(GPIOD,GPIO_Pin_2);
  54. }
  55. /****延时 ****/
  56. void delay_us(u32 n)
  57. {
  58. u8 j;
  59. while(n--)
  60. for(j=0;j<10;j++);
  61. }
  62. void delay_ms(u32 n)
  63. {
  64. while(n--)
  65. delay_us(1000);
  66. }
  67. /**** 初始化GPIO ****/
  68. void GPIO_INIT(void)
  69. {
  70. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
  71. 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;
  72. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  73. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  74. GPIO_Init(GPIOC, &GPIO_InitStructure);
  75. }
  76. /**** USART传输的波特率 ****/
  77. void USART_int(long BaudRate)
  78. {
  79. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);//使能PA和 usart1
  80. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  81. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
  82. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出 PA9作为US1的TX端,打开复用,负责发送数据
  83. GPIO_Init(GPIOA, &GPIO_InitStructure);
  84. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //RX位于PA10
  85. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入,PA10作为US1的RX端,负责接收数据
  86. //RX初始化PA10
  87. USART_InitStructure.USART_BaudRate = BaudRate;//波特率
  88. USART_InitStructure.USART_WordLength = USART_WordLength_8b;//USART_WordLength 在一个帧中传输8位数据(字节)
  89. USART_InitStructure.USART_StopBits = USART_StopBits_1;//停止位为一个字节
  90. USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验
  91. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无流控制
  92. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//收发模式
  93. USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;//时钟低电平活动,开启发送接受数据功能(usart 使能)
  94. USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low; //SCLK输出时钟低电平
  95. USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;//时钟第二个边沿开始数据捕获
  96. USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;//最后一位数据不从SCLK发出
  97. USART_ClockInit(USART1, &USART_ClockInitStructure);//初始化USART1时钟
  98. USART_Init(USART1, &USART_InitStructure);//初始化USART1
  99. USART_Cmd(USART1, ENABLE);//USART1使能
  100. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//使能接收中断,在接受移位寄存器中有数据时产生
  101. USART_Cmd(USART1, ENABLE);
  102. //配置NVIC ,设置优先级分组,使用NVIC_Init对NVIC进行初始化
  103. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);//选择中断分组4(先占优先级四位,从优先级0)
  104. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //选择中断通道
  105. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//抢占优先级1-15
  106. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//响应优先级1-15
  107. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能中断
  108. NVIC_Init(&NVIC_InitStructure); //初始化中断
  109. }
  110. /**** usart发送数据 ****/
  111. void USART_SendStr(char *str) //USART发送数据
  112. {
  113. while((*str)!='\0')
  114. {
  115. USART_SendData(USART1,*str++); //通过外设 USARTx 发送单个数据
  116. while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); //检查指定的 USART 标志位设置与否
  117. }
  118. }
  119. /**** 取字符串中的数字 ****/
  120. unsigned int translate(char* pstr)
  121. {
  122. int s = 0;
  123. while(*pstr != '\0'//如果没扫到字符串的最后不停止
  124. {
  125. if(*pstr >= '0' && *pstr <= '9'//如果字符串中存在0-9的数字
  126. {
  127. s = s * 10 + *pstr - '0';
  128. }
  129. pstr++;
  130. }
  131. return s;
  132. }
  133. /****  点亮led****/
  134. void LED(char *S,char LEN) //(字符串,字符串长度)
  135. {
  136. int m,i;
  137. int a[8]={GPIO_Pin_0,GPIO_Pin_1,GPIO_Pin_2,GPIO_Pin_3,GPIO_Pin_4,GPIO_Pin_5,GPIO_Pin_6,GPIO_Pin_7};
  138. m=translate(S);
  139. 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);
  140. delay_ms(100);
  141. for(i=0;i<8;i++)
  142. {
  143. GPIO_ResetBits(GPIOC,a[i]); // 点亮LED
  144. delay_ms(m);
  145. GPIO_SetBits(GPIOC,a[i]); //熄灭LED
  146. delay_ms(m);
  147. }
  148. }
  149. void input_ASK()
  150. {
  151. char j;
  152. LED(rx_buff,rx_buff_count);
  153. rx_buff_count=0;
  154. for (j=0;j
  155. {
  156. rx_buff[j]='\0';
  157. }//判断读入信息是否结束,如果结束则准备下一次读入
  158. USART_SendStr("\n>");
  159. }
  160. /****接收中断****/
  161. void USART1_IRQHandler(void)
  162. {
  163. while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET)  { } //判断接收中断是否打开
  164. if(USART_ReceiveData(USART1)==0x0d)
  165. {
  166. input_ASK();
  167. }
  168. else
  169. {
  170. USART_SendData(USART1,USART_ReceiveData(USART1)); //将数据传回给电脑
  171. rx_buff[rx_buff_count]= USART_ReceiveData(USART1);
  172. rx_buff_count++;
  173. }
  174. USART_ClearFlag(USART1, USART_FLAG_RXNE); //清除中断接受完成标志位
  175. }

菜鸟
2015-12-07 14:08:09     打赏
6楼

作业五:定时器控制LED灯

#include "stm32f10x.h"  
#include "stm32_eval.h"  
#include <stdio.h>  
/** @addtogroup STM32F10x_StdPeriph_Examples 
  * @{ 
  */  
  
/** @addtogroup EXTI_Config 
  * @{ 
  */   
  
/* Private typedef -----------------------------------------------------------*/  
/* Private define ------------------------------------------------------------*/  
/* Private macro -------------------------------------------------------------*/  
/* Private variables ---------------------------------------------------------*/  
EXTI_InitTypeDef   EXTI_InitStructure;  
GPIO_InitTypeDef   GPIO_InitStructure;  
NVIC_InitTypeDef   NVIC_InitStructure;  
USART_InitTypeDef USART_InitStructure;  
USART_ClockInitTypeDef USART_ClockInitStructure;  
TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;  
TIM_OCInitTypeDef  TIM_OCInitStructure;  
int count=0;  
  
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); 
*/  
  SystemInit();  
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);  
  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG  
  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);  
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_AFIO, ENABLE);  
  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG  
  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;  
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  
  GPIO_Init(GPIOC, &GPIO_InitStructure);  
  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);  
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);  
}  
  
void USART_int(long BaudRate)  
{  
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);  
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;  
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;  
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;   
    GPIO_Init(GPIOA, &GPIO_InitStructure);  
    /* PA10 USART1_Rx  */  
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;  
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;  
    GPIO_Init(GPIOA, &GPIO_InitStructure);  
  /* 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;//???????8bit  
  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);  
  USART_Init(USART1, &USART_InitStructure);  
  USART_Cmd(USART1, ENABLE);  
  USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);  
  USART_Cmd(USART1, ENABLE);  
}  
  
void NVIC_Configuration(void)  
{  
  NVIC_InitTypeDef NVIC_InitStructure;  
  
  /* Enable the TIM2 global Interrupt */  
  NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;  
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;  
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  
  NVIC_Init(&NVIC_InitStructure);  
}  
 
int main(void)  
{  
  /*!< At this stage the microcontroller clock setting is already configured,  
       this is done through SystemInit() function which is called from startup 
       file (startup_stm32f10x_xx.s) before to branch to application main. 
       To reconfigure the default setting of SystemInit() function, refer to 
       system_stm32f10x.c file 
     */       
         
  /* System Clocks Configuration */  
  RCC_Configuration();  
  
  NVIC_Configuration();  
//USART_int(115200);  
//  printf("config done...\r\n");  
  
  /* Time base configuration */  
  TIM_TimeBaseStructure.TIM_Period = 36000;  
  TIM_TimeBaseStructure.TIM_Prescaler = 100;  
  TIM_TimeBaseStructure.TIM_ClockDivision = 0;  
  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  
  TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);  
  TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE );   
    
  /* TIM2 enable counter */  
  TIM_Cmd(TIM2, ENABLE);  
  
  while (1){  
//if(flag == 1)  
//  {printf("TIM2 interrupt......\r\n");  
//flag = 0;  
}  
//else{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);}  
//}  
}  
  
void TIM2_IRQHandler(void) //TIM3  
{  
if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)   
{  
TIM_ClearITPendingBit(TIM2, TIM_IT_Update );  
//  flag = ~flag;     
//  if(flag){  
//  GPIO_SetBits(GPIOC,GPIO_Pin_1);}  
//  else {GPIO_ResetBits(GPIOC,GPIO_Pin_1);}  
/*flag++; 
    if(flag == 50) 
        {led = ~led; 
         flag = 0;} 
    if(led){ 
    GPIO_SetBits(GPIOC,GPIO_Pin_1);} 
    else {GPIO_ResetBits(GPIOC,GPIO_Pin_1);}*/  
    count++;  
    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);  
        if(count==1)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_0);  
    if(count==2)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_1);  
    if(count==3)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_2);  
    if(count==4)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_3);  
    if(count==5)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_4);  
    if(count==6)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_5);  
    if(count==7)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_6);  
    if(count==8)   
    GPIO_ResetBits(GPIOC,GPIO_Pin_7);  
    if(count==9)  
    count=0;  
         }  
}  
 
#ifdef  USE_FULL_ASSERT   
/** 
  * @brief  Reports the name of the source file and the source line number 
  *         where the assert_param error has occurred. 
  * @param  file: pointer to the source file name 
  * @param  line: assert_param error line source number 
  * @retval None 
  */  
void assert_failed(uint8_t* file, uint32_t line)  
{   
  /* User can add his own implementation to report the file name and line number, 
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */  
  
  /* Infinite loop */  
  while (1)  
  {  
  }  
}  
#endif    
#ifdef __GNUC__  
  /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf 
     set to 'Yes') calls __io_putchar() */  
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)  
#else  
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)  
#endif /* __GNUC__ */  
  
PUTCHAR_PROTOTYPE  
{  
  /* Place your implementation of fputc here */  
  /* e.g. write a character to the USART */  
  USART_SendData(EVAL_COM1, (uint8_t) ch);  
  
  /* Loop until the end of transmission */  
  while (USART_GetFlagStatus(EVAL_COM1, USART_FLAG_TC) == RESET)  
  {}  
  
  return ch;  
}  
  
#ifdef  USE_FULL_ASSERT  

void assert_failed(uint8_t* file, uint32_t line)  
{   
  /* User can add his own implementation to report the file name and line number, 
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */  
  
  /* Infinite loop */  
  while (1)  
  {  
  }  
}  

 #endif 

我是菜鸟,都懂的


院士
2015-12-07 21:08:31     打赏
7楼
其实论坛发帖里有 代码插入功能。 这样看上去会非常舒服了

菜鸟
2016-01-14 11:53:24     打赏
8楼

作业六:计算机开机次数

sfr IAP_DATA     = 0xE2;
sfr IAP_ADDRH     = 0xE3;
sfr IAP_ADDRL     = 0xE4;
sfr IAP_CMD      = 0xE5;
sfr IAP_TRIG     = 0xE6;
sfr IAP_CONTR     = 0xE7;

#define           CMD_IDLE  0
#define           CMD_READ   1
#define           CMD_PROGRAM   2
#define           CMD_ERASE   3 

#define     ENABLE_IAP0x80 
#define     ENABLE_IAP0x81 
#define     ENABLE_IAP0x82
#define     ENABLE_IAP0x83 

IAP_ADDRESS    0x2000    //STC90C52ϵÁÐEEPROM²âÊÔÆðʼµØÖ·

void IapIdle(void)
{
IAP_CONTR=0;
IAP_CMD =0;
IAP_TRIG =0;
IAP_ADDRH=0x80;
IAP_ADDRL =0;

}

unsigned char IapReadByte(unsigned int addt) 
{
unsigned char dat;
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_READ;
IAP_ADDRL=addr;
IAP_ADDRL=addr>>8
IAP_TRIG =0x46;
IAP_TRIG =0xb9;
dat = IAP_DATA;
IapIdle();


return dat;

}

void Iap ProgramByte(unsigned int addr,unsigned char dat )
{
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_REOGRAM;
IAP_ADDRL=addr;
IAP_ADDRH=addr>>8
IAP_DATA=date;
IAP_TRIG =0x46;
IAP_TRIG =0xb9;

IapIdle();
}

void Iap EraseSector(unsigned int addr )
{
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_ERASE;
IAP_ADDRL=addr;
IAP_ADDRH=addr>>8
IAP_TRIG =0x46;
IAP_TRIG =0xb9;

IapIdle();
}
unsigned char Num=0;
void main(void)
{
unsigned long i=0;
Num = Iap ReadByte(IAP_ADDRESS+20);
Num++;
Iap EraseSector(IAP_ADDRESS);
Iap ProgramByte(IAP_ADDRESS+20,Num);
for(i=0;i
{
LED0=0;
DelayMs(100);
LED0=1;
DelayMs(100);
}
while(1);
}


菜鸟
2016-01-14 12:01:24     打赏
9楼

作业七:DS18B20温度使灯的颜色变化


#define  "ds18b20.h"

#define "delay.h"

#include "sys.h"

#include "usart.h"

#include "led.h"

#include "lcd.h"

void DS18B20_Rst(void)

{

DS18B20_IO_OUT(); //SET PG11 OUTPUT

DS18B20_DQ_OUT=0;                       //拉低 DQ

delay_us(750);                                    //拉低 750us

DS18B20_DQ_OUT=1;                       //DQ=1

delay_us(15); //15US

}

//等待 DS18B20 的回应

//返回 1:未检测到 DS18B20 的存在

//返回 0:存在

u8 DS18B20_Check(void)

{

u8 retry=0;

DS18B20_IO_IN();//SET PG11 INPUT

while (DS18B20_DQ_IN&&retry<200) { retry++; delay_us(1); };

if(retry>=200)return 1;

else retry=0;

while (!DS18B20_DQ_IN&&retry<240) {retry++; delay_us(1); };

if(retry>=240)return 1;

return 0;

}

//从 DS18B20 读取一个位

//返回值:1/0

u8 DS18B20_Read_Bit(void)

{

u8 data;

DS18B20_IO_OUT();//SET PG11 OUTPUT

DS18B20_DQ_OUT=0;

delay_us(2);

DS18B20_DQ_OUT=1;

DS18B20_IO_IN();//SET PG11 INPUT

delay_us(12);

if(DS18B20_DQ_IN)data=1;

else data=0;

delay_us(50);

return data;

}

//从 DS18B20 读取一个字节

//返回值:读到的数据

u8 DS18B20_Read_Byte(void)

{

u8 i,j,dat;

dat=0;

for (i=1;i<=8;i++)

{

j=DS18B20_Read_Bit();

dat=(j<<7)|(dat>>1);

}

return dat;

}

//写一个字节到 DS18B20

//dat:要写入的字节

void DS18B20_Write_Byte(u8 dat)

{

u8 j;

u8 testb;

DS18B20_IO_OUT();//SET PG11 OUTPUT;

for (j=1;j<=8;j++)

{

testb=dat&0x01;

dat=dat>>1;

if (testb)

{

DS18B20_DQ_OUT=0;// Write 1

delay_us(2);

DS18B20_DQ_OUT=1;

delay_us(60);

}

else

{

DS18B20_DQ_OUT=0;// Write 0

delay_us(60);

DS18B20_DQ_OUT=1;

delay_us(2);

}

}

}

//开始温度转换

void DS18B20_Start(void)

{

DS18B20_Rst();

DS18B20_Check();

DS18B20_Write_Byte(0xcc);// skip rom

DS18B20_Write_Byte(0x44);// convert

}

//初始化 DS18B20 的 IO 口 DQ 同时检测 DS 的存在

//返回 1:不存在

//返回 0:存在

u8 DS18B20_Init(void)

{

GPIO_InitTypeDef GPIO_InitStructure;

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOG, ENABLE);  //使能 GPIOG 时钟

//GPIOG9

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;                  //普通输出模式

GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;                   //推挽输出

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;             //50MHz

GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;                       //上拉

GPIO_Init(GPIOG, &GPIO_InitStructure);                                     //初始化

DS18B20_Rst();

return DS18B20_Check();

}

//从 ds18b20 得到温度值

//精度:0.1C

//返回值:温度值 (-550~1250)

short DS18B20_Get_Temp(void)

{

u8 temp;

u8 TL,TH;

short tem;

DS18B20_Start();// ds1820 start convert

DS18B20_Rst();

DS18B20_Check();

DS18B20_Write_Byte(0xcc);// skip rom

DS18B20_Write_Byte(0xbe);// convert

TL=DS18B20_Read_Byte(); // LSB

TH=DS18B20_Read_Byte(); // MSB

if(TH>7)

{

TH=~TH;

TL=~TL;

temp=0;                               //温度为负

}else temp=1;                       //温度为正

tem=TH;                              //获得高八位

tem<<=8;

tem+=TL;                             //获得底八位

tem=(double)tem*0.625;      //转换

if(temp)return tem;               //返回温度值

else return -tem;

}

//ds18b20.h

#ifndef__DS18B20_H

#define__DS18B20_H

#include"sys.h"

#include"sys.h"

//IO方向设置

#define DS18B20_IO_IN() {GPIOG->MODERA=~(3<<(9*2));GPIOG->MODERA=~(0<<(9*2))} //PG9输入模式

#define DS18B20_IO_OUT() {GPIOG->MODERA=~(3<<(9*2));GPIOG->MODERA=~(0<<(9*2))} //PG9输出模式

//IO操作函数

#define DS18B20_DQ_IN PGout(9)       //数据端口 PG9

#define DS18B20_DQ_OUT PGout(9)    //数据端口PG9

u8 DS18B20_Init(void);                          //初始化DS18B20

short DS18B20_Get_Temp(void);            //获取温度

void DS18B20_Start(void);              //开始温度转换

void DS18B20_Write_Byte(u8 dat);  //写 入一个字节

u8 DS18B20_Read_Byte(void);         //读出一个字节

u8 DS18B20_Read_Bit(void);            //读出一个位

u8 DS18B20_Check(void);                //检测是否存在DS18B20

void DS18B20_Rst(void);                  //复位DS18B20


int main(void)

{

u8 t=0;

short temperature;

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);    //设置系统中断优先级分组2

delay_init(168);                                                          //初始化延时函数

uart_init(115200);                                                      //初始化串口波特率为115200


LED_Init();                                                                             //初始化LED

LCD_Init();

POINT_COLOR=RED;                                                          //设置字体为红色

LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");

LCD_ShowString(30,70,200,16,16,"DS18B20 TEST");

LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK");

LCD_ShowString(30,110,200,16,16,"2014/5/7");

while(DS18B20_Init())                                                           //DS18B20初始化

{

LCD_ShowString(30,130,200,16,16,"DS18B20 Error");

delay_ms(200);

LCD_Fill(30,130,239,130+16,WHITE);

delay_ms(200);

}

LCD_ShowString(30,130,200,16,16,"DS18B20 OK");

POINT_COLOR=BLUE;                                                        //设置字体为蓝色

LCD_ShowString(30,150,200,16,16,"Temp:   . C");

while(1)

{

if(t%10==0)//每100ms读取一次

{

temperature=DS18B20_Get_Temp();

if(temperature<0)

{

LCD_ShowChar(30+40,150,'-',16,0);                                       //显示负号

temperature=-temperature;                                                   //转为正数

}else LCD_ShowChar(30+40,150,' ',16,0);                                //去掉负号

LCD_ShowNum(30+40+8,150,temperature/10,2,16);            //显示正数部分

LCD_ShowNum(30+40+32,150,temperature%10,1,16);     //显示小数部分

}

delay_ms(10);

t++;

if(t==20)

{

t=0;

LED0=!LED0;

}

}

}

我们这种菜鸟,没办法,很多都是借鉴参考别人的,老师你轻些!

共9条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]