forked from bblanchon/ArduinoJson
Reworked all examples
This commit is contained in:
@ -8,7 +8,7 @@ HEAD
|
|||||||
* Added a clear error message when compiled as C instead of C++ (issue #629)
|
* Added a clear error message when compiled as C instead of C++ (issue #629)
|
||||||
* Added detection of MPLAB XC compiler (issue #629)
|
* Added detection of MPLAB XC compiler (issue #629)
|
||||||
* Added detection of Keil ARM Compiler (issue #629)
|
* Added detection of Keil ARM Compiler (issue #629)
|
||||||
* Rewrote example `JsonHttpClient.ino` (issue #600)
|
* Reworked all examples
|
||||||
|
|
||||||
> ### How to use the new feature?
|
> ### How to use the new feature?
|
||||||
>
|
>
|
||||||
|
@ -1,20 +1,21 @@
|
|||||||
// ArduinoJson - arduinojson.org
|
// ArduinoJson - arduinojson.org
|
||||||
// Copyright Benoit Blanchon 2014-2017
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// MIT License
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to generate a JSON document with ArduinoJson.
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
// Initialize Serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) {
|
while (!Serial) continue;
|
||||||
// wait serial port initialization
|
|
||||||
}
|
|
||||||
|
|
||||||
// Memory pool for JSON object tree.
|
// Memory pool for JSON object tree.
|
||||||
//
|
//
|
||||||
// Inside the brackets, 200 is the size of the pool in bytes.
|
// Inside the brackets, 200 is the size of the pool in bytes.
|
||||||
// If the JSON object is more complex, you need to increase that value.
|
// Don't forget to change this value to match your JSON document.
|
||||||
// See http://arduinojson.org/assistant/
|
// See https://arduinojson.org/assistant/
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
StaticJsonBuffer<200> jsonBuffer;
|
||||||
|
|
||||||
// StaticJsonBuffer allocates memory on the stack, it can be
|
// StaticJsonBuffer allocates memory on the stack, it can be
|
||||||
@ -65,3 +66,16 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 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
|
||||||
|
// serialization problem.
|
||||||
|
// Please check it out at: https://arduinojson.org/
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
|
// It begins with a simple example, like the one above, and then adds more
|
||||||
|
// features like serializing directly to a file or an HTTP request.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
@ -2,9 +2,10 @@
|
|||||||
// Copyright Benoit Blanchon 2014-2017
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// Example of an HTTP client parsing a JSON response.
|
// This example shows how to parse a JSON document in an HTTP response.
|
||||||
|
// It uses the Ethernet library, but can be easily adapter for Wifi.
|
||||||
//
|
//
|
||||||
// This program perform an HTTP GET of arduinojson.org/example.json
|
// It performs a GET resquest on arduinojson.org/example.json
|
||||||
// Here is the expected response:
|
// Here is the expected response:
|
||||||
// {
|
// {
|
||||||
// "sensor": "gps",
|
// "sensor": "gps",
|
||||||
@ -14,73 +15,98 @@
|
|||||||
// 2.302038
|
// 2.302038
|
||||||
// ]
|
// ]
|
||||||
// }
|
// }
|
||||||
// See http://arduinojson.org/assistant/ to compute the size of the buffer.
|
|
||||||
//
|
|
||||||
// Disclaimer: the code emphasize the communication between client and server,
|
|
||||||
// it doesn't claim to be a reference of good coding practices.
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
// Initialize Serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial);
|
while (!Serial) continue;
|
||||||
|
|
||||||
echo("Initialize Ethernet library");
|
// Initialize Ethernet library
|
||||||
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
Ethernet.begin(mac) || die("Failed to configure Ethernet");
|
if (!Ethernet.begin(mac)) {
|
||||||
|
Serial.println(F("Failed to configure Ethernet"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
delay(1000);
|
delay(1000);
|
||||||
|
|
||||||
echo("Connect to HTTP server");
|
Serial.println(F("Connecting..."));
|
||||||
|
|
||||||
|
// Connect to HTTP server
|
||||||
EthernetClient client;
|
EthernetClient client;
|
||||||
client.setTimeout(10000);
|
client.setTimeout(10000);
|
||||||
client.connect("arduinojson.org", 80) || die("Connection failed");
|
if (!client.connect("arduinojson.org", 80)) {
|
||||||
|
Serial.println(F("Connection failed"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
echo("Send HTTP request");
|
Serial.println(F("Connected!"));
|
||||||
client.println("GET /example.json HTTP/1.0");
|
|
||||||
client.println("Host: arduinojson.org");
|
|
||||||
client.println("Connection: close");
|
|
||||||
client.println() || die("Failed to send request");
|
|
||||||
|
|
||||||
echo("Check HTTP status");
|
// Send HTTP request
|
||||||
|
client.println(F("GET /example.json HTTP/1.0"));
|
||||||
|
client.println(F("Host: arduinojson.org"));
|
||||||
|
client.println(F("Connection: close"));
|
||||||
|
if (client.println() == 0) {
|
||||||
|
Serial.println(F("Failed to send request"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check HTTP status
|
||||||
char status[32] = {0};
|
char status[32] = {0};
|
||||||
client.readBytesUntil('\r', status, sizeof(status));
|
client.readBytesUntil('\r', status, sizeof(status));
|
||||||
if (strcmp(status, "HTTP/1.1 200 OK") != 0) {
|
if (strcmp(status, "HTTP/1.1 200 OK") != 0) {
|
||||||
echo(status);
|
Serial.print(F("Unexpected response: "));
|
||||||
die("Unexpected HTTP response");
|
Serial.println(status);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
echo("Skip HTTP headers");
|
// Skip HTTP headers
|
||||||
char endOfHeaders[] = "\r\n\r\n";
|
char endOfHeaders[] = "\r\n\r\n";
|
||||||
client.find(endOfHeaders) || die("Invalid response");
|
if (!client.find(endOfHeaders)) {
|
||||||
|
Serial.println(F("Invalid response"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
echo("Allocate JsonBuffer");
|
// Allocate JsonBuffer
|
||||||
const size_t BUFFER_SIZE = JSON_OBJECT_SIZE(3) + JSON_ARRAY_SIZE(2) + 60;
|
// (see https://arduinojson.org/assistant/ to compute the capacity)
|
||||||
DynamicJsonBuffer jsonBuffer(BUFFER_SIZE);
|
const size_t capacity = JSON_OBJECT_SIZE(3) + JSON_ARRAY_SIZE(2) + 60;
|
||||||
|
DynamicJsonBuffer jsonBuffer(capacity);
|
||||||
|
|
||||||
echo("Parse JSON object");
|
// Parse JSON object
|
||||||
JsonObject& root = jsonBuffer.parseObject(client);
|
JsonObject& root = jsonBuffer.parseObject(client);
|
||||||
if (!root.success()) die("Parsing failed!");
|
if (!root.success()) {
|
||||||
|
Serial.println(F("Parsing failed!"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
echo("Extract values");
|
// Extract values
|
||||||
echo(root["sensor"].as<char*>());
|
Serial.println(F("Response:"));
|
||||||
echo(root["time"].as<char*>());
|
Serial.println(root["sensor"].as<char*>());
|
||||||
echo(root["data"][0].as<char*>());
|
Serial.println(root["time"].as<char*>());
|
||||||
echo(root["data"][1].as<char*>());
|
Serial.println(root["data"][0].as<char*>());
|
||||||
|
Serial.println(root["data"][1].as<char*>());
|
||||||
|
|
||||||
echo("Disconnect");
|
// Disconnect
|
||||||
client.stop();
|
client.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {}
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
void echo(const char* message) {
|
|
||||||
Serial.println(message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool die(const char* message) {
|
// See also
|
||||||
Serial.println(message);
|
// --------
|
||||||
while (true); // loop forever
|
//
|
||||||
return false;
|
// The website arduinojson.org contains the documentation for all the functions
|
||||||
}
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization problem.
|
||||||
|
// Please check it out at: https://arduinojson.org/
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on deserialization
|
||||||
|
// showing how to parse the response from Yahoo Weather. In the last chapter,
|
||||||
|
// it shows how to parse the huge documents from OpenWeatherMap
|
||||||
|
// and Weather Underground.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
@ -1,20 +1,21 @@
|
|||||||
// ArduinoJson - arduinojson.org
|
// ArduinoJson - arduinojson.org
|
||||||
// Copyright Benoit Blanchon 2014-2017
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// MIT License
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to deserialize a JSON document with ArduinoJson.
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) {
|
while (!Serial) continue;
|
||||||
// wait serial port initialization
|
|
||||||
}
|
|
||||||
|
|
||||||
// Memory pool for JSON object tree.
|
// Memory pool for JSON object tree.
|
||||||
//
|
//
|
||||||
// Inside the brackets, 200 is the size of the pool in bytes,
|
// Inside the brackets, 200 is the size of the pool in bytes.
|
||||||
// If the JSON object is more complex, you need to increase that value.
|
// Don't forget to change this value to match your JSON document.
|
||||||
// See http://arduinojson.org/assistant/
|
// See https://arduinojson.org/assistant/
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
StaticJsonBuffer<200> jsonBuffer;
|
||||||
|
|
||||||
// StaticJsonBuffer allocates memory on the stack, it can be
|
// StaticJsonBuffer allocates memory on the stack, it can be
|
||||||
@ -62,3 +63,16 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 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.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
@ -1,76 +1,109 @@
|
|||||||
// Sample Arduino Json Web Server
|
// ArduinoJson - arduinojson.org
|
||||||
// Created by Benoit Blanchon.
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// Heavily inspired by "Web Server" from David A. Mellis and Tom Igoe
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to implement an HTTP server that sends JSON document
|
||||||
|
// in the responses.
|
||||||
|
// It uses the Ethernet library but can be easily adapter for Wifi.
|
||||||
|
//
|
||||||
|
// It sends the value of the analog and digital pins.
|
||||||
|
// The JSON document looks like the following:
|
||||||
|
// {
|
||||||
|
// "analog": [ 0, 1, 2, 3, 4, 5 ],
|
||||||
|
// "digital": [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13 ]
|
||||||
|
// }
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
|
|
||||||
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
IPAddress ip(192, 168, 0, 177);
|
|
||||||
EthernetServer server(80);
|
EthernetServer server(80);
|
||||||
|
|
||||||
bool readRequest(EthernetClient& client) {
|
void setup() {
|
||||||
bool currentLineIsBlank = true;
|
// Initialize serial port
|
||||||
while (client.connected()) {
|
Serial.begin(9600);
|
||||||
if (client.available()) {
|
while (!Serial) continue;
|
||||||
char c = client.read();
|
|
||||||
if (c == '\n' && currentLineIsBlank) {
|
// Initialize Ethernet libary
|
||||||
return true;
|
if (!Ethernet.begin(mac)) {
|
||||||
} else if (c == '\n') {
|
Serial.println(F("Failed to initialize Ethernet library"));
|
||||||
currentLineIsBlank = true;
|
return;
|
||||||
} else if (c != '\r') {
|
|
||||||
currentLineIsBlank = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
|
// Start to listen
|
||||||
|
server.begin();
|
||||||
|
|
||||||
|
Serial.println(F("Server is ready."));
|
||||||
|
Serial.print(F("Please connect to http://"));
|
||||||
|
Serial.println(Ethernet.localIP());
|
||||||
}
|
}
|
||||||
|
|
||||||
JsonObject& prepareResponse(JsonBuffer& jsonBuffer) {
|
void loop() {
|
||||||
|
// Wait for an incomming connection
|
||||||
|
EthernetClient client = server.available();
|
||||||
|
|
||||||
|
// Do we have a client?
|
||||||
|
if (!client) return;
|
||||||
|
|
||||||
|
Serial.println(F("New client"));
|
||||||
|
|
||||||
|
// Read the request (we ignore the content in this example)
|
||||||
|
while (client.available()) client.read();
|
||||||
|
|
||||||
|
// Allocate JsonBuffer
|
||||||
|
// Use http://arduinojson.org/assistant/ to compute the right capacity
|
||||||
|
StaticJsonBuffer<500> jsonBuffer;
|
||||||
|
|
||||||
|
// Create the root object
|
||||||
JsonObject& root = jsonBuffer.createObject();
|
JsonObject& root = jsonBuffer.createObject();
|
||||||
|
|
||||||
|
// Create the "analog" array
|
||||||
JsonArray& analogValues = root.createNestedArray("analog");
|
JsonArray& analogValues = root.createNestedArray("analog");
|
||||||
for (int pin = 0; pin < 6; pin++) {
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
|
// Read the analog input
|
||||||
int value = analogRead(pin);
|
int value = analogRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
analogValues.add(value);
|
analogValues.add(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create the "digital" array
|
||||||
JsonArray& digitalValues = root.createNestedArray("digital");
|
JsonArray& digitalValues = root.createNestedArray("digital");
|
||||||
for (int pin = 0; pin < 14; pin++) {
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
|
// Read the digital input
|
||||||
int value = digitalRead(pin);
|
int value = digitalRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
digitalValues.add(value);
|
digitalValues.add(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
return root;
|
Serial.print(F("Sending: "));
|
||||||
}
|
root.printTo(Serial);
|
||||||
|
Serial.println();
|
||||||
|
|
||||||
void writeResponse(EthernetClient& client, JsonObject& json) {
|
// Write response headers
|
||||||
client.println("HTTP/1.1 200 OK");
|
client.println("HTTP/1.0 200 OK");
|
||||||
client.println("Content-Type: application/json");
|
client.println("Content-Type: application/json");
|
||||||
client.println("Connection: close");
|
client.println("Connection: close");
|
||||||
client.println();
|
client.println();
|
||||||
|
|
||||||
json.prettyPrintTo(client);
|
// Write JSON document
|
||||||
|
root.prettyPrintTo(client);
|
||||||
|
|
||||||
|
// Disconnect
|
||||||
|
client.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup() {
|
// See also
|
||||||
Ethernet.begin(mac, ip);
|
// --------
|
||||||
server.begin();
|
//
|
||||||
}
|
// The website arduinojson.org contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
void loop() {
|
// serialization problem.
|
||||||
EthernetClient client = server.available();
|
// Please check it out at: https://arduinojson.org/
|
||||||
if (client) {
|
//
|
||||||
bool success = readRequest(client);
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
if (success) {
|
// It begins with a simple example, then adds more features like serializing
|
||||||
// Use http://arduinojson.org/assistant/ to
|
// directly to a file or an HTTP client.
|
||||||
// compute the right size for the buffer
|
// Please check it out at: https://leanpub.com/arduinojson/
|
||||||
StaticJsonBuffer<500> jsonBuffer;
|
|
||||||
JsonObject& json = prepareResponse(jsonBuffer);
|
|
||||||
writeResponse(client, json);
|
|
||||||
}
|
|
||||||
delay(1);
|
|
||||||
client.stop();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,57 +1,101 @@
|
|||||||
// Send a JSON object on UDP at regular interval
|
// ArduinoJson - arduinojson.org
|
||||||
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
|
// MIT License
|
||||||
//
|
//
|
||||||
// You can easily test this program with netcat:
|
// This example shows how to JSON document to a UDP socket.
|
||||||
// $ nc -ulp 8888
|
// At regular interval, it sends a UDP packet that contains the status of
|
||||||
|
// analog and digital pins.
|
||||||
|
// The JSON document looks like the following:
|
||||||
|
// {
|
||||||
|
// "analog": [ 0, 1, 2, 3, 4, 5 ],
|
||||||
|
// "digital": [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13 ]
|
||||||
|
// }
|
||||||
//
|
//
|
||||||
// by Benoit Blanchon, MIT License 2015-2017
|
// If you want to test this program, you need to be able to receive the UDP
|
||||||
|
// packets.
|
||||||
|
// For example, you can run netcat on your computer
|
||||||
|
// $ ncat -ulp 8888
|
||||||
|
// See https://nmap.org/ncat/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
|
|
||||||
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
IPAddress localIp(192, 168, 0, 177);
|
IPAddress remoteIp(192, 168, 0, 108); // <- EDIT!!!!
|
||||||
IPAddress remoteIp(192, 168, 0, 109);
|
unsigned short remotePort = 8888;
|
||||||
unsigned int remotePort = 8888;
|
unsigned short localPort = 8888;
|
||||||
unsigned localPort = 8888;
|
|
||||||
EthernetUDP udp;
|
EthernetUDP udp;
|
||||||
|
|
||||||
JsonObject& buildJson(JsonBuffer& jsonBuffer) {
|
|
||||||
JsonObject& root = jsonBuffer.createObject();
|
|
||||||
|
|
||||||
JsonArray& analogValues = root.createNestedArray("analog");
|
|
||||||
for (int pin = 0; pin < 6; pin++) {
|
|
||||||
int value = analogRead(pin);
|
|
||||||
analogValues.add(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonArray& digitalValues = root.createNestedArray("digital");
|
|
||||||
for (int pin = 0; pin < 14; pin++) {
|
|
||||||
int value = digitalRead(pin);
|
|
||||||
digitalValues.add(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
return root;
|
|
||||||
}
|
|
||||||
|
|
||||||
void sendJson(JsonObject& json) {
|
|
||||||
udp.beginPacket(remoteIp, remotePort);
|
|
||||||
json.printTo(udp);
|
|
||||||
udp.println();
|
|
||||||
udp.endPacket();
|
|
||||||
}
|
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Ethernet.begin(mac, localIp);
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial) continue;
|
||||||
|
|
||||||
|
// Initialize Ethernet libary
|
||||||
|
if (!Ethernet.begin(mac)) {
|
||||||
|
Serial.println(F("Failed to initialize Ethernet library"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enable UDP
|
||||||
udp.begin(localPort);
|
udp.begin(localPort);
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
delay(1000);
|
// Allocate JsonBuffer
|
||||||
|
// Use http://arduinojson.org/assistant/ to compute the right capacity.
|
||||||
|
StaticJsonBuffer<500> jsonBuffer;
|
||||||
|
|
||||||
// Use http://arduinojson.org/assistant/ to
|
// Create the root object
|
||||||
// compute the right size for the buffer
|
JsonObject& root = jsonBuffer.createObject();
|
||||||
StaticJsonBuffer<300> jsonBuffer;
|
|
||||||
JsonObject& json = buildJson(jsonBuffer);
|
// Create the "analog" array
|
||||||
sendJson(json);
|
JsonArray& analogValues = root.createNestedArray("analog");
|
||||||
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
|
// Read the analog input
|
||||||
|
int value = analogRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
analogValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the "digital" array
|
||||||
|
JsonArray& digitalValues = root.createNestedArray("digital");
|
||||||
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
|
// Read the digital input
|
||||||
|
int value = digitalRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
digitalValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Log
|
||||||
|
Serial.print(F("Sending to "));
|
||||||
|
Serial.print(remoteIp);
|
||||||
|
Serial.print(F(" on port "));
|
||||||
|
Serial.println(remotePort);
|
||||||
|
root.printTo(Serial);
|
||||||
|
|
||||||
|
// Send UDP packet
|
||||||
|
udp.beginPacket(remoteIp, remotePort);
|
||||||
|
root.printTo(udp);
|
||||||
|
udp.println();
|
||||||
|
udp.endPacket();
|
||||||
|
|
||||||
|
// Wait
|
||||||
|
delay(10000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 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
|
||||||
|
// serialization problem.
|
||||||
|
// Please check it out at: https://arduinojson.org/
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
|
// It begins with a simple example, then adds more features like serializing
|
||||||
|
// directly to a file or any stream.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
@ -1,18 +1,19 @@
|
|||||||
// ArduinoJson - arduinojson.org
|
// ArduinoJson - arduinojson.org
|
||||||
// Copyright Benoit Blanchon 2014-2017
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// MIT License
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows the different ways you can use Flash strings with
|
||||||
|
// ArduinoJson.
|
||||||
|
//
|
||||||
|
// Use Flash strings sparingly, because ArduinoJson duplicates them in the
|
||||||
|
// JsonBuffer. Prefer plain old char*, as they are more efficient in term of
|
||||||
|
// code size, speed, and memory usage.
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
// About
|
|
||||||
// -----
|
|
||||||
// This example shows the different ways you can use PROGMEM with ArduinoJson.
|
|
||||||
// Please don't see this as an invitation to use PROGMEM.
|
|
||||||
// On the contrary, you should always use char[] when possible, it's much more
|
|
||||||
// efficient in term of code size, speed and memory usage.
|
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
#ifdef PROGMEM
|
#ifdef PROGMEM // <- check that Flash strings are supported
|
||||||
|
|
||||||
DynamicJsonBuffer jsonBuffer;
|
DynamicJsonBuffer jsonBuffer;
|
||||||
|
|
||||||
// You can use a Flash String as your JSON input.
|
// You can use a Flash String as your JSON input.
|
||||||
@ -51,3 +52,16 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 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 memory
|
||||||
|
// problem.
|
||||||
|
// Please check it out at: https://arduinojson.org/
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a quick C++ course that explains
|
||||||
|
// how your microcontroller stores strings in memory. It also tells why you
|
||||||
|
// should not abuse Flash strings with ArduinoJson.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
@ -1,16 +1,15 @@
|
|||||||
// ArduinoJson - arduinojson.org
|
// ArduinoJson - arduinojson.org
|
||||||
// Copyright Benoit Blanchon 2014-2017
|
// Copyright Benoit Blanchon 2014-2017
|
||||||
// MIT License
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows the different ways you can use String with ArduinoJson.
|
||||||
|
//
|
||||||
|
// Use String objects sparingly, because ArduinoJson duplicates them in the
|
||||||
|
// JsonBuffer. Prefer plain old char[], as they are more efficient in term of
|
||||||
|
// code size, speed, and memory usage.
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
// About
|
|
||||||
// -----
|
|
||||||
// This example shows the different ways you can use String with ArduinoJson.
|
|
||||||
// Please don't see this as an invitation to use String.
|
|
||||||
// On the contrary, you should always use char[] when possible, it's much more
|
|
||||||
// efficient in term of code size, speed and memory usage.
|
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
DynamicJsonBuffer jsonBuffer;
|
DynamicJsonBuffer jsonBuffer;
|
||||||
|
|
||||||
@ -58,3 +57,15 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 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 problem.
|
||||||
|
// Please check it out at: https://arduinojson.org/
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a quick C++ course that explains
|
||||||
|
// how your microcontroller stores strings in memory. On several occasions, it
|
||||||
|
// shows how you can avoid String in your program.
|
||||||
|
// Please check it out at: https://leanpub.com/arduinojson/
|
Reference in New Issue
Block a user