uses BBC micro:bit to measure and display indoor air quality using Bosch BME680 and/or Sensirion SGP30

Dependencies:   microbit

uses Bosch BME680 and/or Sensirion SGP30 sensors to measure indor air quality

sensors should be connected to BBC micro:bit using i2c

commands are received and data is being sent using uBit / nordic radio protocol

display ---

last line always indicates: - first dot: bme680 detected - second dot: sgp30 detected - third dot: sgp 30 setting humidity/temperature - fourth dor: sgp30 measuring - fith dot: bme680 measuring

the detect dots should be in a stable state (not blinking) the measuring dots should be blinking (constant light means: measurement failed)

if only one bme680 is present: - first 3 lines indicate gas resistence (air quality / more dots == worse quality) - fourth line indicates humidity level

if only sgp30 is present: - first two lines indicate SGP30 VOC level - third and fourth line indicate sgp30 CO2 level

if both sensors are present: - first line indicates SGP30 VOC level - second line line indicates sgp30 CO2 level - third line indicates bme680 gas resistence (air quality) - fourth line indicates bme 680 humidity level

buttons - B display state, switches betweeen - full bright - low light - display off

AB reset sgp30 baseline in non volatile storage

data logging -- during measurements the minimum and mximum values for each measured value (temperature, air pressure, humidity,gas resistance, VOC, CO2) are being stored in non volatile storage those (and the last measurement results) are being shown when btn A has been pressed

Committer:
jsa1969
Date:
Thu Mar 21 13:09:58 2019 +0000
Revision:
48:52cad865a84f
Parent:
47:881bfe77a00a
Child:
49:bbb506b58e6e
code cleanup (removed comments)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
jsa1969 0:cef60cc92da0 1 /*
jsa1969 0:cef60cc92da0 2 The MIT License (MIT)
jsa1969 0:cef60cc92da0 3
jsa1969 0:cef60cc92da0 4 Copyright (c) 2016 British Broadcasting Corporation.
jsa1969 0:cef60cc92da0 5 This software is provided by Lancaster University by arrangement with the BBC.
jsa1969 0:cef60cc92da0 6
jsa1969 0:cef60cc92da0 7 Permission is hereby granted, free of charge, to any person obtaining a
jsa1969 0:cef60cc92da0 8 copy of this software and associated documentation files (the "Software"),
jsa1969 0:cef60cc92da0 9 to deal in the Software without restriction, including without limitation
jsa1969 0:cef60cc92da0 10 the rights to use, copy, modify, merge, publish, distribute, sublicense,
jsa1969 0:cef60cc92da0 11 and/or sell copies of the Software, and to permit persons to whom the
jsa1969 0:cef60cc92da0 12 Software is furnished to do so, subject to the following conditions:
jsa1969 0:cef60cc92da0 13
jsa1969 0:cef60cc92da0 14 The above copyright notice and this permission notice shall be included in
jsa1969 0:cef60cc92da0 15 all copies or substantial portions of the Software.
jsa1969 0:cef60cc92da0 16
jsa1969 0:cef60cc92da0 17 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
jsa1969 0:cef60cc92da0 18 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
jsa1969 0:cef60cc92da0 19 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
jsa1969 0:cef60cc92da0 20 THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
jsa1969 0:cef60cc92da0 21 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
jsa1969 0:cef60cc92da0 22 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
jsa1969 0:cef60cc92da0 23 DEALINGS IN THE SOFTWARE.
jsa1969 0:cef60cc92da0 24 */
jsa1969 0:cef60cc92da0 25
jsa1969 0:cef60cc92da0 26 #include "MicroBit.h"
jsa1969 0:cef60cc92da0 27
jsa1969 0:cef60cc92da0 28 #include "bme680.h"
jsa1969 2:544117df8c65 29 #include "sgp30.h"
jsa1969 46:2fed2865a0f3 30 #include "IaqNonVolatileStore.h"
jsa1969 2:544117df8c65 31
jsa1969 1:f9245fb53737 32 #include "physics.h"
jsa1969 0:cef60cc92da0 33
jsa1969 46:2fed2865a0f3 34 #include "MovingAverage.h"
jsa1969 47:881bfe77a00a 35 #include "RangeTransform.h"
jsa1969 46:2fed2865a0f3 36
jsa1969 33:af2dfab24ca9 37 #include "AppSpecificTestrunner.h"
jsa1969 33:af2dfab24ca9 38
jsa1969 0:cef60cc92da0 39 MicroBit uBit;
jsa1969 2:544117df8c65 40 Bme680* bme680 = NULL;
jsa1969 2:544117df8c65 41 struct bme680_field_data* bme680Data = NULL;
jsa1969 2:544117df8c65 42 Sgp30* sgp30 = NULL;
jsa1969 12:96eb06e837f4 43 I2cCallbacks* callbacks = NULL;
jsa1969 46:2fed2865a0f3 44 IaqNonVolatileStore* nvStore = NULL;
jsa1969 12:96eb06e837f4 45
jsa1969 12:96eb06e837f4 46 bool cancelMeasureLoops = false;
jsa1969 12:96eb06e837f4 47 int runningLoops = 0;
jsa1969 20:2f11b93f4cbf 48 int displayState = 0;
jsa1969 0:cef60cc92da0 49
jsa1969 12:96eb06e837f4 50 void waitForLooppsToFinish() {
jsa1969 12:96eb06e837f4 51 cancelMeasureLoops=true;
jsa1969 12:96eb06e837f4 52 while (runningLoops>0) {
jsa1969 12:96eb06e837f4 53 uBit.sleep(10);
jsa1969 12:96eb06e837f4 54 }
jsa1969 12:96eb06e837f4 55 cancelMeasureLoops = false;
jsa1969 12:96eb06e837f4 56 }
jsa1969 0:cef60cc92da0 57
jsa1969 11:6844a5578b4f 58 void displayPixels(int ystart, int pixels, int maxpixels) {
jsa1969 11:6844a5578b4f 59 int y = ystart;
jsa1969 11:6844a5578b4f 60 for (int i=0; i+((y-ystart)*5)<maxpixels; ++i) {
jsa1969 11:6844a5578b4f 61 if (i==5) {
jsa1969 11:6844a5578b4f 62 ++y;
jsa1969 11:6844a5578b4f 63 i=0;
jsa1969 11:6844a5578b4f 64 }
jsa1969 11:6844a5578b4f 65 int pixelsused = i+((y-ystart)*5);
jsa1969 11:6844a5578b4f 66 uBit.display.image.setPixelValue(i, y, pixelsused<pixels? 255 : 0);
jsa1969 10:8e6b71a46871 67 }
jsa1969 10:8e6b71a46871 68 }
jsa1969 48:52cad865a84f 69
jsa1969 1:f9245fb53737 70 int measureBme680(){
jsa1969 38:0f29a0ea64ca 71 int result = BME680_E_DEV_NOT_FOUND;
jsa1969 1:f9245fb53737 72 if (bme680!=NULL && bme680Data!=NULL) {
jsa1969 38:0f29a0ea64ca 73 result = bme680->measure(
jsa1969 1:f9245fb53737 74 bme680Data,
jsa1969 2:544117df8c65 75 bme680Data->temperature==0 ?
jsa1969 2:544117df8c65 76 uBit.thermometer.getTemperature()
jsa1969 45:d6a9fd9c8200 77 : bme680Data->temperature,
jsa1969 38:0f29a0ea64ca 78 2000, 350);
jsa1969 1:f9245fb53737 79 }
jsa1969 38:0f29a0ea64ca 80 return result;
jsa1969 0:cef60cc92da0 81 }
jsa1969 0:cef60cc92da0 82
jsa1969 11:6844a5578b4f 83 void measureAndDisplayBme680() {
jsa1969 11:6844a5578b4f 84 if (bme680!=NULL) {
jsa1969 46:2fed2865a0f3 85 // measuring
jsa1969 11:6844a5578b4f 86 uBit.display.image.setPixelValue(4, 4, 255);
jsa1969 11:6844a5578b4f 87 if (measureBme680()==MICROBIT_OK) {
jsa1969 27:cb75a0c5c52a 88 nvStore->updateGas(bme680Data->gas_resistance, bme680Data->humidity);
jsa1969 17:a2c4dd192146 89 nvStore->updateTemp(bme680Data->temperature);
jsa1969 17:a2c4dd192146 90 nvStore->updatePress(bme680Data->pressure);
jsa1969 17:a2c4dd192146 91 nvStore->updateHumidity(bme680Data->humidity);
jsa1969 17:a2c4dd192146 92
jsa1969 46:2fed2865a0f3 93 const uint32_t gasMax = nvStore->getGasMax(bme680Data->humidity);
jsa1969 46:2fed2865a0f3 94
jsa1969 46:2fed2865a0f3 95 // status (last line: 0 sensor found, 2, stray signals, 4, measuring)
jsa1969 14:71060505061e 96 uBit.display.image.setPixelValue(0, 4, 255);
jsa1969 46:2fed2865a0f3 97 uBit.display.image.setPixelValue(2, 4, nvStore->strayData() || gasMax < bme680Data->gas_resistance ? 255 : 0);
jsa1969 46:2fed2865a0f3 98 // will be set below uBit.display.image.setPixelValue(4, 4, 0);
jsa1969 44:67a19da5f269 99
jsa1969 46:2fed2865a0f3 100 // if sgp 30 exists, we have less room fpr bme680 resukts
jsa1969 47:881bfe77a00a 101 const int bmeY = sgp30 != NULL ? 2 : 0;
jsa1969 47:881bfe77a00a 102 const int bmeMaxPixels = sgp30 != NULL ? 5 : 15;
jsa1969 46:2fed2865a0f3 103
jsa1969 46:2fed2865a0f3 104 // bme 680 gas state
jsa1969 47:881bfe77a00a 105 const int bmeGasPixels = (gasMax - bme680Data->gas_resistance) * bmeMaxPixels / gasMax;
jsa1969 47:881bfe77a00a 106 displayPixels(bmeY, bmeGasPixels, bmeMaxPixels);
jsa1969 46:2fed2865a0f3 107
jsa1969 46:2fed2865a0f3 108 // humidity index
jsa1969 11:6844a5578b4f 109 displayPixels(3, 5*bme680Data->humidity/100000, 5);
jsa1969 14:71060505061e 110 } else {
jsa1969 46:2fed2865a0f3 111 // indicate sensor not working
jsa1969 14:71060505061e 112 uBit.display.image.setPixelValue(0, 4, 0);
jsa1969 2:544117df8c65 113 }
jsa1969 46:2fed2865a0f3 114 // not measuring
jsa1969 12:96eb06e837f4 115 uBit.display.image.setPixelValue(4, 4, 0);
jsa1969 11:6844a5578b4f 116 }
jsa1969 11:6844a5578b4f 117 }
jsa1969 11:6844a5578b4f 118
jsa1969 11:6844a5578b4f 119 void measureAndDisplaySgp30() {
jsa1969 11:6844a5578b4f 120 if (sgp30!=NULL) {
jsa1969 11:6844a5578b4f 121 int sgpMaxPixels = 10;
jsa1969 11:6844a5578b4f 122 int secondLineStart = 2;
jsa1969 11:6844a5578b4f 123 if (bme680!=NULL) {
jsa1969 11:6844a5578b4f 124 sgpMaxPixels = 5;
jsa1969 11:6844a5578b4f 125 secondLineStart = 1;
jsa1969 44:67a19da5f269 126 uBit.display.image.setPixelValue(3, 4, 255);
jsa1969 11:6844a5578b4f 127 if (sgp30->setHumidity(bme680Data->humidity, bme680Data->temperature)) {
jsa1969 44:67a19da5f269 128 uBit.display.image.setPixelValue(3, 4, 0);
jsa1969 11:6844a5578b4f 129 }
jsa1969 11:6844a5578b4f 130 uBit.sleep(10);
jsa1969 11:6844a5578b4f 131 }
jsa1969 11:6844a5578b4f 132 uBit.display.image.setPixelValue(3, 4, 255);
jsa1969 38:0f29a0ea64ca 133 bool measureOK = sgp30->IAQmeasure();
jsa1969 38:0f29a0ea64ca 134 if (measureOK) {
jsa1969 13:996026828be7 135 uBit.display.image.setPixelValue(1, 4, 255);
jsa1969 11:6844a5578b4f 136 uBit.display.image.setPixelValue(3, 4, 0);
jsa1969 18:c4ac93e01027 137
jsa1969 18:c4ac93e01027 138 nvStore->updateVoc(sgp30->TVOC);
jsa1969 18:c4ac93e01027 139 nvStore->updateCo(sgp30->eCO2);
jsa1969 18:c4ac93e01027 140
jsa1969 12:96eb06e837f4 141 int co2Dots = min (5, sgp30->eCO2 /1500);
jsa1969 47:881bfe77a00a 142 displayPixels(0, 5 - RangeTransform::exponentialTransform(sgp30->TVOC, 20000, sgpMaxPixels), sgpMaxPixels);
jsa1969 11:6844a5578b4f 143 displayPixels(secondLineStart, co2Dots, sgpMaxPixels);
jsa1969 13:996026828be7 144 } else {
jsa1969 13:996026828be7 145 uBit.display.image.setPixelValue(1, 4, 0);
jsa1969 11:6844a5578b4f 146 }
jsa1969 2:544117df8c65 147 }
jsa1969 2:544117df8c65 148 }
jsa1969 2:544117df8c65 149
jsa1969 12:96eb06e837f4 150 void bmeMeasureLoop() {
jsa1969 12:96eb06e837f4 151 if (bme680!=NULL) {
jsa1969 12:96eb06e837f4 152 ++runningLoops;
jsa1969 12:96eb06e837f4 153 while (!cancelMeasureLoops){
jsa1969 11:6844a5578b4f 154 measureAndDisplayBme680();
jsa1969 45:d6a9fd9c8200 155 uBit.sleep(500);
jsa1969 12:96eb06e837f4 156 }
jsa1969 12:96eb06e837f4 157 --runningLoops;
jsa1969 12:96eb06e837f4 158 }
jsa1969 24:07a1d2e6914e 159 release_fiber();
jsa1969 12:96eb06e837f4 160 }
jsa1969 12:96eb06e837f4 161
jsa1969 12:96eb06e837f4 162 void sgpMeasureLoop() {
jsa1969 12:96eb06e837f4 163 if (sgp30!=NULL) {
jsa1969 12:96eb06e837f4 164 ++runningLoops;
jsa1969 12:96eb06e837f4 165 while (!cancelMeasureLoops){
jsa1969 11:6844a5578b4f 166 measureAndDisplaySgp30();
jsa1969 12:96eb06e837f4 167 uBit.sleep(950);
jsa1969 2:544117df8c65 168 }
jsa1969 12:96eb06e837f4 169 --runningLoops;
jsa1969 2:544117df8c65 170 }
jsa1969 24:07a1d2e6914e 171 release_fiber();
jsa1969 12:96eb06e837f4 172 }
jsa1969 12:96eb06e837f4 173
jsa1969 34:069c4f6d5b2c 174 void startMeasureLoops() {
jsa1969 12:96eb06e837f4 175 if (runningLoops>0) {
jsa1969 12:96eb06e837f4 176 uBit.display.scroll("already running");
jsa1969 12:96eb06e837f4 177 return;
jsa1969 12:96eb06e837f4 178 }
jsa1969 14:71060505061e 179 create_fiber(sgpMeasureLoop);
jsa1969 12:96eb06e837f4 180 create_fiber(bmeMeasureLoop);
jsa1969 2:544117df8c65 181 }
jsa1969 2:544117df8c65 182
jsa1969 11:6844a5578b4f 183 void init680(){
jsa1969 9:5150afa50eb6 184 if (bme680!=NULL){
jsa1969 9:5150afa50eb6 185 delete bme680;
jsa1969 9:5150afa50eb6 186 }
jsa1969 10:8e6b71a46871 187
jsa1969 27:cb75a0c5c52a 188 uint32_t gasMax = nvStore->getGasMax(0);
jsa1969 11:6844a5578b4f 189 if (gasMax>0) {
jsa1969 11:6844a5578b4f 190 uBit.display.scroll((int)gasMax);
jsa1969 11:6844a5578b4f 191 }
jsa1969 10:8e6b71a46871 192
jsa1969 14:71060505061e 193 bme680 = new Bme680(callbacks);
jsa1969 9:5150afa50eb6 194 int code = bme680->init();
jsa1969 9:5150afa50eb6 195 if (code == MICROBIT_OK){
jsa1969 9:5150afa50eb6 196 if (bme680Data==NULL) {
jsa1969 9:5150afa50eb6 197 bme680Data = new struct bme680_field_data;
jsa1969 9:5150afa50eb6 198 }
jsa1969 9:5150afa50eb6 199 code = bme680->measure(
jsa1969 9:5150afa50eb6 200 bme680Data,
jsa1969 9:5150afa50eb6 201 uBit.thermometer.getTemperature(),
jsa1969 9:5150afa50eb6 202 100, 100);
jsa1969 9:5150afa50eb6 203 }
jsa1969 9:5150afa50eb6 204 if (code != MICROBIT_OK){
jsa1969 9:5150afa50eb6 205 delete bme680;
jsa1969 9:5150afa50eb6 206 bme680 = NULL;
jsa1969 9:5150afa50eb6 207 delete bme680Data;
jsa1969 9:5150afa50eb6 208 bme680Data = NULL;
jsa1969 9:5150afa50eb6 209 uBit.display.scroll(code);
jsa1969 9:5150afa50eb6 210 } else {
jsa1969 9:5150afa50eb6 211 uBit.display.image.setPixelValue(0, 4, 255);
jsa1969 9:5150afa50eb6 212 }
jsa1969 11:6844a5578b4f 213 }
jsa1969 9:5150afa50eb6 214
jsa1969 11:6844a5578b4f 215 void initSgp30(){
jsa1969 9:5150afa50eb6 216 if (sgp30!=NULL){
jsa1969 9:5150afa50eb6 217 delete sgp30;
jsa1969 9:5150afa50eb6 218 }
jsa1969 43:f968ca84d4ed 219 sgp30 = new Sgp30(callbacks);
jsa1969 9:5150afa50eb6 220 if (sgp30->test() && sgp30->begin()) {
jsa1969 9:5150afa50eb6 221 uBit.display.image.setPixelValue(1, 4, 255);
jsa1969 9:5150afa50eb6 222 } else {
jsa1969 9:5150afa50eb6 223 delete sgp30;
jsa1969 9:5150afa50eb6 224 sgp30 = NULL;
jsa1969 40:a67a880cb538 225 }
jsa1969 40:a67a880cb538 226 }
jsa1969 11:6844a5578b4f 227
jsa1969 11:6844a5578b4f 228 void initSensors() {
jsa1969 12:96eb06e837f4 229 waitForLooppsToFinish();
jsa1969 11:6844a5578b4f 230 init680();
jsa1969 11:6844a5578b4f 231 initSgp30();
jsa1969 9:5150afa50eb6 232 }
jsa1969 9:5150afa50eb6 233
jsa1969 12:96eb06e837f4 234 void displayValuesTxt() {
jsa1969 12:96eb06e837f4 235 waitForLooppsToFinish();
jsa1969 8:1bdb50e03d39 236 if (bme680Data!=NULL) {
jsa1969 8:1bdb50e03d39 237 uBit.display.scroll("g");
jsa1969 39:efe22f143e47 238 const int currentGas = (int)bme680Data->gas_resistance;
jsa1969 39:efe22f143e47 239 uBit.display.scroll(currentGas);
jsa1969 8:1bdb50e03d39 240 uBit.display.scroll("+");
jsa1969 38:0f29a0ea64ca 241 const int highGas = (int)nvStore->getGasMax(bme680Data->humidity);
jsa1969 38:0f29a0ea64ca 242 uBit.display.scroll(highGas);
jsa1969 44:67a19da5f269 243 if (nvStore->strayData() || highGas < currentGas) {
jsa1969 46:2fed2865a0f3 244 for (int i=0; i<IaqNonVolatileStore::AVERAGE_BUFFER_SIZE; ++i) {
jsa1969 38:0f29a0ea64ca 245 uBit.display.scroll(":");
jsa1969 38:0f29a0ea64ca 246 uBit.display.scroll((int)nvStore->debugInfo()[i]);
jsa1969 38:0f29a0ea64ca 247 }
jsa1969 38:0f29a0ea64ca 248 }
jsa1969 14:71060505061e 249 uBit.display.scroll("-");
jsa1969 14:71060505061e 250 uBit.display.scroll((int)nvStore->getGasMin());
jsa1969 17:a2c4dd192146 251 uBit.display.scroll("t");
jsa1969 17:a2c4dd192146 252 uBit.display.scroll((int)bme680Data->temperature);
jsa1969 17:a2c4dd192146 253 uBit.display.scroll("+");
jsa1969 17:a2c4dd192146 254 uBit.display.scroll((int)nvStore->getTempMax());
jsa1969 17:a2c4dd192146 255 uBit.display.scroll("-");
jsa1969 17:a2c4dd192146 256 uBit.display.scroll((int)nvStore->getTempMin());
jsa1969 17:a2c4dd192146 257 uBit.display.scroll("p");
jsa1969 17:a2c4dd192146 258 uBit.display.scroll((int)bme680Data->pressure);
jsa1969 17:a2c4dd192146 259 uBit.display.scroll("+");
jsa1969 17:a2c4dd192146 260 uBit.display.scroll((int)nvStore->getPressMax());
jsa1969 17:a2c4dd192146 261 uBit.display.scroll("-");
jsa1969 17:a2c4dd192146 262 uBit.display.scroll((int)nvStore->getPressMin());
jsa1969 17:a2c4dd192146 263 uBit.display.scroll("h");
jsa1969 17:a2c4dd192146 264 uBit.display.scroll((int)bme680Data->humidity);
jsa1969 17:a2c4dd192146 265 uBit.display.scroll("+");
jsa1969 17:a2c4dd192146 266 uBit.display.scroll((int)nvStore->getHumMax());
jsa1969 17:a2c4dd192146 267 uBit.display.scroll("-");
jsa1969 17:a2c4dd192146 268 uBit.display.scroll((int)nvStore->getHumMin());
jsa1969 8:1bdb50e03d39 269 }
jsa1969 17:a2c4dd192146 270
jsa1969 8:1bdb50e03d39 271 if (sgp30!=NULL) {
jsa1969 8:1bdb50e03d39 272 uBit.display.scroll("v");
jsa1969 8:1bdb50e03d39 273 uBit.display.scroll((int)sgp30->TVOC);
jsa1969 18:c4ac93e01027 274 uBit.display.scroll("+");
jsa1969 18:c4ac93e01027 275 uBit.display.scroll((int)nvStore->getVocMax());
jsa1969 8:1bdb50e03d39 276 uBit.display.scroll("c");
jsa1969 8:1bdb50e03d39 277 uBit.display.scroll((int)sgp30->eCO2);
jsa1969 18:c4ac93e01027 278 uBit.display.scroll("+");
jsa1969 18:c4ac93e01027 279 uBit.display.scroll((int)nvStore->getCoMax());
jsa1969 8:1bdb50e03d39 280 }
jsa1969 0:cef60cc92da0 281 }
jsa1969 0:cef60cc92da0 282
jsa1969 12:96eb06e837f4 283 void onButtonA(MicroBitEvent evt)
jsa1969 12:96eb06e837f4 284 {
jsa1969 12:96eb06e837f4 285 if (runningLoops>0) {
jsa1969 12:96eb06e837f4 286 displayValuesTxt();
jsa1969 12:96eb06e837f4 287 } else {
jsa1969 34:069c4f6d5b2c 288 startMeasureLoops();
jsa1969 12:96eb06e837f4 289 }
jsa1969 12:96eb06e837f4 290 }
jsa1969 12:96eb06e837f4 291
jsa1969 12:96eb06e837f4 292 void onButtonB(MicroBitEvent evt)
jsa1969 12:96eb06e837f4 293 {
jsa1969 20:2f11b93f4cbf 294 switch (++displayState) {
jsa1969 20:2f11b93f4cbf 295 case 1:
jsa1969 20:2f11b93f4cbf 296 uBit.display.setBrightness(5);
jsa1969 20:2f11b93f4cbf 297 break;
jsa1969 20:2f11b93f4cbf 298 case 2:
jsa1969 20:2f11b93f4cbf 299 uBit.display.disable();
jsa1969 20:2f11b93f4cbf 300 break;
jsa1969 20:2f11b93f4cbf 301 default:
jsa1969 20:2f11b93f4cbf 302 uBit.display.setBrightness(255);
jsa1969 20:2f11b93f4cbf 303 uBit.display.enable();
jsa1969 20:2f11b93f4cbf 304 displayState = 0;
jsa1969 20:2f11b93f4cbf 305 }
jsa1969 12:96eb06e837f4 306 }
jsa1969 12:96eb06e837f4 307
jsa1969 9:5150afa50eb6 308 void onButtonAB(MicroBitEvent evt)
jsa1969 9:5150afa50eb6 309 {
jsa1969 19:52e19461e867 310 waitForLooppsToFinish();
jsa1969 46:2fed2865a0f3 311 nvStore->clear();
jsa1969 19:52e19461e867 312 uBit.display.scroll("clear");
jsa1969 9:5150afa50eb6 313 }
jsa1969 9:5150afa50eb6 314
jsa1969 34:069c4f6d5b2c 315 const char* runSofwareModuleTests() {
jsa1969 48:52cad865a84f 316 // heap we've got plenty, stack is rare
jsa1969 33:af2dfab24ca9 317 AppSpecificTestrunner* runner = new AppSpecificTestrunner();
jsa1969 33:af2dfab24ca9 318 const char* result = runner->runAll();
jsa1969 33:af2dfab24ca9 319 delete runner;
jsa1969 33:af2dfab24ca9 320 return result;
jsa1969 33:af2dfab24ca9 321 }
jsa1969 33:af2dfab24ca9 322
jsa1969 0:cef60cc92da0 323 int main()
jsa1969 0:cef60cc92da0 324 {
jsa1969 0:cef60cc92da0 325 uBit.init();
jsa1969 0:cef60cc92da0 326
jsa1969 0:cef60cc92da0 327 uBit.messageBus.listen(MICROBIT_ID_BUTTON_A, MICROBIT_BUTTON_EVT_CLICK, onButtonA);
jsa1969 0:cef60cc92da0 328 uBit.messageBus.listen(MICROBIT_ID_BUTTON_B, MICROBIT_BUTTON_EVT_CLICK, onButtonB);
jsa1969 9:5150afa50eb6 329 uBit.messageBus.listen(MICROBIT_ID_BUTTON_AB, MICROBIT_BUTTON_EVT_CLICK, onButtonAB);
jsa1969 2:544117df8c65 330
jsa1969 46:2fed2865a0f3 331 callbacks = new I2cCallbacks(&uBit);
jsa1969 46:2fed2865a0f3 332 nvStore = new IaqNonVolatileStore(&uBit);
jsa1969 33:af2dfab24ca9 333
jsa1969 46:2fed2865a0f3 334 uBit.display.scroll("t");
jsa1969 34:069c4f6d5b2c 335 const char* testResults = runSofwareModuleTests();
jsa1969 33:af2dfab24ca9 336 if (! Testrunner::messageOK(testResults)) {
jsa1969 33:af2dfab24ca9 337 uBit.display.scroll(testResults);
jsa1969 33:af2dfab24ca9 338 return -1;
jsa1969 33:af2dfab24ca9 339 }
jsa1969 46:2fed2865a0f3 340
jsa1969 34:069c4f6d5b2c 341 // includes hardware tests
jsa1969 9:5150afa50eb6 342 initSensors();
jsa1969 9:5150afa50eb6 343
jsa1969 34:069c4f6d5b2c 344 startMeasureLoops();
jsa1969 2:544117df8c65 345
jsa1969 0:cef60cc92da0 346 release_fiber();
jsa1969 0:cef60cc92da0 347 }
jsa1969 0:cef60cc92da0 348