import network
import time
def connect():
ssid = '***'
password = '******'
wlan = network.WLAN(network.STA_IF)
wlan.active(True)
wlan.connect(ssid, password)
while wlan.isconnected() == False:
print('Waiting for connection...')
time.sleep(1)
print('Connected on {ip}'.format(ip = wlan.ifconfig()[0]))
from umqtt.simple import MQTTClient
MQTT_SERVER = 'iot.xpstem.com'
MQTT_PORT = 1883
MQTT_USER = 'ss10001'
MQTT_PASSWD = '******'
MQTT_CLIENT_ID = 'ESP32-CAM-001'
def connect():
client = MQTTClient(MQTT_CLIENT_ID, MQTT_SERVER, MQTT_PORT, MQTT_USER, MQTT_PASSWD, 300)
client.connect()
print('Connected to MQTT Broker "{server}"'.format(server = MQTT_SERVER))
return client
###################################
# 智能浇花项目
#
# 通过报像头拍照并上传。
# 要结合物联网系统来使用
#
# author: billy_zh@126.com
###################################
import wifi
import mqtt
import gc
import json
import random
import binascii
import time
import _thread
import camera
from machine import ADC, Pin
# 摄像头图像数据上报主题
PUB_TOPIC = b'xxxxxx'
# 报像头指令数据订阅主题
SUB_TOPIC = 'xxxxxx'
# wifi 连接
wifi.connect()
# mqtt 连接
mqtt_client = mqtt.connect()
####################
# 报像头拍照并将图像数据分块上传到服务器
####################
def capture_and_publish():
t = time.localtime()
id = 't{year}{month}{day}{id}'.format(year=t[0],month=t[1],day=t[2],id=random.randint(100000, 999999))
buf = camera.capture()
if (buf==False):
print("capture failure, skip...")
camera.deinit()
gc.collect()
# 重新初始化
camera.init(1)
return
img_bytes = bytes(buf)
# 字符数组传16进制字符数组(上传用)
img_str = binascii.hexlify(img_bytes).decode('ascii')
img_len = len(img_str)
num = (img_len + 799) // 800
# 分块上传数据头
msg_dict = {
"id": id,
"segment": 1,
"batchNum": num,
"totalSize": img_len,
"chknum": ""
}
msg = json.dumps(msg_dict)
result = mqtt_client.publish(PUB_TOPIC, msg)
print("Send message to topic '{topic}'".format(topic = PUB_TOPIC))
for i in range(num):
start = i * 800
end = start + 800
if (end > img_len):
end = img_len;
# 分块上传数据包
msg_dict = {l
"id": id,
"segment": 2,
"batchNo": i+1,
"data": {
"img": img_str[start:end]
}
}
msg = json.dumps(msg_dict)
result = mqtt_client.publish(PUB_TOPIC, msg)
print("Send message to topic '{topic}'".format(topic=PUB_TOPIC))
def msg_callback(topic, msg):
try:
payload = msg.decode();
print('从{topic}接收到消息, data:{data}'.format(topic=topic.decode(), data=payload))
dict = json.loads(payload)
action = dict['data']['action']
if action=='capture':
# 发送线程
_thread.start_new_thread(capture_and_publish, ())
except Exception as e:
print(f"消息接收出现错误:{e}")
# mqtt 订阅
mqtt_client.set_callback(msg_callback)
mqtt_client.subscribe(SUB_TOPIC)
camera.init(1)
####################
# 主循环
####################
while True:
# 检查是否有消息回调
mqtt_client.check_msg()
time.sleep(1)
UART是一种通用串行数据总线,用于异步通信。该总线双向通信,可以实现全双工传输和接收。在嵌入式设计中,UART用于主机与辅助设备通信。
Arduino-ESP32与ESP-IDF的版本对应表。
Arduino-ESP32提供了多种文件系统解决方案,本文将深入解析SPIFFS、LittleFS和SD卡三种主流存储方案,帮助你做出最佳选择。
ESP32-P4-WIFI6-DEV-KIT是一款微雪(Waveshare)设计的基于 ESP32-P4 的多媒体开发板,并集成 ESP32-C6,支持 Wi-Fi 6 和 BLE 5 无线连接。它提供丰富的人机交互接口,包括 MIPI-CSI (集成图像信号处理器 ISP)、MIPI-DSI、SPI、I2S、I2C、LED PWM、MCPWM、RMT、ADC、UART 和 TWAI 等。
ESP-Hosted 解决方案提供了将 ESP 板用作 Wi-Fi 和 Bluetooth/BLE 连接的通信处理器的方法。
ESP-Hosted 提供了一种将ESP芯片和模组用作通信协处理器的解决方案,该解决方案为主机微处理器或微控制器提供无线连接,使主机能够与其他设备通信。简单来说为网卡方案。
Arduino+ESP32上使用TFT_eSPI库快速点亮这个屏幕,驱动芯片ST7789
本文给出了一个ESP32与SPI 接口TFT显示屏接线的详细说明,供大家参考。
本文讲解如何在Micropython环境下使用ESP32的ESPNow功能进行数据传输。
ESP-Dongle 是一款基于 ESP32-S3 芯片开发的多功能 USB Device 解决方案。它不仅外形小巧,功能齐全,更集成了无线 U 盘、SD 卡读取以及 USB 无线网卡等多项功能。
ESP32 系列芯片可以利用 CSI 数据实现动作检测和存在检测。无论是自动调节灯光、风扇,还是节能控制,CSI 技术为智能家居带来了新的可能性。随着 CSI 技术的发展,未来的智能家居将能够更精确地感知和响应我们的行为,实现更高效、更人性化的控制。