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 19:57:40 2015 +0000
Revision:
3:642cd9d00b69
Parent:
2:24d9b7a3073c
Child:
4:c8b23ce175f4
string with parcans + bow with spot. untested for bow.

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 3:642cd9d00b69 46 #define kDMX_SPOT_DIMMER 31
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 2:24d9b7a3073c 107 float sMaxFixed = 0.2;
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 // unsigned char parCanData[4];
tobyspark 0:59b1d685427c 246 // parCanData[kDMX_PARCAN_R] = 255;
tobyspark 0:59b1d685427c 247 // parCanData[kDMX_PARCAN_G] = 255;
tobyspark 0:59b1d685427c 248 // parCanData[kDMX_PARCAN_B] = 255;
tobyspark 0:59b1d685427c 249 // parCanData[kDMX_PARCAN_LUMA] = 0;
tobyspark 0:59b1d685427c 250 // dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 0:59b1d685427c 251 // dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 0:59b1d685427c 252 // dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 0:59b1d685427c 253 // dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 0:59b1d685427c 254
tobyspark 0:59b1d685427c 255 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 256 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 257 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 258 dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 259
tobyspark 0:59b1d685427c 260 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 261 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 262 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 263 dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 264
tobyspark 0:59b1d685427c 265 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 266 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 267 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 268 dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 269
tobyspark 0:59b1d685427c 270 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_R, 255);
tobyspark 0:59b1d685427c 271 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_G, 255);
tobyspark 0:59b1d685427c 272 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_B, 255);
tobyspark 0:59b1d685427c 273 dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_LUMA, 0);
tobyspark 0:59b1d685427c 274
tobyspark 0:59b1d685427c 275 //// Serial
tobyspark 0:59b1d685427c 276 usbSerial.baud(kUSB_BAUD);
tobyspark 0:59b1d685427c 277 usbSerial.attach(usbSerialReceive);
tobyspark 0:59b1d685427c 278
tobyspark 0:59b1d685427c 279 //// TASK: Prime button change detection
tobyspark 0:59b1d685427c 280 buttonLastState = button;
tobyspark 0:59b1d685427c 281
tobyspark 0:59b1d685427c 282 //// TASK: GO!
tobyspark 0:59b1d685427c 283
tobyspark 0:59b1d685427c 284 // We've finished setting up, now loop this forever...
tobyspark 0:59b1d685427c 285 while (true)
tobyspark 0:59b1d685427c 286 {
tobyspark 3:642cd9d00b69 287 if (newStringData)
tobyspark 0:59b1d685427c 288 {
tobyspark 0:59b1d685427c 289 char S1DMX = S1 * sMultiplier;
tobyspark 0:59b1d685427c 290 char S2DMX = S2 * sMultiplier;
tobyspark 0:59b1d685427c 291 char S3DMX = S3 * sMultiplier;
tobyspark 0:59b1d685427c 292 char S4DMX = S4 * sMultiplier;
tobyspark 2:24d9b7a3073c 293 // dmx.put(kDMX_PARCAN_1+kDMX_PARCAN_LUMA, S1DMX);
tobyspark 2:24d9b7a3073c 294 // dmx.put(kDMX_PARCAN_2+kDMX_PARCAN_LUMA, S2DMX);
tobyspark 2:24d9b7a3073c 295 // dmx.put(kDMX_PARCAN_3+kDMX_PARCAN_LUMA, S3DMX);
tobyspark 2:24d9b7a3073c 296 // dmx.put(kDMX_PARCAN_4+kDMX_PARCAN_LUMA, S4DMX);
tobyspark 2:24d9b7a3073c 297
tobyspark 2:24d9b7a3073c 298 unsigned char parCanData[4];
tobyspark 2:24d9b7a3073c 299 parCanData[kDMX_PARCAN_R] = 255;
tobyspark 2:24d9b7a3073c 300 parCanData[kDMX_PARCAN_G] = 255;
tobyspark 2:24d9b7a3073c 301 parCanData[kDMX_PARCAN_B] = 255;
tobyspark 2:24d9b7a3073c 302
tobyspark 2:24d9b7a3073c 303 parCanData[kDMX_PARCAN_LUMA] = S1DMX;
tobyspark 2:24d9b7a3073c 304 dmx.put(parCanData, kDMX_PARCAN_1, 4);
tobyspark 2:24d9b7a3073c 305
tobyspark 2:24d9b7a3073c 306 parCanData[kDMX_PARCAN_LUMA] = S2DMX;
tobyspark 2:24d9b7a3073c 307 dmx.put(parCanData, kDMX_PARCAN_2, 4);
tobyspark 2:24d9b7a3073c 308
tobyspark 2:24d9b7a3073c 309 parCanData[kDMX_PARCAN_LUMA] = S3DMX;
tobyspark 2:24d9b7a3073c 310 dmx.put(parCanData, kDMX_PARCAN_3, 4);
tobyspark 2:24d9b7a3073c 311
tobyspark 2:24d9b7a3073c 312 parCanData[kDMX_PARCAN_LUMA] = S4DMX;
tobyspark 2:24d9b7a3073c 313 dmx.put(parCanData, kDMX_PARCAN_4, 4);
tobyspark 0:59b1d685427c 314
tobyspark 0:59b1d685427c 315 char dmxSummary[kStringBufferLength];
tobyspark 0:59b1d685427c 316 snprintf(dmxSummary, kStringBufferLength, "S %03u %03u %03u %03u", S1DMX, S2DMX, S3DMX, S4DMX);
tobyspark 0:59b1d685427c 317 screen.textToBuffer(dmxSummary,6);
tobyspark 0:59b1d685427c 318
tobyspark 3:642cd9d00b69 319 newStringData = false;
tobyspark 3:642cd9d00b69 320 }
tobyspark 3:642cd9d00b69 321
tobyspark 3:642cd9d00b69 322 if (newBowData)
tobyspark 3:642cd9d00b69 323 {
tobyspark 3:642cd9d00b69 324 if (EB < 0) EB = 0;
tobyspark 3:642cd9d00b69 325 char bowDMX = EB * eMultiplier;
tobyspark 3:642cd9d00b69 326 dmx.put(kDMX_SPOT_DIMMER, bowDMX);
tobyspark 0:59b1d685427c 327 }
tobyspark 0:59b1d685427c 328
tobyspark 0:59b1d685427c 329 // Has the button changed?
tobyspark 0:59b1d685427c 330 if (button != buttonLastState) {
tobyspark 0:59b1d685427c 331 // If so, lets update the lastState variable and then send an OSC message
tobyspark 0:59b1d685427c 332 buttonLastState = button;
tobyspark 0:59b1d685427c 333
tobyspark 2:24d9b7a3073c 334 if (button)
tobyspark 2:24d9b7a3073c 335 {
tobyspark 2:24d9b7a3073c 336 testDMX();
tobyspark 2:24d9b7a3073c 337 screen.textToBuffer("Sent: /mbed/button 1",5);
tobyspark 2:24d9b7a3073c 338 //dmx.put(kDMX_HAZER_HAZE, 128);
tobyspark 2:24d9b7a3073c 339 //dmx.put(kDMX_HAZER_FAN, 255);
tobyspark 2:24d9b7a3073c 340 }
tobyspark 2:24d9b7a3073c 341 else
tobyspark 2:24d9b7a3073c 342 {
tobyspark 2:24d9b7a3073c 343 screen.textToBuffer("Sent: /mbed/button 0",5);
tobyspark 2:24d9b7a3073c 344 dmx.put(kDMX_HAZER_HAZE, 0);
tobyspark 2:24d9b7a3073c 345 dmx.put(kDMX_HAZER_FAN, 0);
tobyspark 2:24d9b7a3073c 346 }
tobyspark 0:59b1d685427c 347 }
tobyspark 2:24d9b7a3073c 348
tobyspark 0:59b1d685427c 349 // for (int i = 0; i<256; i++)
tobyspark 0:59b1d685427c 350 // {
tobyspark 0:59b1d685427c 351 // for (int j = 0; j<256; j++)
tobyspark 0:59b1d685427c 352 // {
tobyspark 0:59b1d685427c 353 // dmx.put(j, i);
tobyspark 0:59b1d685427c 354 // }
tobyspark 0:59b1d685427c 355 // wait(0.01);
tobyspark 0:59b1d685427c 356 // }
tobyspark 0:59b1d685427c 357
tobyspark 0:59b1d685427c 358 screen.sendBuffer();
tobyspark 0:59b1d685427c 359 }
tobyspark 0:59b1d685427c 360 }