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用于主机与辅助设备通信。
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 技术的发展,未来的智能家居将能够更精确地感知和响应我们的行为,实现更高效、更人性化的控制。
ESP32-FreeRTOS项目提供了丰富的示例,帮助开发者快速掌握ESP32的硬件功能和FreeRTOS实时操作系统。
本节我们在迭代二的基础上使用四位数码管和OLED显示屏显示相关交互信息。
本节我们在迭代一的基础上增加采集土壤湿度数据,并根据湿度数据来决定是否自动进行浇水动作。