STM32+ESP8266点灯(STA 模式)点灯(2)

1、简介

STM32+ESP8266点灯(AP+STA 模式)点灯(1)一文已经通过串口助手实现与网络调试助手透传,本文通过STM32单片机替代网络调试助手,实现远程点灯。

2、单片机配置

2.1 cubemax配置

2.1.1 RCC配置

 2.1.2 SYS配置

  2.1.3 时钟树配置

   2.1.4 LED配置

  2.1.5 UART配置

 2.1.6 UART配置

 2.2 KEIL 5配置

2.2.1 led宏定义

#define LED_ON  HAL_GPIO_WritePin(LED_GPIO_Port,LED_Pin,GPIO_PIN_SET)
#define LED_OFF HAL_GPIO_WritePin(LED_GPIO_Port,LED_Pin,GPIO_PIN_RESET)

 2.2.2 串口配置

#include "stdio.h"
/* USER CODE BEGIN 1 */
int fputc(int ch, FILE *f)
{
 uint8_t temp[1] = {ch};
 HAL_UART_Transmit(&huart1, temp, 1, 2);
 //HAL_UART_Transmit(&huart2, temp, 1, 2);
 return ch;
}
/* USER CODE END 1 */

 2.2.3 联网配置

main.c

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2023 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "usart.h"
#include "gpio.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "stdio.h"
char buf;
/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */
void  HAL_UART_RxCpltCallback(UART_HandleTypeDef  *huart)//串口中断回调函数
{
	if(huart1.Instance == USART1)
	{
		
		if(buf == 'A')
		{
			 LED_ON;
      HAL_UART_Receive_IT(&huart1, (uint8_t *)&buf, 1);
		}
		if(buf == 'B')
		{
			 LED_OFF;
      HAL_UART_Receive_IT(&huart1, (uint8_t *)&buf, 1);
		}
		HAL_UART_Receive_IT(&huart1, (uint8_t *)&buf, 1);
	}   
}
     
/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

/* Private variables ---------------------------------------------------------*/

/* USER CODE BEGIN PV */

/* USER CODE END PV */

/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
/* USER CODE BEGIN PFP */

/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */

/* USER CODE END 0 */

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_USART1_UART_Init();
  /* USER CODE BEGIN 2 */

	HAL_Delay(200);
	printf("AT+CIPSTART=\"TCP\",\"192.168.218.245\",8880\r\n");
	HAL_Delay(200);
	printf("AT+CIPMODE=1\r\n");
	HAL_Delay(200);
  printf("AT+CIPSEND\r\n");
	HAL_Delay(200);
	LED_ON;
//	printf("AT+RST\r\n");
  HAL_Delay(200);
  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {		
	   HAL_UART_Receive_IT(&huart1, (uint8_t *)&buf, 1);
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }
  /* USER CODE END 3 */
}

/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }

  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    Error_Handler();
  }
}

/* USER CODE BEGIN 4 */

/* USER CODE END 4 */

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1)
  {
  }
  /* USER CODE END Error_Handler_Debug */
}

#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 CODE BEGIN 6 */
  /* 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) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */

3、测试

在网络调试助手分别发送A、B进行点灯关灯。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要让STM32ESP8266连接到阿里云,需要先了解阿里云的物联网平台和相关的API接口。然后根据具体的应用场景需求,选择合适的协议和通信方式进行连接。具体可以采用MQTT或者HTTP协议进行连接,由此实现双向的数据传输。 首先,在STM32ESP8266中需要增加ESP8266的AT指令,将其作为WiFi模块使用,然后在此基础上进行网络配置和连接,获取SSID和密码信息等。然后基于MQTT或者HTTP协议进行连接,这两种协议都可以在阿里云IoT平台上实现。 使用MQTT协议进行连接,需要在STM32ESP8266中进行配置,包括服务器地址,端口号,客户端ID等信息。然后建立连接,发布或者订阅主题消息即可。 使用HTTP协议进行连接,需要在STM32ESP8266上进行HTTP请求,获取授权信息和TOKEN,然后调用阿里云提供的API接口来实现信息的发送和接收。 以上是STM32ESP8266连接阿里云的一些关键思路和步骤,具体还需要根据具体的需求进行详细的实现和调试。 ### 回答2: STM32是一款低功耗高性能的单片微控制器,而ESP8266是一款低成本的Wi-Fi模组,它们可以联合使用来连接到阿里云。 首先,你需要准备一台带有Wi-Fi模块供应商的STM32开发板,例如STMicroelectronics提供的Nucleo-F401RE,以及一台ESP8266 Wi-Fi模组。你还需要在阿里云上创建一个IoT Hub实例并为其生成证书。 接下来,你需要下载阿里云的SDK,该SDK支持C语言和STM32平台。将SDK包中的文件添加到您的工程中,并包含其头文件。 然后,在您的工程中设置Wi-Fi连接信息,包括SSID和密码。根据您的需求,您可以选择使用TCP或UDP协议,以及MQTT客户端进行连接和通信。 在向阿里云发送消息之前,您需要先使用证书验证自己的身份,并将证书和密钥文件添加到您的工程中。然后,您可以使用阿里云提供的API来发送和接收MQTT消息。 当您成功连接到阿里云IoT Hub并成功发送消息时,您可以在控制台中查看数据并将其用于您的应用程序。 在整个过程中,您需要确保您的代码按照阿里云SDK的指导进行编写,并且正确设置了Wi-Fi连接信息和证书。这将帮助您在不久的将来轻松地实现自己的IoT应用程序。 ### 回答3: STM32ESP8266作为微控制器和Wi-Fi模块组合,可以联合运作并连接到阿里云。概括地说,需要进行以下几步: 1. 准备硬件 网上购买STM32ESP8266开发板,将它们连接在一起。需要确保它们之间的连接是准确的,例如使用串行通信,确保引脚连接正确。 2. 搭建开发环境 需要安装ST-Link/V2驱动、Keil或者IAR等开发环境。ESP8266可以使用AT指令模式进行编程,也可以使用Lua语言进行编程。 3. 实现连接阿里云 (1)首先,注册阿里云账号并创建物联网实例。 (2)在阿里云后台创建设备,并获得设备的三元组信息(Device Name、ProductKey、Device Secret)。 (3)在STM32ESP8266中,添加连接阿里云云平台所需要的支持代码,例如接入SDK等。 (4)编写代码,将STM32ESP8266连接到Wi-Fi网络并连接到阿里云云平台。具体步骤包括: a. 将ESP8266设置为STA模式或AP模式,分别连接到Wi-Fi网络或者创建一个Wi-Fi热点。 b. 设置阿里云物联网平台的API密钥。 c. 在STM32中,编写代码将设备信息(Device Name、ProductKey、Device Secret)从芯片里读取出来。 d. 在ESP8266中编写代码将三元组信息加入MQTT连接参数,并连接到云端。 4. 通过阿里云平台进行消息传递 连接成功后,STM32ESP8266可以通过阿里云平台来进行双向数据传递。例如,STM32可以向阿里云发送传感器数据,阿里云会将数据转发给ESP8266ESP8266再将数据发送到远程设备或者APP上。 这就是STM32ESP8266连接到阿里云的主要流程。由于每个项目的要求不同,需要根据实际环境和需求来优化代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值