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)总线, 又称集成电路内置音频总线,是飞利浦公司为数字音频设备之间的音频数据传输而制定的一种总线标准。
ESP32-CAM与MicroPython结合可实现摄像头图像采集、视频流传输等功能,不过Micropython官方没有支持ESP32-CAM的固件,需要烧录第三方的专有固件。
相信很多人都有把绿植给养死的经历,可能是浇水过多、忘记浇水、较长时间不在家不能浇水等,本文介绍一种可以灵活定制的智能浇花方案。
MicroPython 在 ESP32 上支持线程(Thread)功能,通过_thread模块实现。线程允许程序并发执行多个任务,适合处理需要同时运行的场景,例如传感器数据采集和网络通信。
掌控板3.0升级了主控,还主打AI。带有双麦克风阵列,增加了音频解码芯片,板载了一个1W喇叭,还把之前的单色屏幕换成了1.47寸的彩色屏幕,有更多的可玩性。
使用了 MicroPython 库,通过 定时器(Timer) 和 ADC(模数转换器) 功能来实时读取传感器数据。使用定时器可以实现高精度、非阻塞、低资源消耗的周期性任务,保证实时性和可靠性,特别适用于嵌入式系统中的多任务处理和低功耗场景。
LED点阵屏由LED发光二极管组成,通过控制LED亮灭来显示文字、图片、动画、视频等,被广泛应用于公共场合做信息展示,如广告屏、公告牌等。
ESP32的DAC函数可以实现真正的模拟输出。
ESP32 没有Arduino输出 PWM 的 analogWrite(pin, value) 方法,取而代之的 ESP32 有一个 LEDC 来实现PWM功能。