Files
ArduinoJson/examples/JsonParserExample/JsonParserExample.ino

78 lines
2.4 KiB
Arduino
Raw Normal View History

// ArduinoJson - arduinojson.org
// Copyright Benoit Blanchon 2014-2017
2014-11-03 21:29:55 +01:00
// MIT License
2017-12-11 15:19:28 +01:00
//
// This example shows how to deserialize a JSON document with ArduinoJson.
2014-03-01 12:59:45 +01:00
2014-11-03 21:29:55 +01:00
#include <ArduinoJson.h>
2014-03-01 12:59:45 +01:00
2014-11-03 21:29:55 +01:00
void setup() {
2017-12-11 15:19:28 +01:00
// Initialize serial port
2014-11-03 21:29:55 +01:00
Serial.begin(9600);
2017-12-11 15:19:28 +01:00
while (!Serial) continue;
2014-07-03 14:00:51 +02:00
2016-02-01 13:31:07 +01:00
// Memory pool for JSON object tree.
//
2017-12-11 15:19:28 +01:00
// Inside the brackets, 200 is the size of the pool in bytes.
// Don't forget to change this value to match your JSON document.
// Use arduinojson.org/assistant to compute the capacity.
2014-11-03 21:29:55 +01:00
StaticJsonBuffer<200> jsonBuffer;
2014-03-01 12:59:45 +01:00
2016-02-01 13:31:07 +01:00
// StaticJsonBuffer allocates memory on the stack, it can be
// replaced by DynamicJsonBuffer which allocates in the heap.
//
// DynamicJsonBuffer jsonBuffer(200);
2016-02-01 13:31:07 +01:00
// JSON input string.
//
// It's better to use a char[] as shown here.
// If you use a const char* or a String, ArduinoJson will
// have to make a copy of the input in the JsonBuffer.
2014-11-03 21:29:55 +01:00
char json[] =
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
2014-03-01 12:59:45 +01:00
2016-02-01 13:31:07 +01:00
// Root of the object tree.
//
// It's a reference to the JsonObject, the actual bytes are inside the
// JsonBuffer with all the other nodes of the object tree.
// Memory is freed when jsonBuffer goes out of scope.
2014-11-03 21:29:55 +01:00
JsonObject& root = jsonBuffer.parseObject(json);
2014-03-01 12:59:45 +01:00
2016-02-01 13:31:07 +01:00
// Test if parsing succeeds.
2014-11-03 21:29:55 +01:00
if (!root.success()) {
Serial.println("parseObject() failed");
return;
}
2014-03-01 12:59:45 +01:00
2016-02-01 13:31:07 +01:00
// Fetch values.
//
// Most of the time, you can rely on the implicit casts.
// In other case, you can do root["time"].as<long>();
2014-11-03 21:29:55 +01:00
const char* sensor = root["sensor"];
long time = root["time"];
double latitude = root["data"][0];
double longitude = root["data"][1];
2014-03-01 12:59:45 +01:00
2016-02-01 13:31:07 +01:00
// Print values.
2014-11-03 21:29:55 +01:00
Serial.println(sensor);
Serial.println(time);
Serial.println(latitude, 6);
Serial.println(longitude, 6);
2014-03-01 12:59:45 +01:00
}
2014-11-03 21:29:55 +01:00
void loop() {
// not used in this example
2015-08-20 15:15:59 +02:00
}
2017-12-11 15:19:28 +01:00
// See also
// --------
//
// The website arduinojson.org contains the documentation for all the functions
// used above. It also includes an FAQ that will help you solve any
// deserialization problem.
// Please check it out at: https://arduinojson.org/
//
// The book "Mastering ArduinoJson" contains a tutorial on deserialization.
// It begins with a simple example, like the one above, and then adds more
// features like deserializing directly from a file or an HTTP request.
2017-12-27 14:15:49 +01:00
// Please check it out at: https://arduinojson.org/book/