2. 使用JsonDocument
创建一个JsonDocument之后,默认初始化为空,调用 JsonDocument::isNull()会返回true,这个时候既可以代表当做jsonObject,也可以当做jsonArray,这取决于你插入第一个value的类型。
例2: doc 作为JsonArray使用
DynamicJsonDocument doc(1024);
3. as —— 获取顶节点,并把它转成T类型
DynamicJsonBuffer doc(1024);
4. to —— jsondocument转成T类型
函数说明:
5. clear —— 清除JsonDocument并释放内存空间
清除JsonDocument并释放内存空间
6. isNull —— 判断jsondocument是否为空
/**
7. memoryUsage —— jsondocument已使用内存字节数
函数说明:
8. remove —— 移除特定key和value
results.remove(0);
三. 解析构造相关
1.deserializeJson —— 解析json/** * 解析json * @param doc jsondocument对象 * @param input 输入内容 * @return DeserializationError 解析结果 */ // writable input => zero-copy DeserializationError deserializeJson(JsonDocument& doc, char* input); DeserializationError deserializeJson(JsonDocument& doc, char* input, size_t inputSize); // read-only input => duplication DeserializationError deserializeJson(JsonDocument& doc, const char* input); DeserializationError deserializeJson(JsonDocument& doc, const char* input, size_t inputSize); DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input); DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input, size_t inputSize); DeserializationError deserializeJson(JsonDocument& doc, const String& input); DeserializationError deserializeJson(JsonDocument& doc, const std::string& input); DeserializationError deserializeJson(JsonDocument& doc, Stream& input); DeserializationError deserializeJson(JsonDocument& doc, std::istream& input);
2. serializeJson —— 构造序列化json (串口打印json)
StaticJsonDocument<200> doc;
3. serializeJsonPretty —— 构造序列化json,格式化输出 (串口美化打印json)
/**
4. measureJson —— 计算构造序列化json的长度
/**
2. createNestedArray —— 在当前对象中添加子key,子value为json数组
StaticJsonDocument<256> doc;
3. createNestedObject —— 在当前对象中添加子key,子value为json对象
StaticJsonDocument<256> doc;
4. getMember —— 获取key对应的value (仅限JsonObject类型)
/**
5. getOrCreateMember —— 获取或者创建key对应的value(仅限JsonObject类型)
/**
2. createNestedArray —— 添加json数组
StaticJsonDocument<200> doc;
3. createNestedObject —— 添加json对象
StaticJsonDocument<200> doc;
4. getElement —— 获取index位置的元素(仅限JsonArray类型)
/**
5. getOrAddElement —— 获取或者创建index对应的value(仅限JsonArray类型)
同上
#include <Arduino.h> #include "ArduinoJson.h" String jsonStr = "{\"results\":[{\"location\":{\"id\":\"WW7MBNP039PE\",\"name\":\"泰安\",\"country\":\"CN\",\"path\":\"泰安,泰安,山东,中国\",\"timezone\":\"Asia/Shanghai\",\"timezone_offset\":\"+08:00\"},\"now\":{\"text\":\"晴\",\"code\":\"0\",\"temperature\":\"28\"},\"last_update\":\"2020-09-09T10:09:00+08:00\"}]}"; DynamicJsonDocument doc(512); void setup() { Serial.begin(115200); delay(3000); } void loop() { //解析JSON字符串 Serial.println("从jsonStr解码成的DynamicJsonDocument对象doc:"); deserializeJson(doc, jsonStr); serializeJson(doc, Serial); Serial.println("从doc对象转换成的JsonObject类型对象root:"); JsonObject root = doc.as<JsonObject>(); serializeJson(root, Serial); Serial.println(); Serial.println(doc.memoryUsage()); Serial.println(measureJson(doc)); Serial.println(measureJsonPretty(doc)); Serial.println("root里有一个子JsonArray对象 results:"); JsonArray results = root["results"]; serializeJson(results, Serial); Serial.println(); //JsonArray类型的数组results里面只有一个元素: JsonObject对象results[0], //该元素有三个子对象 location, now, last_update //location Serial.println("JsonObject对象 results[0]中的子JsonObject对象location:"); JsonObject location = results[0]["location"]; serializeJson(location, Serial); Serial.println(); Serial.println("从JsonObject对象location中取出id"); const char *id = location["id"]; Serial.println(id); Serial.println("从JsonObject对象location中取出name"); const char *name = location["name"]; Serial.println(name); Serial.println("从JsonObject对象location中取出country"); const char *country = location["country"]; Serial.println(country); Serial.println("从JsonObject对象location中取出path"); const char *path = location["path"]; Serial.println(path); Serial.println("从JsonObject对象location中取出timezone"); const char *timezone = location["timezone"]; Serial.println(timezone); Serial.println("从JsonObject对象location中取出timezone_offset"); const char *timezone_offset = location["timezone_offset"]; Serial.println(timezone_offset); //now Serial.println("JsonObject对象 results[0]中的子JsonObject对象now(为了避免和timer中的now重名,把它叫做now1):"); JsonObject now1 = results[0]["now"]; serializeJson(now1, Serial); Serial.println("从JsonObject对象now1中取出text"); const char *text = now1["text"]; Serial.println(text); Serial.println("从JsonObject对象now1中取出code"); const char *code = now1["code"]; Serial.println(code); Serial.println("从JsonObject对象now1中取出temperature"); const char *temperature = now1["temperature"]; Serial.println(temperature); //last_update const char *last_update = results[0].getMember("last_update"); Serial.println("last_update:"); Serial.println(last_update); Serial.println(); delay(10000); }
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显示屏显示相关交互信息。
本节我们在迭代一的基础上增加采集土壤湿度数据,并根据湿度数据来决定是否自动进行浇水动作。