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);
}
I2S(Inter—IC Sound)总线, 又称集成电路内置音频总线,是飞利浦公司为数字音频设备之间的音频数据传输而制定的一种总线标准。
本文主要讲解WebServer库如何来处理表单请求。
WebServer是非常常用的一个功能,在设备上使用该功能可以直接通过浏览器访问和操作设备。
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显示屏接线的详细说明,供大家参考。