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:
Thu May 14 00:43:18 2015 +0000
Revision:
2:24d9b7a3073c
Parent:
1:f0cc153fe8d3
Child:
3:642cd9d00b69
Sometimes crashes on fast playing?

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 2:24d9b7a3073c 36 #define kDMX_PARCAN_1 8 - 4 // don't know why but fixtures are four higher than code
tobyspark 2:24d9b7a3073c 37 #define kDMX_PARCAN_2 12 - 4
tobyspark 2:24d9b7a3073c 38 #define kDMX_PARCAN_3 16 - 4
tobyspark 2:24d9b7a3073c 39 #define kDMX_PARCAN_4 20 - 4
tobyspark 0:59b1d685427c 40
tobyspark 0:59b1d685427c 41 #define kDMX_PARCAN_R 0
tobyspark 0:59b1d685427c 42 #define kDMX_PARCAN_G 1
tobyspark 0:59b1d685427c 43 #define kDMX_PARCAN_B 2
tobyspark 0:59b1d685427c 44 #define kDMX_PARCAN_LUMA 3
tobyspark 0:59b1d685427c 45
tobyspark 2:24d9b7a3073c 46 #define kDMX_HAZER_HAZE 128
tobyspark 2:24d9b7a3073c 47 #define kDMX_HAZER_FAN 129
tobyspark 2:24d9b7a3073c 48
tobyspark 0:59b1d685427c 49 // MISC Defines
tobyspark 0:59b1d685427c 50
tobyspark 0:59b1d685427c 51 #define kStringBufferLength 30
tobyspark 1:f0cc153fe8d3 52 #define kUSBSerialBufferLength 256
tobyspark 0:59b1d685427c 53
tobyspark 0:59b1d685427c 54 //// USB Serial
tobyspark 0:59b1d685427c 55
tobyspark 0:59b1d685427c 56 Serial usbSerial(USBTX, USBRX);
tobyspark 0:59b1d685427c 57
tobyspark 0:59b1d685427c 58 //// DMX
tobyspark 0:59b1d685427c 59
tobyspark 0:59b1d685427c 60 DigitalIn rj45ModeDIN(kMBED_DIN_ETHLO_DMXHI);
tobyspark 0:59b1d685427c 61 DigitalOut dmxDirectionDOUT(kMBED_DOUT_RS485_TXHI_RXLO);
tobyspark 0:59b1d685427c 62 enum { rj45Ethernet = 0, rj45DMX = 1}; // These values from circuit
tobyspark 0:59b1d685427c 63
tobyspark 0:59b1d685427c 64 DMX dmx(kMBED_RS485_TTLTX, kMBED_RS485_TTLRX);
tobyspark 0:59b1d685427c 65
tobyspark 0:59b1d685427c 66 //// Display
tobyspark 0:59b1d685427c 67
tobyspark 0:59b1d685427c 68 // SPKDisplay(PinName mosi, PinName clk, PinName cs, PinName dc, PinName res, Serial *debugSerial = NULL);
tobyspark 0:59b1d685427c 69 SPKDisplay screen(kMBED_OLED_MOSI, kMBED_OLED_SCK, kMBED_OLED_CS, kMBED_OLED_DC, kMBED_OLED_RES, NULL);
tobyspark 0:59b1d685427c 70
tobyspark 0:59b1d685427c 71 //// mbed input
tobyspark 0:59b1d685427c 72
tobyspark 0:59b1d685427c 73 DigitalIn button(kMBED_DIN_TAP_L);
tobyspark 2:24d9b7a3073c 74 DigitalIn buttonR(kMBED_DIN_TAP_R);
tobyspark 0:59b1d685427c 75 bool buttonLastState;
tobyspark 0:59b1d685427c 76
tobyspark 1:f0cc153fe8d3 77 char usbSerialBuffer[kUSBSerialBufferLength];
tobyspark 1:f0cc153fe8d3 78 int usbSerialBufferPosition = 0;
tobyspark 0:59b1d685427c 79 bool newData = false;
tobyspark 0:59b1d685427c 80
tobyspark 0:59b1d685427c 81 //// LAUREL VIOLIN DATA
tobyspark 0:59b1d685427c 82
tobyspark 0:59b1d685427c 83 // [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 84 int TA, TB;
tobyspark 0:59b1d685427c 85
tobyspark 0:59b1d685427c 86 // [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 87 float P1A, P1B, P2A, P2B, P3A, P3B, P4A, P4B;
tobyspark 0:59b1d685427c 88
tobyspark 0:59b1d685427c 89 // [S: A] = signal strength. A is RMS of audio signal in the buffer.
tobyspark 0:59b1d685427c 90 float S1, S2, S3, S4;
tobyspark 0:59b1d685427c 91
tobyspark 0:59b1d685427c 92 // [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 93 float F1, F2, F3, F4;
tobyspark 0:59b1d685427c 94
tobyspark 0:59b1d685427c 95 // [B: A, B, C, D] = raw bow data, A is sensor closest to frog, D closest to tip.
tobyspark 0:59b1d685427c 96 float B1, B2, B3, B4;
tobyspark 0:59b1d685427c 97
tobyspark 0:59b1d685427c 98 // [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 99 float EA, EB;
tobyspark 0:59b1d685427c 100 int EC;
tobyspark 0:59b1d685427c 101
tobyspark 0:59b1d685427c 102 // TOBY VIOLIN EXTRAS
tobyspark 0:59b1d685427c 103
tobyspark 2:24d9b7a3073c 104 float sMaxFixed = 0.2;
tobyspark 2:24d9b7a3073c 105 float sMultiplier = 255.0/sMaxFixed;
tobyspark 2:24d9b7a3073c 106
tobyspark 2:24d9b7a3073c 107 void testDMX()
tobyspark 2:24d9b7a3073c 108 {
tobyspark 2:24d9b7a3073c 109 static char state = 1;
tobyspark 2:24d9b7a3073c 110
tobyspark 2:24d9b7a3073c 111 int address;
tobyspark 2:24d9b7a3073c 112
tobyspark 2:24d9b7a3073c 113 switch (state)
tobyspark 2:24d9b7a3073c 114 {
tobyspark 2:24d9b7a3073c 115 case 1: address = kDMX_PARCAN_1; break;
tobyspark 2:24d9b7a3073c 116 case 2: address = kDMX_PARCAN_2; break;
tobyspark 2:24d9b7a3073c 117 case 3: address = kDMX_PARCAN_3; break;
tobyspark 2:24d9b7a3073c 118 case 4: address = kDMX_PARCAN_4; break;
tobyspark 2:24d9b7a3073c 119 }
tobyspark 2:24d9b7a3073c 120
tobyspark 2:24d9b7a3073c 121 unsigned char parCanData[4];
tobyspark 2:24d9b7a3073c 122 parCanData[kDMX_PARCAN_R] = 255;
tobyspark 2:24d9b7a3073c 123 parCanData[kDMX_PARCAN_G] = 255;
tobyspark 2:24d9b7a3073c 124 parCanData[kDMX_PARCAN_B] = 255;
tobyspark 2:24d9b7a3073c 125 parCanData[kDMX_PARCAN_LUMA] = 0;
tobyspark 2:24d9b7a3073c 126 dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 2:24d9b7a3073c 127 dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 2:24d9b7a3073c 128 dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 2:24d9b7a3073c 129 dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 2:24d9b7a3073c 130
tobyspark 2:24d9b7a3073c 131 parCanData[kDMX_PARCAN_LUMA] = 255;
tobyspark 2:24d9b7a3073c 132 dmx.put(parCanData, address, 4);
tobyspark 2:24d9b7a3073c 133
tobyspark 2:24d9b7a3073c 134 if (++state > 4) state = 1;
tobyspark 2:24d9b7a3073c 135 }
tobyspark 2:24d9b7a3073c 136
tobyspark 2:24d9b7a3073c 137 inline void processData()
tobyspark 2:24d9b7a3073c 138 {
tobyspark 2:24d9b7a3073c 139 float sMax = S1;
tobyspark 2:24d9b7a3073c 140 if (sMax < S2) sMax = S2;
tobyspark 2:24d9b7a3073c 141 if (sMax < S3) sMax = S3;
tobyspark 2:24d9b7a3073c 142 if (sMax < S4) sMax = S4;
tobyspark 2:24d9b7a3073c 143
tobyspark 2:24d9b7a3073c 144 float threshold = sMax * 0.7;
tobyspark 2:24d9b7a3073c 145
tobyspark 2:24d9b7a3073c 146 if (S1 < threshold) S1 = 0;
tobyspark 2:24d9b7a3073c 147 if (S2 < threshold) S2 = 0;
tobyspark 2:24d9b7a3073c 148 if (S3 < threshold) S3 = 0;
tobyspark 2:24d9b7a3073c 149 if (S4 < threshold) S4 = 0;
tobyspark 2:24d9b7a3073c 150 }
tobyspark 0:59b1d685427c 151
tobyspark 0:59b1d685427c 152 void usbSerialReceive(void)
tobyspark 0:59b1d685427c 153 {
tobyspark 0:59b1d685427c 154 char receivedChar;
tobyspark 0:59b1d685427c 155
tobyspark 0:59b1d685427c 156 //if data is ready in the buffer
tobyspark 0:59b1d685427c 157 while (usbSerial.readable())
tobyspark 0:59b1d685427c 158 {
tobyspark 0:59b1d685427c 159 receivedChar = usbSerial.getc();
tobyspark 0:59b1d685427c 160
tobyspark 0:59b1d685427c 161 // Is end of line?
tobyspark 0:59b1d685427c 162 if (receivedChar == '\n' || receivedChar == '\r')
tobyspark 0:59b1d685427c 163 {
tobyspark 0:59b1d685427c 164 // [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 165 int scanCount;
tobyspark 0:59b1d685427c 166 // scanCount = sscanf(
tobyspark 0:59b1d685427c 167 // usbSerialString.c_str(),
tobyspark 0:59b1d685427c 168 // "[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 169 // &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 170 // );
tobyspark 0:59b1d685427c 171 // if (scanCount == 25)
tobyspark 0:59b1d685427c 172 scanCount = sscanf(
tobyspark 1:f0cc153fe8d3 173 usbSerialBuffer,
tobyspark 0:59b1d685427c 174 "[S: %f, %f, %f, %f],[E: %f, %f, %d]",
tobyspark 0:59b1d685427c 175 &S1, &S2, &S3, &S4, &EA, &EB, &EC
tobyspark 0:59b1d685427c 176 );
tobyspark 0:59b1d685427c 177
tobyspark 0:59b1d685427c 178 if (scanCount == 7)
tobyspark 0:59b1d685427c 179 {
tobyspark 0:59b1d685427c 180 newData = true;
tobyspark 2:24d9b7a3073c 181 processData();
tobyspark 2:24d9b7a3073c 182 }
tobyspark 2:24d9b7a3073c 183 else if (scanCount == 4)
tobyspark 2:24d9b7a3073c 184 {
tobyspark 2:24d9b7a3073c 185 // No bow data
tobyspark 2:24d9b7a3073c 186 newData = true;
tobyspark 2:24d9b7a3073c 187 processData();
tobyspark 0:59b1d685427c 188 }
tobyspark 0:59b1d685427c 189 else
tobyspark 0:59b1d685427c 190 {
tobyspark 0:59b1d685427c 191 screen.textToBuffer("Read vars failed", 6);
tobyspark 0:59b1d685427c 192 }
tobyspark 0:59b1d685427c 193
tobyspark 0:59b1d685427c 194 // Clear to start again
tobyspark 1:f0cc153fe8d3 195 usbSerialBufferPosition = 0;
tobyspark 0:59b1d685427c 196 }
tobyspark 1:f0cc153fe8d3 197 else if (usbSerialBufferPosition < kUSBSerialBufferLength)
tobyspark 0:59b1d685427c 198 {
tobyspark 0:59b1d685427c 199 // Build string up
tobyspark 1:f0cc153fe8d3 200 usbSerialBuffer[usbSerialBufferPosition++] = receivedChar;
tobyspark 1:f0cc153fe8d3 201 usbSerialBuffer[usbSerialBufferPosition] = 0;
tobyspark 0:59b1d685427c 202
tobyspark 1:f0cc153fe8d3 203 screen.textToBuffer(usbSerialBuffer,4);
tobyspark 0:59b1d685427c 204 }
tobyspark 0:59b1d685427c 205 }
tobyspark 0:59b1d685427c 206 }
tobyspark 0:59b1d685427c 207
tobyspark 0:59b1d685427c 208 //// M A I N
tobyspark 0:59b1d685427c 209 int main() {
tobyspark 0:59b1d685427c 210
tobyspark 0:59b1d685427c 211 // Set display font
tobyspark 0:59b1d685427c 212 screen.fontStartCharacter = &characterBytesStartChar;
tobyspark 0:59b1d685427c 213 screen.fontEndCharacter = &characterBytesEndChar;
tobyspark 0:59b1d685427c 214 screen.fontCharacters = characterBytes;
tobyspark 0:59b1d685427c 215
tobyspark 0:59b1d685427c 216 // Splash screen
tobyspark 0:59b1d685427c 217 screen.imageToBuffer(spkDisplayLogo);
tobyspark 0:59b1d685427c 218 screen.textToBuffer("SPK:DMXer",0);
tobyspark 0:59b1d685427c 219 screen.textToBuffer("FRATRES 2015",1);
tobyspark 0:59b1d685427c 220 screen.textToBuffer("SW v01",2);
tobyspark 0:59b1d685427c 221 screen.sendBuffer();
tobyspark 0:59b1d685427c 222
tobyspark 0:59b1d685427c 223 if (rj45ModeDIN == rj45DMX) screen.textToBuffer("RJ45: DMX Mode", 3);
tobyspark 0:59b1d685427c 224 else screen.textToBuffer("RJ45: Ethernet Mode", 3);
tobyspark 0:59b1d685427c 225 screen.sendBuffer();
tobyspark 0:59b1d685427c 226
tobyspark 0:59b1d685427c 227 dmxDirectionDOUT = 1;
tobyspark 0:59b1d685427c 228 dmx.start();
tobyspark 0:59b1d685427c 229
tobyspark 0:59b1d685427c 230 // unsigned char parCanData[4];
tobyspark 0:59b1d685427c 231 // parCanData[kDMX_PARCAN_R] = 255;
tobyspark 0:59b1d685427c 232 // parCanData[kDMX_PARCAN_G] = 255;
tobyspark 0:59b1d685427c 233 // parCanData[kDMX_PARCAN_B] = 255;
tobyspark 0:59b1d685427c 234 // parCanData[kDMX_PARCAN_LUMA] = 0;
tobyspark 0:59b1d685427c 235 // dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 0:59b1d685427c 236 // dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 0:59b1d685427c 237 // dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 0:59b1d685427c 238 // dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 0:59b1d685427c 239
tobyspark 0:59b1d685427c 240 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 241 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 242 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 243 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 244
tobyspark 0:59b1d685427c 245 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 246 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 247 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 248 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 249
tobyspark 0:59b1d685427c 250 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 251 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 252 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 253 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 254
tobyspark 0:59b1d685427c 255 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 256 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 257 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 258 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 259
tobyspark 0:59b1d685427c 260 //// Serial
tobyspark 0:59b1d685427c 261 usbSerial.baud(kUSB_BAUD);
tobyspark 0:59b1d685427c 262 usbSerial.attach(usbSerialReceive);
tobyspark 0:59b1d685427c 263
tobyspark 0:59b1d685427c 264 //// TASK: Prime button change detection
tobyspark 0:59b1d685427c 265 buttonLastState = button;
tobyspark 0:59b1d685427c 266
tobyspark 0:59b1d685427c 267 //// TASK: GO!
tobyspark 0:59b1d685427c 268
tobyspark 0:59b1d685427c 269 // We've finished setting up, now loop this forever...
tobyspark 0:59b1d685427c 270 while (true)
tobyspark 0:59b1d685427c 271 {
tobyspark 0:59b1d685427c 272 if (newData)
tobyspark 0:59b1d685427c 273 {
tobyspark 0:59b1d685427c 274 char S1DMX = S1 * sMultiplier;
tobyspark 0:59b1d685427c 275 char S2DMX = S2 * sMultiplier;
tobyspark 0:59b1d685427c 276 char S3DMX = S3 * sMultiplier;
tobyspark 0:59b1d685427c 277 char S4DMX = S4 * sMultiplier;
tobyspark 2:24d9b7a3073c 278 // dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_LUMA, S1DMX);
tobyspark 2:24d9b7a3073c 279 // dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_LUMA, S2DMX);
tobyspark 2:24d9b7a3073c 280 // dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_LUMA, S3DMX);
tobyspark 2:24d9b7a3073c 281 // dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_LUMA, S4DMX);
tobyspark 2:24d9b7a3073c 282
tobyspark 2:24d9b7a3073c 283 unsigned char parCanData[4];
tobyspark 2:24d9b7a3073c 284 parCanData[kDMX_PARCAN_R] = 255;
tobyspark 2:24d9b7a3073c 285 parCanData[kDMX_PARCAN_G] = 255;
tobyspark 2:24d9b7a3073c 286 parCanData[kDMX_PARCAN_B] = 255;
tobyspark 2:24d9b7a3073c 287
tobyspark 2:24d9b7a3073c 288 parCanData[kDMX_PARCAN_LUMA] = S1DMX;
tobyspark 2:24d9b7a3073c 289 dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 2:24d9b7a3073c 290
tobyspark 2:24d9b7a3073c 291 parCanData[kDMX_PARCAN_LUMA] = S2DMX;
tobyspark 2:24d9b7a3073c 292 dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 2:24d9b7a3073c 293
tobyspark 2:24d9b7a3073c 294 parCanData[kDMX_PARCAN_LUMA] = S3DMX;
tobyspark 2:24d9b7a3073c 295 dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 2:24d9b7a3073c 296
tobyspark 2:24d9b7a3073c 297 parCanData[kDMX_PARCAN_LUMA] = S4DMX;
tobyspark 2:24d9b7a3073c 298 dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 0:59b1d685427c 299
tobyspark 0:59b1d685427c 300 char dmxSummary[kStringBufferLength];
tobyspark 0:59b1d685427c 301 snprintf(dmxSummary, kStringBufferLength, "S %03u %03u %03u %03u", S1DMX, S2DMX, S3DMX, S4DMX);
tobyspark 0:59b1d685427c 302 screen.textToBuffer(dmxSummary,6);
tobyspark 0:59b1d685427c 303
tobyspark 0:59b1d685427c 304 newData = false;
tobyspark 0:59b1d685427c 305 }
tobyspark 0:59b1d685427c 306
tobyspark 0:59b1d685427c 307 // Has the button changed?
tobyspark 0:59b1d685427c 308 if (button != buttonLastState) {
tobyspark 0:59b1d685427c 309 // If so, lets update the lastState variable and then send an OSC message
tobyspark 0:59b1d685427c 310 buttonLastState = button;
tobyspark 0:59b1d685427c 311
tobyspark 2:24d9b7a3073c 312 if (button)
tobyspark 2:24d9b7a3073c 313 {
tobyspark 2:24d9b7a3073c 314 testDMX();
tobyspark 2:24d9b7a3073c 315 screen.textToBuffer("Sent: /mbed/button 1",5);
tobyspark 2:24d9b7a3073c 316 //dmx.put(kDMX_HAZER_HAZE, 128);
tobyspark 2:24d9b7a3073c 317 //dmx.put(kDMX_HAZER_FAN, 255);
tobyspark 2:24d9b7a3073c 318 }
tobyspark 2:24d9b7a3073c 319 else
tobyspark 2:24d9b7a3073c 320 {
tobyspark 2:24d9b7a3073c 321 screen.textToBuffer("Sent: /mbed/button 0",5);
tobyspark 2:24d9b7a3073c 322 dmx.put(kDMX_HAZER_HAZE, 0);
tobyspark 2:24d9b7a3073c 323 dmx.put(kDMX_HAZER_FAN, 0);
tobyspark 2:24d9b7a3073c 324 }
tobyspark 0:59b1d685427c 325 }
tobyspark 2:24d9b7a3073c 326
tobyspark 0:59b1d685427c 327 // for (int i = 0; i<256; i++)
tobyspark 0:59b1d685427c 328 // {
tobyspark 0:59b1d685427c 329 // for (int j = 0; j<256; j++)
tobyspark 0:59b1d685427c 330 // {
tobyspark 0:59b1d685427c 331 // dmx.put(j, i);
tobyspark 0:59b1d685427c 332 // }
tobyspark 0:59b1d685427c 333 // wait(0.01);
tobyspark 0:59b1d685427c 334 // }
tobyspark 0:59b1d685427c 335
tobyspark 0:59b1d685427c 336 screen.sendBuffer();
tobyspark 0:59b1d685427c 337 }
tobyspark 0:59b1d685427c 338 }