1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-01-10 00:46:09 +01:00
Arduino/libraries/Bridge/examples/SpacebrewYun/inputOutput/inputOutput.ino

133 lines
3.2 KiB
Arduino
Raw Normal View History

2013-08-07 17:16:13 +02:00
/*
Input Output
Demonstrates how to create a sketch that sends and receives all standard
2014-04-01 09:35:56 +02:00
spacebrew data types, and a custom data type. Every time data is
2013-08-07 17:16:13 +02:00
received it is output to the Serial monitor.
2014-05-30 12:17:09 +02:00
Make sure that your Yún is connected to the internet for this example
2013-08-07 17:16:13 +02:00
to function properly.
2014-04-01 09:35:56 +02:00
2013-08-07 17:16:13 +02:00
The circuit:
- No circuit required
2014-04-01 09:35:56 +02:00
2013-08-07 17:16:13 +02:00
created 2013
by Julio Terra
2014-04-01 09:35:56 +02:00
2013-08-07 17:16:13 +02:00
This example code is in the public domain.
2014-04-01 09:35:56 +02:00
More information about Spacebrew is available at:
2013-08-07 17:16:13 +02:00
http://spacebrew.cc/
2014-04-01 09:35:56 +02:00
2013-08-07 17:16:13 +02:00
*/
2013-07-18 14:07:39 +02:00
#include <Bridge.h>
#include <SpacebrewYun.h>
2013-08-07 17:16:13 +02:00
// create a variable of type SpacebrewYun and initialize it with the constructor
2013-07-18 14:07:39 +02:00
SpacebrewYun sb = SpacebrewYun("aYun", "Arduino Yun spacebrew test");
2013-08-07 17:16:13 +02:00
// create variables to manage interval between each time we send a string
2013-07-18 14:07:39 +02:00
long last = 0;
int interval = 2000;
2013-08-07 17:16:13 +02:00
int counter = 0;
2014-04-01 09:35:56 +02:00
void setup() {
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
// start the serial port
Serial.begin(57600);
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
// for debugging, wait until a serial console is connected
delay(4000);
while (!Serial) { ; }
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
// start-up the bridge
Bridge.begin();
2013-08-07 17:16:13 +02:00
2014-04-01 09:35:56 +02:00
// configure the spacebrew object to print status messages to serial
sb.verbose(true);
2013-08-07 17:16:13 +02:00
2014-04-01 09:35:56 +02:00
// configure the spacebrew publisher and subscriber
sb.addPublish("string test", "string");
sb.addPublish("range test", "range");
sb.addPublish("boolean test", "boolean");
sb.addPublish("custom test", "crazy");
sb.addSubscribe("string test", "string");
sb.addSubscribe("range test", "range");
sb.addSubscribe("boolean test", "boolean");
sb.addSubscribe("custom test", "crazy");
2013-08-07 17:16:13 +02:00
2014-04-01 09:35:56 +02:00
// register the string message handler method
sb.onRangeMessage(handleRange);
sb.onStringMessage(handleString);
sb.onBooleanMessage(handleBoolean);
sb.onCustomMessage(handleCustom);
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
// connect to cloud spacebrew server at "sandbox.spacebrew.cc"
sb.connect("sandbox.spacebrew.cc");
// we give some time to arduino to connect to sandbox, otherwise the first sb.monitor(); call will give an error
delay(1000);
}
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
void loop() {
// monitor spacebrew connection for new data
sb.monitor();
2013-08-07 17:16:13 +02:00
2014-04-01 09:35:56 +02:00
// connected to spacebrew then send a string every 2 seconds
if ( sb.connected() ) {
2013-08-07 17:16:13 +02:00
2014-04-01 09:35:56 +02:00
// check if it is time to send a new message
if ( (millis() - last) > interval ) {
String test_str_msg = "testing, testing, ";
test_str_msg += counter;
counter ++;
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
sb.send("string test", test_str_msg);
sb.send("range test", 500);
sb.send("boolean test", true);
sb.send("custom test", "youre loco");
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
last = millis();
2013-07-18 14:07:39 +02:00
2014-04-01 09:35:56 +02:00
}
}
delay(1000);
}
2013-07-18 14:07:39 +02:00
2013-08-07 17:16:13 +02:00
// define handler methods, all standard data type handlers take two appropriate arguments
2013-07-18 14:07:39 +02:00
void handleRange (String route, int value) {
2014-04-01 09:35:56 +02:00
Serial.print("Range msg ");
Serial.print(route);
Serial.print(", value ");
Serial.println(value);
2013-07-18 14:07:39 +02:00
}
void handleString (String route, String value) {
2014-04-01 09:35:56 +02:00
Serial.print("String msg ");
Serial.print(route);
Serial.print(", value ");
Serial.println(value);
2013-07-18 14:07:39 +02:00
}
void handleBoolean (String route, boolean value) {
2014-04-01 09:35:56 +02:00
Serial.print("Boolen msg ");
Serial.print(route);
Serial.print(", value ");
Serial.println(value ? "true" : "false");
2013-07-18 14:07:39 +02:00
}
2013-08-07 17:16:13 +02:00
// custom data type handlers takes three String arguments
2013-07-18 14:07:39 +02:00
void handleCustom (String route, String value, String type) {
2014-04-01 09:35:56 +02:00
Serial.print("Custom msg ");
Serial.print(route);
Serial.print(" of type ");
Serial.print(type);
Serial.print(", value ");
Serial.println(value);
2013-07-18 14:07:39 +02:00
}