Uses *spark d-fuser controller hardware as a USB-DMX interface. Developed for visualising Laurel Pardue’s augmented violin with lights.

Dependencies:   DMX mbed spk_oled_ssd1305

Committer:
tobyspark
Date:
Wed May 18 15:28:17 2016 +0000
Revision:
6:cd5846520ea6
Parent:
5:1fe29795851a
Child:
7:7f3140672370
Removed vestigial commented code

Who changed what in which revision?

UserRevisionLine numberNew contents of line
tobyspark 0:59b1d685427c 1 #include "mbed.h"
tobyspark 0:59b1d685427c 2 #include "DMX.h"
tobyspark 0:59b1d685427c 3 #include "spk_oled_ssd1305.h"
tobyspark 0:59b1d685427c 4 #include "spk_oled_gfx.h"
tobyspark 0:59b1d685427c 5
tobyspark 1:f0cc153fe8d3 6 // https://developer.mbed.org/forum/mbed/post/4526/
tobyspark 1:f0cc153fe8d3 7 // 110, 300, 600, 1200, 2400, 4800, 9600, 14400, 19200, 38400, 57600, 115200, 230400, 460800, 921600
tobyspark 0:59b1d685427c 8 #define kUSB_BAUD 57600
tobyspark 0:59b1d685427c 9
tobyspark 0:59b1d685427c 10 // MBED PINS
tobyspark 0:59b1d685427c 11
tobyspark 0:59b1d685427c 12 #define kMBED_AIN_XFADE p20
tobyspark 0:59b1d685427c 13 #define kMBED_AIN_FADEUP p19
tobyspark 0:59b1d685427c 14 #define kMBED_DIN_TAP_L p24
tobyspark 0:59b1d685427c 15 #define kMBED_DIN_TAP_R p23
tobyspark 0:59b1d685427c 16 #define kMBED_ENC_SW p15
tobyspark 0:59b1d685427c 17 #define kMBED_ENC_A p16
tobyspark 0:59b1d685427c 18 #define kMBED_ENC_B p17
tobyspark 0:59b1d685427c 19
tobyspark 0:59b1d685427c 20 #define kMBED_RS232_TTLTX p13
tobyspark 0:59b1d685427c 21 #define kMBED_RS232_TTLRX p14
tobyspark 0:59b1d685427c 22
tobyspark 0:59b1d685427c 23 #define kMBED_OLED_MOSI p5
tobyspark 0:59b1d685427c 24 #define kMBED_OLED_SCK p7
tobyspark 0:59b1d685427c 25 #define kMBED_OLED_CS p8
tobyspark 0:59b1d685427c 26 #define kMBED_OLED_RES p9
tobyspark 0:59b1d685427c 27 #define kMBED_OLED_DC p10
tobyspark 0:59b1d685427c 28
tobyspark 0:59b1d685427c 29 #define kMBED_DIN_ETHLO_DMXHI p30
tobyspark 0:59b1d685427c 30 #define kMBED_DOUT_RS485_TXHI_RXLO p29
tobyspark 0:59b1d685427c 31 #define kMBED_RS485_TTLTX p28
tobyspark 0:59b1d685427c 32 #define kMBED_RS485_TTLRX p27
tobyspark 0:59b1d685427c 33
tobyspark 0:59b1d685427c 34 // DMX Fixtures
tobyspark 0:59b1d685427c 35
tobyspark 4:c8b23ce175f4 36 #define kDMX_PARCAN_1 8 - 1
tobyspark 4:c8b23ce175f4 37 #define kDMX_PARCAN_2 12 - 1
tobyspark 4:c8b23ce175f4 38 #define kDMX_PARCAN_3 16 - 1
tobyspark 4:c8b23ce175f4 39 #define kDMX_PARCAN_4 20 - 1
tobyspark 0:59b1d685427c 40
tobyspark 5:1fe29795851a 41 #define kDMX_PARCAN_LUMA 0
tobyspark 5:1fe29795851a 42 #define kDMX_PARCAN_R 1
tobyspark 5:1fe29795851a 43 #define kDMX_PARCAN_G 2
tobyspark 5:1fe29795851a 44 #define kDMX_PARCAN_B 3
tobyspark 0:59b1d685427c 45
tobyspark 5:1fe29795851a 46 #define kDMX_SPOT_DIMMER 32 - 1
tobyspark 3:642cd9d00b69 47
tobyspark 2:24d9b7a3073c 48 #define kDMX_HAZER_HAZE 128
tobyspark 2:24d9b7a3073c 49 #define kDMX_HAZER_FAN 129
tobyspark 2:24d9b7a3073c 50
tobyspark 0:59b1d685427c 51 // MISC Defines
tobyspark 0:59b1d685427c 52
tobyspark 0:59b1d685427c 53 #define kStringBufferLength 30
tobyspark 1:f0cc153fe8d3 54 #define kUSBSerialBufferLength 256
tobyspark 0:59b1d685427c 55
tobyspark 0:59b1d685427c 56 //// USB Serial
tobyspark 0:59b1d685427c 57
tobyspark 0:59b1d685427c 58 Serial usbSerial(USBTX, USBRX);
tobyspark 0:59b1d685427c 59
tobyspark 0:59b1d685427c 60 //// DMX
tobyspark 0:59b1d685427c 61
tobyspark 0:59b1d685427c 62 DigitalIn rj45ModeDIN(kMBED_DIN_ETHLO_DMXHI);
tobyspark 0:59b1d685427c 63 DigitalOut dmxDirectionDOUT(kMBED_DOUT_RS485_TXHI_RXLO);
tobyspark 0:59b1d685427c 64 enum { rj45Ethernet = 0, rj45DMX = 1}; // These values from circuit
tobyspark 0:59b1d685427c 65
tobyspark 0:59b1d685427c 66 DMX dmx(kMBED_RS485_TTLTX, kMBED_RS485_TTLRX);
tobyspark 0:59b1d685427c 67
tobyspark 0:59b1d685427c 68 //// Display
tobyspark 0:59b1d685427c 69
tobyspark 0:59b1d685427c 70 // SPKDisplay(PinName mosi, PinName clk, PinName cs, PinName dc, PinName res, Serial *debugSerial = NULL);
tobyspark 0:59b1d685427c 71 SPKDisplay screen(kMBED_OLED_MOSI, kMBED_OLED_SCK, kMBED_OLED_CS, kMBED_OLED_DC, kMBED_OLED_RES, NULL);
tobyspark 0:59b1d685427c 72
tobyspark 0:59b1d685427c 73 //// mbed input
tobyspark 0:59b1d685427c 74
tobyspark 0:59b1d685427c 75 DigitalIn button(kMBED_DIN_TAP_L);
tobyspark 2:24d9b7a3073c 76 DigitalIn buttonR(kMBED_DIN_TAP_R);
tobyspark 0:59b1d685427c 77 bool buttonLastState;
tobyspark 0:59b1d685427c 78
tobyspark 1:f0cc153fe8d3 79 char usbSerialBuffer[kUSBSerialBufferLength];
tobyspark 1:f0cc153fe8d3 80 int usbSerialBufferPosition = 0;
tobyspark 3:642cd9d00b69 81 bool newStringData = false;
tobyspark 3:642cd9d00b69 82 bool newBowData = false;
tobyspark 0:59b1d685427c 83
tobyspark 0:59b1d685427c 84 //// LAUREL VIOLIN DATA
tobyspark 0:59b1d685427c 85
tobyspark 0:59b1d685427c 86 // [T: A, B] - T = timestamp. A is the time count (in minutes or something. Not presently very useful), B is sample count. I can change what is creating the stamp. Also, as I'm using sample count, this is only useful/changes when I record.
tobyspark 0:59b1d685427c 87 int TA, TB;
tobyspark 0:59b1d685427c 88
tobyspark 0:59b1d685427c 89 // [P: A, B] - P = pitch. A is hardware estimate- i.e the pitch estimate that is determined solely from the fingerboard data. B is the combined hardware + audio data (more accurate, slightly slower). -1 = no data/not confident enough to estimate
tobyspark 0:59b1d685427c 90 float P1A, P1B, P2A, P2B, P3A, P3B, P4A, P4B;
tobyspark 0:59b1d685427c 91
tobyspark 0:59b1d685427c 92 // [S: A] = signal strength. A is RMS of audio signal in the buffer.
tobyspark 0:59b1d685427c 93 float S1, S2, S3, S4;
tobyspark 0:59b1d685427c 94
tobyspark 0:59b1d685427c 95 // [F: A, B, C, D] = finger on string raw data. generally ranges 1 (no contact) to like .4, 1 being no string down, .9 being low pitch near nut, .4 higher up in pitch closer to the bridge. A is G string (i think)
tobyspark 0:59b1d685427c 96 float F1, F2, F3, F4;
tobyspark 0:59b1d685427c 97
tobyspark 0:59b1d685427c 98 // [B: A, B, C, D] = raw bow data, A is sensor closest to frog, D closest to tip.
tobyspark 0:59b1d685427c 99 float B1, B2, B3, B4;
tobyspark 0:59b1d685427c 100
tobyspark 0:59b1d685427c 101 // [E: A, B, C] = bow Estimate. (currently broken) This should be A - pos estimate (0 to 1 normalized frog to tip), B- pressure (0 -400?) and C- on string/off (0, 1 if B is > 40) 0 for A/B means it isn't ready to estimate. -1 means bow off string.
tobyspark 0:59b1d685427c 102 float EA, EB;
tobyspark 0:59b1d685427c 103 int EC;
tobyspark 0:59b1d685427c 104
tobyspark 0:59b1d685427c 105 // TOBY VIOLIN EXTRAS
tobyspark 0:59b1d685427c 106
tobyspark 4:c8b23ce175f4 107 float sMaxFixed = 0.1;
tobyspark 2:24d9b7a3073c 108 float sMultiplier = 255.0/sMaxFixed;
tobyspark 2:24d9b7a3073c 109
tobyspark 3:642cd9d00b69 110 float eMaxFixed = 400;
tobyspark 3:642cd9d00b69 111 float eMultiplier = 255.0/eMaxFixed;
tobyspark 3:642cd9d00b69 112
tobyspark 2:24d9b7a3073c 113 void testDMX()
tobyspark 2:24d9b7a3073c 114 {
tobyspark 2:24d9b7a3073c 115 static char state = 1;
tobyspark 2:24d9b7a3073c 116
tobyspark 3:642cd9d00b69 117 if (state == 5)
tobyspark 3:642cd9d00b69 118 {
tobyspark 3:642cd9d00b69 119 dmx.put(kDMX_SPOT_DIMMER, 255);
tobyspark 3:642cd9d00b69 120 }
tobyspark 3:642cd9d00b69 121 else
tobyspark 2:24d9b7a3073c 122 {
tobyspark 3:642cd9d00b69 123 dmx.put(kDMX_SPOT_DIMMER, 0);
tobyspark 3:642cd9d00b69 124
tobyspark 3:642cd9d00b69 125 int address;
tobyspark 3:642cd9d00b69 126
tobyspark 3:642cd9d00b69 127 switch (state)
tobyspark 3:642cd9d00b69 128 {
tobyspark 3:642cd9d00b69 129 case 1: address = kDMX_PARCAN_1; break;
tobyspark 3:642cd9d00b69 130 case 2: address = kDMX_PARCAN_2; break;
tobyspark 3:642cd9d00b69 131 case 3: address = kDMX_PARCAN_3; break;
tobyspark 3:642cd9d00b69 132 case 4: address = kDMX_PARCAN_4; break;
tobyspark 3:642cd9d00b69 133 }
tobyspark 3:642cd9d00b69 134
tobyspark 3:642cd9d00b69 135 unsigned char parCanData[4];
tobyspark 3:642cd9d00b69 136 parCanData[kDMX_PARCAN_R] = 255;
tobyspark 3:642cd9d00b69 137 parCanData[kDMX_PARCAN_G] = 255;
tobyspark 3:642cd9d00b69 138 parCanData[kDMX_PARCAN_B] = 255;
tobyspark 3:642cd9d00b69 139 parCanData[kDMX_PARCAN_LUMA] = 0;
tobyspark 3:642cd9d00b69 140 dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 3:642cd9d00b69 141 dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 3:642cd9d00b69 142 dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 3:642cd9d00b69 143 dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 3:642cd9d00b69 144
tobyspark 3:642cd9d00b69 145 parCanData[kDMX_PARCAN_LUMA] = 255;
tobyspark 3:642cd9d00b69 146 dmx.put(parCanData, address, 4);
tobyspark 2:24d9b7a3073c 147 }
tobyspark 2:24d9b7a3073c 148
tobyspark 3:642cd9d00b69 149 if (++state > 5) state = 1;
tobyspark 2:24d9b7a3073c 150 }
tobyspark 2:24d9b7a3073c 151
tobyspark 2:24d9b7a3073c 152 inline void processData()
tobyspark 2:24d9b7a3073c 153 {
tobyspark 2:24d9b7a3073c 154 float sMax = S1;
tobyspark 2:24d9b7a3073c 155 if (sMax < S2) sMax = S2;
tobyspark 2:24d9b7a3073c 156 if (sMax < S3) sMax = S3;
tobyspark 2:24d9b7a3073c 157 if (sMax < S4) sMax = S4;
tobyspark 2:24d9b7a3073c 158
tobyspark 2:24d9b7a3073c 159 float threshold = sMax * 0.7;
tobyspark 2:24d9b7a3073c 160
tobyspark 2:24d9b7a3073c 161 if (S1 < threshold) S1 = 0;
tobyspark 2:24d9b7a3073c 162 if (S2 < threshold) S2 = 0;
tobyspark 2:24d9b7a3073c 163 if (S3 < threshold) S3 = 0;
tobyspark 2:24d9b7a3073c 164 if (S4 < threshold) S4 = 0;
tobyspark 2:24d9b7a3073c 165 }
tobyspark 0:59b1d685427c 166
tobyspark 0:59b1d685427c 167 void usbSerialReceive(void)
tobyspark 0:59b1d685427c 168 {
tobyspark 0:59b1d685427c 169 char receivedChar;
tobyspark 0:59b1d685427c 170
tobyspark 0:59b1d685427c 171 //if data is ready in the buffer
tobyspark 0:59b1d685427c 172 while (usbSerial.readable())
tobyspark 0:59b1d685427c 173 {
tobyspark 0:59b1d685427c 174 receivedChar = usbSerial.getc();
tobyspark 0:59b1d685427c 175
tobyspark 0:59b1d685427c 176 // Is end of line?
tobyspark 0:59b1d685427c 177 if (receivedChar == '\n' || receivedChar == '\r')
tobyspark 0:59b1d685427c 178 {
tobyspark 0:59b1d685427c 179 // [T: 352, 16896000],[P: 196, -1, 196, -1, 196, -1, 196, -1],[S: 0, 0, 0, 0],[F: 1, 1, 1, 1],[B: 0.5346, 0.5781, 0.9043, 0.9029],[E: 0, 0, 0]
tobyspark 0:59b1d685427c 180 int scanCount;
tobyspark 0:59b1d685427c 181 // scanCount = sscanf(
tobyspark 0:59b1d685427c 182 // usbSerialString.c_str(),
tobyspark 0:59b1d685427c 183 // "[T: %d, %d],[P: %f, %f, %f, %f, %f, %f, %f, %f],[S: %f, %f, %f, %f],[F: %f, %f, %f, %f],[B: %f, %f, %f, %f],[E: %f, %f, %d]",
tobyspark 0:59b1d685427c 184 // &TA, &TB, &P1A, &P1B, &P2A, &P2B, &P3A, &P3B, &P4A, &P4B, &S1, &S2, &S3, &S4, &F1, &F2, &F3, &F4, &B1, &B2, &B3, &B4, &EA, &EB, &EC
tobyspark 0:59b1d685427c 185 // );
tobyspark 0:59b1d685427c 186 // if (scanCount == 25)
tobyspark 0:59b1d685427c 187 scanCount = sscanf(
tobyspark 1:f0cc153fe8d3 188 usbSerialBuffer,
tobyspark 0:59b1d685427c 189 "[S: %f, %f, %f, %f],[E: %f, %f, %d]",
tobyspark 0:59b1d685427c 190 &S1, &S2, &S3, &S4, &EA, &EB, &EC
tobyspark 0:59b1d685427c 191 );
tobyspark 0:59b1d685427c 192
tobyspark 0:59b1d685427c 193 if (scanCount == 7)
tobyspark 0:59b1d685427c 194 {
tobyspark 3:642cd9d00b69 195 newStringData = true;
tobyspark 3:642cd9d00b69 196 newBowData = true;
tobyspark 2:24d9b7a3073c 197 processData();
tobyspark 2:24d9b7a3073c 198 }
tobyspark 2:24d9b7a3073c 199 else if (scanCount == 4)
tobyspark 2:24d9b7a3073c 200 {
tobyspark 3:642cd9d00b69 201 newStringData = true;
tobyspark 2:24d9b7a3073c 202 processData();
tobyspark 0:59b1d685427c 203 }
tobyspark 0:59b1d685427c 204 else
tobyspark 0:59b1d685427c 205 {
tobyspark 0:59b1d685427c 206 screen.textToBuffer("Read vars failed", 6);
tobyspark 0:59b1d685427c 207 }
tobyspark 0:59b1d685427c 208
tobyspark 0:59b1d685427c 209 // Clear to start again
tobyspark 1:f0cc153fe8d3 210 usbSerialBufferPosition = 0;
tobyspark 0:59b1d685427c 211 }
tobyspark 1:f0cc153fe8d3 212 else if (usbSerialBufferPosition < kUSBSerialBufferLength)
tobyspark 0:59b1d685427c 213 {
tobyspark 0:59b1d685427c 214 // Build string up
tobyspark 1:f0cc153fe8d3 215 usbSerialBuffer[usbSerialBufferPosition++] = receivedChar;
tobyspark 1:f0cc153fe8d3 216 usbSerialBuffer[usbSerialBufferPosition] = 0;
tobyspark 0:59b1d685427c 217
tobyspark 1:f0cc153fe8d3 218 screen.textToBuffer(usbSerialBuffer,4);
tobyspark 0:59b1d685427c 219 }
tobyspark 0:59b1d685427c 220 }
tobyspark 0:59b1d685427c 221 }
tobyspark 0:59b1d685427c 222
tobyspark 0:59b1d685427c 223 //// M A I N
tobyspark 0:59b1d685427c 224 int main() {
tobyspark 0:59b1d685427c 225
tobyspark 0:59b1d685427c 226 // Set display font
tobyspark 0:59b1d685427c 227 screen.fontStartCharacter = &characterBytesStartChar;
tobyspark 0:59b1d685427c 228 screen.fontEndCharacter = &characterBytesEndChar;
tobyspark 0:59b1d685427c 229 screen.fontCharacters = characterBytes;
tobyspark 0:59b1d685427c 230
tobyspark 0:59b1d685427c 231 // Splash screen
tobyspark 0:59b1d685427c 232 screen.imageToBuffer(spkDisplayLogo);
tobyspark 0:59b1d685427c 233 screen.textToBuffer("SPK:DMXer",0);
tobyspark 0:59b1d685427c 234 screen.textToBuffer("FRATRES 2015",1);
tobyspark 0:59b1d685427c 235 screen.textToBuffer("SW v01",2);
tobyspark 0:59b1d685427c 236 screen.sendBuffer();
tobyspark 0:59b1d685427c 237
tobyspark 0:59b1d685427c 238 if (rj45ModeDIN == rj45DMX) screen.textToBuffer("RJ45: DMX Mode", 3);
tobyspark 0:59b1d685427c 239 else screen.textToBuffer("RJ45: Ethernet Mode", 3);
tobyspark 0:59b1d685427c 240 screen.sendBuffer();
tobyspark 0:59b1d685427c 241
tobyspark 0:59b1d685427c 242 dmxDirectionDOUT = 1;
tobyspark 0:59b1d685427c 243 dmx.start();
tobyspark 0:59b1d685427c 244
tobyspark 0:59b1d685427c 245 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 246 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 247 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 248 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 249
tobyspark 0:59b1d685427c 250 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 251 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 252 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 253 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 254
tobyspark 0:59b1d685427c 255 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 256 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 257 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 258 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 259
tobyspark 0:59b1d685427c 260 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 261 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 262 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 263 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 264
tobyspark 0:59b1d685427c 265 //// Serial
tobyspark 0:59b1d685427c 266 usbSerial.baud(kUSB_BAUD);
tobyspark 0:59b1d685427c 267 usbSerial.attach(usbSerialReceive);
tobyspark 0:59b1d685427c 268
tobyspark 0:59b1d685427c 269 //// TASK: Prime button change detection
tobyspark 0:59b1d685427c 270 buttonLastState = button;
tobyspark 0:59b1d685427c 271
tobyspark 0:59b1d685427c 272 //// TASK: GO!
tobyspark 0:59b1d685427c 273
tobyspark 0:59b1d685427c 274 // We've finished setting up, now loop this forever...
tobyspark 0:59b1d685427c 275 while (true)
tobyspark 0:59b1d685427c 276 {
tobyspark 3:642cd9d00b69 277 if (newStringData)
tobyspark 0:59b1d685427c 278 {
tobyspark 0:59b1d685427c 279 char S1DMX = S1 * sMultiplier;
tobyspark 0:59b1d685427c 280 char S2DMX = S2 * sMultiplier;
tobyspark 0:59b1d685427c 281 char S3DMX = S3 * sMultiplier;
tobyspark 0:59b1d685427c 282 char S4DMX = S4 * sMultiplier;
tobyspark 2:24d9b7a3073c 283
tobyspark 2:24d9b7a3073c 284 unsigned char parCanData[4];
tobyspark 2:24d9b7a3073c 285 parCanData[kDMX_PARCAN_R] = 255;
tobyspark 2:24d9b7a3073c 286 parCanData[kDMX_PARCAN_G] = 255;
tobyspark 2:24d9b7a3073c 287 parCanData[kDMX_PARCAN_B] = 255;
tobyspark 2:24d9b7a3073c 288
tobyspark 2:24d9b7a3073c 289 parCanData[kDMX_PARCAN_LUMA] = S1DMX;
tobyspark 2:24d9b7a3073c 290 dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 2:24d9b7a3073c 291
tobyspark 2:24d9b7a3073c 292 parCanData[kDMX_PARCAN_LUMA] = S2DMX;
tobyspark 2:24d9b7a3073c 293 dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 2:24d9b7a3073c 294
tobyspark 2:24d9b7a3073c 295 parCanData[kDMX_PARCAN_LUMA] = S3DMX;
tobyspark 2:24d9b7a3073c 296 dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 2:24d9b7a3073c 297
tobyspark 2:24d9b7a3073c 298 parCanData[kDMX_PARCAN_LUMA] = S4DMX;
tobyspark 2:24d9b7a3073c 299 dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 0:59b1d685427c 300
tobyspark 0:59b1d685427c 301 char dmxSummary[kStringBufferLength];
tobyspark 0:59b1d685427c 302 snprintf(dmxSummary, kStringBufferLength, "S %03u %03u %03u %03u", S1DMX, S2DMX, S3DMX, S4DMX);
tobyspark 0:59b1d685427c 303 screen.textToBuffer(dmxSummary,6);
tobyspark 0:59b1d685427c 304
tobyspark 3:642cd9d00b69 305 newStringData = false;
tobyspark 3:642cd9d00b69 306 }
tobyspark 3:642cd9d00b69 307
tobyspark 3:642cd9d00b69 308 if (newBowData)
tobyspark 3:642cd9d00b69 309 {
tobyspark 3:642cd9d00b69 310 if (EB < 0) EB = 0;
tobyspark 3:642cd9d00b69 311 char bowDMX = EB * eMultiplier;
tobyspark 3:642cd9d00b69 312 dmx.put(kDMX_SPOT_DIMMER, bowDMX);
tobyspark 0:59b1d685427c 313 }
tobyspark 0:59b1d685427c 314
tobyspark 0:59b1d685427c 315 // Has the button changed?
tobyspark 0:59b1d685427c 316 if (button != buttonLastState) {
tobyspark 0:59b1d685427c 317 // If so, lets update the lastState variable and then send an OSC message
tobyspark 0:59b1d685427c 318 buttonLastState = button;
tobyspark 0:59b1d685427c 319
tobyspark 2:24d9b7a3073c 320 if (button)
tobyspark 2:24d9b7a3073c 321 {
tobyspark 2:24d9b7a3073c 322 testDMX();
tobyspark 2:24d9b7a3073c 323 screen.textToBuffer("Sent: /mbed/button 1",5);
tobyspark 2:24d9b7a3073c 324 //dmx.put(kDMX_HAZER_HAZE, 128);
tobyspark 2:24d9b7a3073c 325 //dmx.put(kDMX_HAZER_FAN, 255);
tobyspark 2:24d9b7a3073c 326 }
tobyspark 2:24d9b7a3073c 327 else
tobyspark 2:24d9b7a3073c 328 {
tobyspark 2:24d9b7a3073c 329 screen.textToBuffer("Sent: /mbed/button 0",5);
tobyspark 2:24d9b7a3073c 330 dmx.put(kDMX_HAZER_HAZE, 0);
tobyspark 2:24d9b7a3073c 331 dmx.put(kDMX_HAZER_FAN, 0);
tobyspark 2:24d9b7a3073c 332 }
tobyspark 0:59b1d685427c 333 }
tobyspark 0:59b1d685427c 334
tobyspark 0:59b1d685427c 335 screen.sendBuffer();
tobyspark 0:59b1d685427c 336 }
tobyspark 0:59b1d685427c 337 }