The codebase to run the *spark d-fuser controller www.sparkav.co.uk/dvimixer

Dependencies:   SPK-TVOne DMX DmxArtNet NetServicesMin OSC PinDetect mRotaryEncoder iniparser mbed spk_oled_ssd1305 filter

Committer:
tobyspark
Date:
Tue Aug 28 15:41:51 2012 +0000
Revision:
12:c270870bdd23
Parent:
11:0783cfbeb746
Child:
13:3796bde6ba8f
Moved HDCPoff from startup to a menu item. Now nothing is altered on power-on of controller.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
tobyspark 8:d46cc49f0f37 1 /* *SPARK D-FUSER
tobyspark 8:d46cc49f0f37 2 * A project by Toby Harris
tobyspark 8:d46cc49f0f37 3 *
tobyspark 8:d46cc49f0f37 4 * 'DJ' controller styke RS232 Control for TV-One products
tobyspark 8:d46cc49f0f37 5 * Good for 1T-C2-750, others will need some extra work
tobyspark 8:d46cc49f0f37 6 *
tobyspark 8:d46cc49f0f37 7 * www.sparkav.co.uk/dvimixer
tobyspark 8:d46cc49f0f37 8 */
tobyspark 0:87aab40d5806 9
tobyspark 8:d46cc49f0f37 10 /* Copyright (c) 2011 Toby Harris, MIT License
tobyspark 8:d46cc49f0f37 11 *
tobyspark 8:d46cc49f0f37 12 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
tobyspark 8:d46cc49f0f37 13 * and associated documentation files (the "Software"), to deal in the Software without restriction,
tobyspark 8:d46cc49f0f37 14 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
tobyspark 8:d46cc49f0f37 15 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
tobyspark 8:d46cc49f0f37 16 * furnished to do so, subject to the following conditions:
tobyspark 8:d46cc49f0f37 17 *
tobyspark 8:d46cc49f0f37 18 * The above copyright notice and this permission notice shall be included in all copies or
tobyspark 8:d46cc49f0f37 19 * substantial portions of the Software.
tobyspark 8:d46cc49f0f37 20 *
tobyspark 8:d46cc49f0f37 21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
tobyspark 8:d46cc49f0f37 22 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
tobyspark 8:d46cc49f0f37 23 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
tobyspark 8:d46cc49f0f37 24 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
tobyspark 8:d46cc49f0f37 25 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
tobyspark 8:d46cc49f0f37 26 */
tobyspark 8:d46cc49f0f37 27
tobyspark 8:d46cc49f0f37 28 /* ROADMAP / HISTORY
tobyspark 8:d46cc49f0f37 29 * v10 - Port to mBed, keying redux - Apr'11
tobyspark 8:d46cc49f0f37 30 * v11 - Sign callbacks, code clean-up - Apr'11
tobyspark 8:d46cc49f0f37 31 * v12 - TVOne header split into two: defines and mbed class. v002 header updates pulled down. Removed sign callbacks, rewrite of debug and signing. - Apr'11
tobyspark 8:d46cc49f0f37 32 * v13 - Menu system for Resolution + Keying implemented, it writing to debug, it sending TVOne commands - Apr'11
tobyspark 8:d46cc49f0f37 33 * v14 - Fixes for new PCB - Oct'11
tobyspark 8:d46cc49f0f37 34 * v15 - TBZ PCB, OLED - Mar'12
tobyspark 8:d46cc49f0f37 35 * v16 - Comms menu, OSC, ArtNet - April'12
tobyspark 8:d46cc49f0f37 36 * v17 - RJ45 - May'12
tobyspark 8:d46cc49f0f37 37 * v18 - DMX - July'12
tobyspark 8:d46cc49f0f37 38 * vxx - TODO: Keying values load from USB mass storage
tobyspark 10:c011b0e5c17e 39 * vxx - TODO: Set keying values from controller, requires a guided, step-through process for user
tobyspark 8:d46cc49f0f37 40 * vxx - TODO: Defaults load/save from USB mass storage
tobyspark 8:d46cc49f0f37 41 * vxx - TODO: EDID upload from USB mass storage
tobyspark 8:d46cc49f0f37 42 * vxx - TODO: EDID creation from resolution
tobyspark 8:d46cc49f0f37 43 */
tobyspark 8:d46cc49f0f37 44
tobyspark 0:87aab40d5806 45 #include "mbed.h"
tobyspark 0:87aab40d5806 46
tobyspark 0:87aab40d5806 47 #include "spk_tvone_mbed.h"
tobyspark 0:87aab40d5806 48 #include "spk_utils.h"
tobyspark 0:87aab40d5806 49 #include "spk_mRotaryEncoder.h"
tobyspark 0:87aab40d5806 50 #include "spk_oled_ssd1305.h"
tobyspark 2:50043054e4f7 51 #include "spk_oled_gfx.h"
tobyspark 11:0783cfbeb746 52 #include "spk_settings.h"
tobyspark 1:f9fca21102e0 53 #include "EthernetNetIf.h"
tobyspark 1:f9fca21102e0 54 #include "mbedOSC.h"
tobyspark 3:033d2b7768f3 55 #include "DmxArtNet.h"
tobyspark 5:f8b285ca41ba 56 #include "DMX.h"
tobyspark 0:87aab40d5806 57
tobyspark 0:87aab40d5806 58 #include <sstream>
tobyspark 0:87aab40d5806 59
tobyspark 5:f8b285ca41ba 60 // MBED PINS
tobyspark 5:f8b285ca41ba 61
tobyspark 5:f8b285ca41ba 62 #define kMBED_AIN_XFADE p20
tobyspark 5:f8b285ca41ba 63 #define kMBED_AIN_FADEUP p19
tobyspark 5:f8b285ca41ba 64 #define kMBED_DIN_TAP_L p24
tobyspark 5:f8b285ca41ba 65 #define kMBED_DIN_TAP_R p23
tobyspark 5:f8b285ca41ba 66 #define kMBED_ENC_SW p15
tobyspark 5:f8b285ca41ba 67 #define kMBED_ENC_A p16
tobyspark 5:f8b285ca41ba 68 #define kMBED_ENC_B p17
tobyspark 5:f8b285ca41ba 69
tobyspark 5:f8b285ca41ba 70 #define kMBED_RS232_TTLTX p13
tobyspark 5:f8b285ca41ba 71 #define kMBED_RS232_TTLRX p14
tobyspark 5:f8b285ca41ba 72
tobyspark 5:f8b285ca41ba 73 #define kMBED_OLED_MOSI p5
tobyspark 5:f8b285ca41ba 74 #define kMBED_OLED_SCK p7
tobyspark 5:f8b285ca41ba 75 #define kMBED_OLED_CS p8
tobyspark 5:f8b285ca41ba 76 #define kMBED_OLED_RES p9
tobyspark 5:f8b285ca41ba 77 #define kMBED_OLED_DC p10
tobyspark 5:f8b285ca41ba 78
tobyspark 5:f8b285ca41ba 79 #define kMBED_DIN_ETHLO_DMXHI p30
tobyspark 5:f8b285ca41ba 80 #define kMBED_DOUT_RS485_TXHI_RXLO p29
tobyspark 5:f8b285ca41ba 81 #define kMBED_RS485_TTLTX p28
tobyspark 5:f8b285ca41ba 82 #define kMBED_RS485_TTLRX p27
tobyspark 5:f8b285ca41ba 83
tobyspark 5:f8b285ca41ba 84 // DISPLAY
tobyspark 5:f8b285ca41ba 85
tobyspark 1:f9fca21102e0 86 #define kMenuLine1 3
tobyspark 1:f9fca21102e0 87 #define kMenuLine2 4
tobyspark 1:f9fca21102e0 88 #define kCommsStatusLine 6
tobyspark 1:f9fca21102e0 89 #define kTVOneStatusLine 7
tobyspark 1:f9fca21102e0 90
tobyspark 5:f8b285ca41ba 91 // NETWORKING
tobyspark 5:f8b285ca41ba 92
tobyspark 1:f9fca21102e0 93 #define kOSCMbedPort 10000
tobyspark 1:f9fca21102e0 94 #define kOSCMbedIPAddress 10,0,0,2
tobyspark 1:f9fca21102e0 95 #define kOSCMbedSubnetMask 255,255,255,0
tobyspark 1:f9fca21102e0 96 #define kOSCMbedGateway 10,0,0,1
tobyspark 1:f9fca21102e0 97 #define kOSCMbedDNS 10,0,0,1
tobyspark 0:87aab40d5806 98
tobyspark 3:033d2b7768f3 99 #define kArtNetBindIPAddress 2,0,0,100
tobyspark 3:033d2b7768f3 100 #define kArtNetBroadcastAddress 2,255,255,255
tobyspark 3:033d2b7768f3 101
tobyspark 5:f8b285ca41ba 102 #define kDMXInChannelXFade 0
tobyspark 5:f8b285ca41ba 103 #define kDMXInChannelFadeUp 1
tobyspark 5:f8b285ca41ba 104 #define kDMXOutChannelXFade 0
tobyspark 5:f8b285ca41ba 105 #define kDMXOutChannelFadeUp 1
tobyspark 5:f8b285ca41ba 106
tobyspark 11:0783cfbeb746 107 #define kSPKDFSettingsFilename "SPKDF-Settings.txt"
tobyspark 11:0783cfbeb746 108
tobyspark 0:87aab40d5806 109 //// DEBUG
tobyspark 0:87aab40d5806 110
tobyspark 0:87aab40d5806 111 // Comment out one or the other...
tobyspark 5:f8b285ca41ba 112 //Serial *debug = new Serial(USBTX, USBRX); // For debugging via USB serial
tobyspark 5:f8b285ca41ba 113 Serial *debug = NULL; // For release (no debugging)
tobyspark 0:87aab40d5806 114
tobyspark 0:87aab40d5806 115 //// mBED PIN ASSIGNMENTS
tobyspark 0:87aab40d5806 116
tobyspark 0:87aab40d5806 117 // Inputs
tobyspark 5:f8b285ca41ba 118 AnalogIn xFadeAIN(kMBED_AIN_XFADE);
tobyspark 5:f8b285ca41ba 119 AnalogIn fadeUpAIN(kMBED_AIN_FADEUP);
tobyspark 5:f8b285ca41ba 120 DigitalIn tapLeftDIN(kMBED_DIN_TAP_L);
tobyspark 5:f8b285ca41ba 121 DigitalIn tapRightDIN(kMBED_DIN_TAP_R);
tobyspark 0:87aab40d5806 122
tobyspark 5:f8b285ca41ba 123 SPKRotaryEncoder menuEnc(kMBED_ENC_A, kMBED_ENC_B, kMBED_ENC_SW);
tobyspark 5:f8b285ca41ba 124
tobyspark 5:f8b285ca41ba 125 DigitalIn rj45ModeDIN(kMBED_DIN_ETHLO_DMXHI);
tobyspark 0:87aab40d5806 126
tobyspark 0:87aab40d5806 127 // Outputs
tobyspark 0:87aab40d5806 128 PwmOut fadeAPO(LED1);
tobyspark 0:87aab40d5806 129 PwmOut fadeBPO(LED2);
tobyspark 0:87aab40d5806 130
tobyspark 5:f8b285ca41ba 131 DigitalOut dmxDirectionDOUT(kMBED_DOUT_RS485_TXHI_RXLO);
tobyspark 5:f8b285ca41ba 132
tobyspark 0:87aab40d5806 133 // SPKTVOne(PinName txPin, PinName rxPin, PinName signWritePin, PinName signErrorPin, Serial *debugSerial)
tobyspark 5:f8b285ca41ba 134 SPKTVOne tvOne(kMBED_RS232_TTLTX, kMBED_RS232_TTLRX, LED3, LED4, debug);
tobyspark 0:87aab40d5806 135
tobyspark 0:87aab40d5806 136 // SPKDisplay(PinName mosi, PinName clk, PinName cs, PinName dc, PinName res, Serial *debugSerial = NULL);
tobyspark 5:f8b285ca41ba 137 SPKDisplay screen(kMBED_OLED_MOSI, kMBED_OLED_SCK, kMBED_OLED_CS, kMBED_OLED_DC, kMBED_OLED_RES, debug);
tobyspark 0:87aab40d5806 138
tobyspark 11:0783cfbeb746 139 // Saved Settings
tobyspark 11:0783cfbeb746 140 SPKSettings settings;
tobyspark 11:0783cfbeb746 141
tobyspark 0:87aab40d5806 142 // Menu
tobyspark 0:87aab40d5806 143 SPKMenu *selectedMenu;
tobyspark 0:87aab40d5806 144 SPKMenu *lastSelectedMenu;
tobyspark 0:87aab40d5806 145 SPKMenuOfMenus mainMenu;
tobyspark 0:87aab40d5806 146 SPKMenuPayload resolutionMenu;
tobyspark 0:87aab40d5806 147 SPKMenuPayload mixModeMenu;
tobyspark 12:c270870bdd23 148 SPKMenuPayload advancedMenu;
tobyspark 12:c270870bdd23 149
tobyspark 11:0783cfbeb746 150 enum { blend, additive, key }; // additive will require custom TVOne firmware.
tobyspark 5:f8b285ca41ba 151 int mixMode = blend;
tobyspark 1:f9fca21102e0 152 SPKMenuPayload commsMenu;
tobyspark 5:f8b285ca41ba 153 enum { commsNone, commsOSC, commsArtNet, commsDMXIn, commsDMXOut};
tobyspark 5:f8b285ca41ba 154 int commsMode = commsNone;
tobyspark 12:c270870bdd23 155 enum { advancedHDCPOn, advancedHDCPOff };
tobyspark 1:f9fca21102e0 156
tobyspark 5:f8b285ca41ba 157 // RJ45 Comms
tobyspark 5:f8b285ca41ba 158 enum { rj45Ethernet = 0, rj45DMX = 1}; // These values from circuit
tobyspark 5:f8b285ca41ba 159 int rj45Mode = -1;
tobyspark 1:f9fca21102e0 160 EthernetNetIf *ethernet = NULL;
tobyspark 1:f9fca21102e0 161 OSCClass *osc = NULL;
tobyspark 3:033d2b7768f3 162 OSCMessage recMessage;
tobyspark 3:033d2b7768f3 163 DmxArtNet *artNet = NULL;
tobyspark 5:f8b285ca41ba 164 DMX *dmx = NULL;
tobyspark 0:87aab40d5806 165
tobyspark 3:033d2b7768f3 166 // Fade logic constants
tobyspark 0:87aab40d5806 167 const float xFadeTolerance = 0.05;
tobyspark 0:87aab40d5806 168 const float fadeUpTolerance = 0.05;
tobyspark 0:87aab40d5806 169
tobyspark 0:87aab40d5806 170 // A&B Fade as resolved percent
tobyspark 0:87aab40d5806 171 int fadeAPercent = 0;
tobyspark 0:87aab40d5806 172 int fadeBPercent = 0;
tobyspark 0:87aab40d5806 173
tobyspark 0:87aab40d5806 174 // Tap button states
tobyspark 5:f8b285ca41ba 175 bool tapLeftWasFirstPressed = false;
tobyspark 0:87aab40d5806 176
tobyspark 0:87aab40d5806 177 // Key mode parameters
tobyspark 0:87aab40d5806 178 int keyerParamsSet = -1; // last keyParams index uploaded to unit
tobyspark 0:87aab40d5806 179
tobyspark 3:033d2b7768f3 180 void processOSC(float &xFade, float &fadeUp) {
tobyspark 3:033d2b7768f3 181 std::stringstream statusMessage;
tobyspark 3:033d2b7768f3 182 statusMessage.setf(ios::fixed,ios::floatfield);
tobyspark 3:033d2b7768f3 183 statusMessage.precision(2);
tobyspark 3:033d2b7768f3 184
tobyspark 3:033d2b7768f3 185 if (!strcmp( recMessage.getTopAddress() , "dvimxr" ))
tobyspark 3:033d2b7768f3 186 {
tobyspark 3:033d2b7768f3 187 statusMessage << "OSC: /dvimxr";
tobyspark 3:033d2b7768f3 188 if (!strcmp( recMessage.getSubAddress() , "xFade" ))
tobyspark 3:033d2b7768f3 189 if (recMessage.getArgNum() == 1)
tobyspark 3:033d2b7768f3 190 if (recMessage.getTypeTag(0) == 'f')
tobyspark 3:033d2b7768f3 191 {
tobyspark 3:033d2b7768f3 192 double newXFade = recMessage.getArgFloat(0);
tobyspark 3:033d2b7768f3 193 statusMessage << "/xFade " << newXFade;
tobyspark 3:033d2b7768f3 194 xFade = newXFade;
tobyspark 3:033d2b7768f3 195 }
tobyspark 3:033d2b7768f3 196 else if (!strcmp( recMessage.getSubAddress() , "fadeUp" ))
tobyspark 3:033d2b7768f3 197 if (recMessage.getArgNum() == 1)
tobyspark 3:033d2b7768f3 198 if (recMessage.getTypeTag(0) == 'f')
tobyspark 3:033d2b7768f3 199 {
tobyspark 3:033d2b7768f3 200 double newFadeUp = recMessage.getArgFloat(0);
tobyspark 3:033d2b7768f3 201 statusMessage << "/fadeUp " << newFadeUp;
tobyspark 3:033d2b7768f3 202 xFade = newFadeUp;
tobyspark 3:033d2b7768f3 203 }
tobyspark 3:033d2b7768f3 204 else statusMessage << recMessage.getSubAddress() << " - Ignoring";
tobyspark 3:033d2b7768f3 205 }
tobyspark 3:033d2b7768f3 206 else
tobyspark 3:033d2b7768f3 207 {
tobyspark 3:033d2b7768f3 208 statusMessage << "OSC: " << recMessage.getTopAddress() << " - Ignoring";
tobyspark 3:033d2b7768f3 209 }
tobyspark 3:033d2b7768f3 210
tobyspark 3:033d2b7768f3 211 screen.clearBufferRow(kCommsStatusLine);
tobyspark 3:033d2b7768f3 212 screen.textToBuffer(statusMessage.str(), kCommsStatusLine);
tobyspark 3:033d2b7768f3 213 screen.sendBuffer();
tobyspark 3:033d2b7768f3 214 if (debug) debug->printf("%s \r\n", statusMessage.str().c_str());
tobyspark 3:033d2b7768f3 215
tobyspark 3:033d2b7768f3 216 }
tobyspark 3:033d2b7768f3 217
tobyspark 8:d46cc49f0f37 218 void processArtNet(float &xFade, float &fadeUp)
tobyspark 8:d46cc49f0f37 219 {
tobyspark 3:033d2b7768f3 220 screen.clearBufferRow(kCommsStatusLine);
tobyspark 3:033d2b7768f3 221 screen.textToBuffer("ArtNet activity", kCommsStatusLine);
tobyspark 3:033d2b7768f3 222 screen.sendBuffer();
tobyspark 3:033d2b7768f3 223 if (debug) debug->printf("ArtNet activity");
tobyspark 3:033d2b7768f3 224 }
tobyspark 0:87aab40d5806 225
tobyspark 8:d46cc49f0f37 226 void processDMXIn(float &xFade, float &fadeUp)
tobyspark 8:d46cc49f0f37 227 {
tobyspark 5:f8b285ca41ba 228 std::stringstream statusMessage;
tobyspark 5:f8b285ca41ba 229
tobyspark 5:f8b285ca41ba 230 int xFadeDMX = dmx->get(kDMXInChannelXFade);
tobyspark 7:e6717468c18d 231 int fadeUpDMX = dmx->get(kDMXInChannelFadeUp);
tobyspark 5:f8b285ca41ba 232
tobyspark 5:f8b285ca41ba 233 xFade = (float)xFadeDMX/255;
tobyspark 5:f8b285ca41ba 234 fadeUp = (float)fadeUpDMX/255;
tobyspark 5:f8b285ca41ba 235
tobyspark 5:f8b285ca41ba 236 screen.clearBufferRow(kCommsStatusLine);
tobyspark 5:f8b285ca41ba 237 statusMessage << "DMX In: xF " << xFadeDMX << " fUp " << fadeUpDMX;
tobyspark 5:f8b285ca41ba 238 screen.textToBuffer(statusMessage.str(), kCommsStatusLine);
tobyspark 5:f8b285ca41ba 239 screen.sendBuffer();
tobyspark 5:f8b285ca41ba 240 if (debug) debug->printf(statusMessage.str().c_str());
tobyspark 5:f8b285ca41ba 241 }
tobyspark 5:f8b285ca41ba 242
tobyspark 8:d46cc49f0f37 243 void processDMXOut(float &xFade, float &fadeUp)
tobyspark 8:d46cc49f0f37 244 {
tobyspark 5:f8b285ca41ba 245 std::stringstream statusMessage;
tobyspark 5:f8b285ca41ba 246
tobyspark 5:f8b285ca41ba 247 int xFadeDMX = xFade*255;
tobyspark 5:f8b285ca41ba 248 int fadeUpDMX = fadeUp*255;
tobyspark 5:f8b285ca41ba 249
tobyspark 5:f8b285ca41ba 250 dmx->put(kDMXOutChannelXFade, xFadeDMX);
tobyspark 5:f8b285ca41ba 251 dmx->put(kDMXOutChannelFadeUp, fadeUpDMX);
tobyspark 5:f8b285ca41ba 252
tobyspark 5:f8b285ca41ba 253 screen.clearBufferRow(kCommsStatusLine);
tobyspark 5:f8b285ca41ba 254 statusMessage << "DMX Out: xF " << xFadeDMX << " fUp " << fadeUpDMX;
tobyspark 5:f8b285ca41ba 255 screen.textToBuffer(statusMessage.str(), kCommsStatusLine);
tobyspark 5:f8b285ca41ba 256 screen.sendBuffer();
tobyspark 5:f8b285ca41ba 257 if (debug) debug->printf(statusMessage.str().c_str());
tobyspark 5:f8b285ca41ba 258 }
tobyspark 0:87aab40d5806 259
tobyspark 8:d46cc49f0f37 260 inline float fadeCalc (const float AIN, const float tolerance)
tobyspark 8:d46cc49f0f37 261 {
tobyspark 0:87aab40d5806 262 float pos ;
tobyspark 0:87aab40d5806 263 if (AIN < tolerance) pos = 0;
tobyspark 0:87aab40d5806 264 else if (AIN > 1.0 - tolerance) pos = 1;
tobyspark 0:87aab40d5806 265 else pos = (AIN - tolerance) / (1 - 2*tolerance);
tobyspark 0:87aab40d5806 266 if (debug && false) debug->printf("fadeCalc in: %f out: %f \r\n", AIN, pos);
tobyspark 0:87aab40d5806 267 return pos;
tobyspark 0:87aab40d5806 268 }
tobyspark 0:87aab40d5806 269
tobyspark 8:d46cc49f0f37 270 bool setKeyParamsTo(int index)
tobyspark 8:d46cc49f0f37 271 {
tobyspark 0:87aab40d5806 272 // Only spend the time uploading six parameters if we need to
tobyspark 0:87aab40d5806 273 // Might want to bounds check here
tobyspark 0:87aab40d5806 274
tobyspark 9:f83eadd8917a 275 bool ok;
tobyspark 0:87aab40d5806 276
tobyspark 0:87aab40d5806 277 if (index != keyerParamsSet)
tobyspark 0:87aab40d5806 278 {
tobyspark 11:0783cfbeb746 279 ok = tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMinY, settings.keyerParamSet(index)[0]);
tobyspark 11:0783cfbeb746 280 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMaxY, settings.keyerParamSet(index)[1]);
tobyspark 11:0783cfbeb746 281 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMinU, settings.keyerParamSet(index)[2]);
tobyspark 11:0783cfbeb746 282 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMaxU, settings.keyerParamSet(index)[3]);
tobyspark 11:0783cfbeb746 283 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMinV, settings.keyerParamSet(index)[4]);
tobyspark 11:0783cfbeb746 284 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerMaxV, settings.keyerParamSet(index)[5]);
tobyspark 0:87aab40d5806 285
tobyspark 0:87aab40d5806 286 keyerParamsSet = index;
tobyspark 9:f83eadd8917a 287 }
tobyspark 9:f83eadd8917a 288 else
tobyspark 9:f83eadd8917a 289 {
tobyspark 9:f83eadd8917a 290 ok = true;
tobyspark 9:f83eadd8917a 291 }
tobyspark 0:87aab40d5806 292
tobyspark 0:87aab40d5806 293 return ok;
tobyspark 0:87aab40d5806 294 }
tobyspark 0:87aab40d5806 295
tobyspark 0:87aab40d5806 296 int main()
tobyspark 0:87aab40d5806 297 {
tobyspark 0:87aab40d5806 298 if (debug)
tobyspark 0:87aab40d5806 299 {
tobyspark 0:87aab40d5806 300 debug->printf("\r\n\r\n");
tobyspark 0:87aab40d5806 301 debug->printf("*spark d-fuser -----------\r\n");
tobyspark 0:87aab40d5806 302 debug->printf(" debug channel\r\n");
tobyspark 0:87aab40d5806 303 }
tobyspark 2:50043054e4f7 304
tobyspark 2:50043054e4f7 305 // Set display font
tobyspark 2:50043054e4f7 306 screen.fontStartCharacter = &characterBytesStartChar;
tobyspark 2:50043054e4f7 307 screen.fontEndCharacter = &characterBytesEndChar;
tobyspark 2:50043054e4f7 308 screen.fontCharacters = characterBytes;
tobyspark 2:50043054e4f7 309
tobyspark 0:87aab40d5806 310 // Splash screen
tobyspark 2:50043054e4f7 311 screen.imageToBuffer(spkDisplayLogo);
tobyspark 0:87aab40d5806 312 screen.textToBuffer("SPK:D-Fuser",0);
tobyspark 5:f8b285ca41ba 313 screen.textToBuffer("SW beta.18",1);
tobyspark 5:f8b285ca41ba 314 screen.sendBuffer();
tobyspark 0:87aab40d5806 315
tobyspark 11:0783cfbeb746 316 // Load saved settings
tobyspark 11:0783cfbeb746 317 settings.load(kSPKDFSettingsFilename);
tobyspark 11:0783cfbeb746 318
tobyspark 0:87aab40d5806 319 // Set menu structure
tobyspark 0:87aab40d5806 320 mixModeMenu.title = "Mix Mode";
tobyspark 0:87aab40d5806 321 mixModeMenu.addMenuItem("Blend", blend, 0);
tobyspark 11:0783cfbeb746 322 for (int i=0; i < settings.keyerSetCount(); i++)
tobyspark 11:0783cfbeb746 323 {
tobyspark 11:0783cfbeb746 324 mixModeMenu.addMenuItem(settings.keyerParamName(i), key+i, 0);
tobyspark 11:0783cfbeb746 325 }
tobyspark 0:87aab40d5806 326
tobyspark 0:87aab40d5806 327 resolutionMenu.title = "Resolution";
tobyspark 0:87aab40d5806 328 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionVGA, kTV1ResolutionVGA, 5);
tobyspark 0:87aab40d5806 329 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionSVGA, kTV1ResolutionSVGA, 5);
tobyspark 0:87aab40d5806 330 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionXGAp60, kTV1ResolutionXGAp60, 5);
tobyspark 0:87aab40d5806 331 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionWSXGAPLUSp60, kTV1ResolutionWSXGAPLUSp60, 5);
tobyspark 0:87aab40d5806 332 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionWUXGAp60, kTV1ResolutionWUXGAp60, 5);
tobyspark 0:87aab40d5806 333 resolutionMenu.addMenuItem(kTV1ResolutionDescription720p60, kTV1Resolution720p60, 5);
tobyspark 0:87aab40d5806 334 resolutionMenu.addMenuItem(kTV1ResolutionDescription1080p60, kTV1Resolution1080p60, 5);
tobyspark 0:87aab40d5806 335 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionDualHeadSVGAp60, kTV1ResolutionDualHeadSVGAp60, 0);
tobyspark 0:87aab40d5806 336 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionDualHeadXGAp60, kTV1ResolutionDualHeadXGAp60, 0);
tobyspark 0:87aab40d5806 337 resolutionMenu.addMenuItem(kTV1ResolutionDescriptionTripleHeadVGAp60, kTV1ResolutionTripleHeadVGAp60, 0);
tobyspark 0:87aab40d5806 338
tobyspark 5:f8b285ca41ba 339 commsMenu.title = "Network Mode";
tobyspark 1:f9fca21102e0 340 commsMenu.addMenuItem("None", commsNone, 0);
tobyspark 1:f9fca21102e0 341 commsMenu.addMenuItem("OSC", commsOSC, 0);
tobyspark 1:f9fca21102e0 342 commsMenu.addMenuItem("ArtNet", commsArtNet, 0);
tobyspark 5:f8b285ca41ba 343 commsMenu.addMenuItem("DMX In", commsDMXIn, 0);
tobyspark 5:f8b285ca41ba 344 commsMenu.addMenuItem("DMX Out", commsDMXOut, 0);
tobyspark 1:f9fca21102e0 345
tobyspark 12:c270870bdd23 346 advancedMenu.title = "Processor Advanced";
tobyspark 12:c270870bdd23 347 advancedMenu.addMenuItem("HDCP Off", advancedHDCPOff, 0);
tobyspark 12:c270870bdd23 348
tobyspark 0:87aab40d5806 349 mainMenu.title = "Main Menu";
tobyspark 0:87aab40d5806 350 mainMenu.addMenuItem(&mixModeMenu);
tobyspark 0:87aab40d5806 351 mainMenu.addMenuItem(&resolutionMenu);
tobyspark 1:f9fca21102e0 352 mainMenu.addMenuItem(&commsMenu);
tobyspark 12:c270870bdd23 353 mainMenu.addMenuItem(&advancedMenu);
tobyspark 0:87aab40d5806 354
tobyspark 0:87aab40d5806 355 selectedMenu = &mainMenu;
tobyspark 0:87aab40d5806 356 lastSelectedMenu = &mainMenu;
tobyspark 0:87aab40d5806 357
tobyspark 0:87aab40d5806 358 // Misc I/O stuff
tobyspark 0:87aab40d5806 359
tobyspark 0:87aab40d5806 360 fadeAPO.period(0.001);
tobyspark 0:87aab40d5806 361 fadeBPO.period(0.001);
tobyspark 0:87aab40d5806 362
tobyspark 12:c270870bdd23 363 // TODO: Test for TVOne connectivity here and display in status line
tobyspark 0:87aab40d5806 364
tobyspark 12:c270870bdd23 365 // Display menu and framing lines
tobyspark 0:87aab40d5806 366 screen.horizLineToBuffer(kMenuLine1*pixInPage - 1);
tobyspark 0:87aab40d5806 367 screen.clearBufferRow(kMenuLine1);
tobyspark 0:87aab40d5806 368 screen.textToBuffer(selectedMenu->title, kMenuLine1);
tobyspark 0:87aab40d5806 369 screen.clearBufferRow(kMenuLine2);
tobyspark 0:87aab40d5806 370 screen.textToBuffer(selectedMenu->selectedString(), kMenuLine2);
tobyspark 0:87aab40d5806 371 screen.horizLineToBuffer(kMenuLine2*pixInPage + pixInPage);
tobyspark 1:f9fca21102e0 372 screen.horizLineToBuffer(kCommsStatusLine*pixInPage - 1);
tobyspark 1:f9fca21102e0 373 screen.clearBufferRow(kCommsStatusLine);
tobyspark 1:f9fca21102e0 374 screen.textToBuffer(commsMenu.selectedString(), kCommsStatusLine);
tobyspark 1:f9fca21102e0 375 screen.clearBufferRow(kTVOneStatusLine);
tobyspark 0:87aab40d5806 376 screen.sendBuffer();
tobyspark 0:87aab40d5806 377
tobyspark 0:87aab40d5806 378
tobyspark 0:87aab40d5806 379 //// CONTROLS TEST
tobyspark 0:87aab40d5806 380
tobyspark 0:87aab40d5806 381 while (0) {
tobyspark 0:87aab40d5806 382 if (debug) debug->printf("xFade: %f, fadeOut: %f, tapLeft %i, tapRight: %i encPos: %i encChange:%i encHasPressed:%i \r\n" , xFadeAIN.read(), fadeUpAIN.read(), tapLeftDIN.read(), tapRightDIN.read(), menuEnc.getPos(), menuEnc.getChange(), menuEnc.hasPressed());
tobyspark 0:87aab40d5806 383 }
tobyspark 0:87aab40d5806 384
tobyspark 0:87aab40d5806 385 //// MIXER RUN
tobyspark 0:87aab40d5806 386
tobyspark 8:d46cc49f0f37 387 while (1)
tobyspark 8:d46cc49f0f37 388 {
tobyspark 1:f9fca21102e0 389 //// Task background things
tobyspark 5:f8b285ca41ba 390 if (ethernet && rj45Mode == rj45Ethernet)
tobyspark 5:f8b285ca41ba 391 {
tobyspark 5:f8b285ca41ba 392 if (debug) debug->printf("net poll");
tobyspark 5:f8b285ca41ba 393 Net::poll();
tobyspark 5:f8b285ca41ba 394 }
tobyspark 5:f8b285ca41ba 395
tobyspark 5:f8b285ca41ba 396 //// RJ45 SWITCH
tobyspark 5:f8b285ca41ba 397
tobyspark 5:f8b285ca41ba 398 if (rj45ModeDIN != rj45Mode)
tobyspark 1:f9fca21102e0 399 {
tobyspark 5:f8b285ca41ba 400 // update state
tobyspark 5:f8b285ca41ba 401 rj45Mode = rj45ModeDIN;
tobyspark 5:f8b285ca41ba 402 if (rj45Mode == rj45Ethernet) commsMenu.title = "Network Mode [Ethernet]";
tobyspark 5:f8b285ca41ba 403 if (rj45Mode == rj45DMX) commsMenu.title = "Network Mode [DMX]";
tobyspark 5:f8b285ca41ba 404
tobyspark 5:f8b285ca41ba 405 // cancel old comms
tobyspark 5:f8b285ca41ba 406 commsMode = commsNone;
tobyspark 5:f8b285ca41ba 407 commsMenu = commsMode;
tobyspark 5:f8b285ca41ba 408
tobyspark 5:f8b285ca41ba 409 // refresh display
tobyspark 5:f8b285ca41ba 410 if (selectedMenu == &commsMenu) screen.textToBuffer(selectedMenu->title, kMenuLine1);
tobyspark 5:f8b285ca41ba 411 if (rj45Mode == rj45Ethernet) screen.textToBuffer("RJ45: Ethernet Engaged", kCommsStatusLine);
tobyspark 5:f8b285ca41ba 412 if (rj45Mode == rj45DMX) screen.textToBuffer("RJ45: DMX Engaged", kCommsStatusLine);
tobyspark 1:f9fca21102e0 413 }
tobyspark 1:f9fca21102e0 414
tobyspark 0:87aab40d5806 415 //// MENU
tobyspark 0:87aab40d5806 416
tobyspark 0:87aab40d5806 417 int menuChange = menuEnc.getChange();
tobyspark 0:87aab40d5806 418
tobyspark 0:87aab40d5806 419 // Update GUI
tobyspark 0:87aab40d5806 420 if (menuChange != 0)
tobyspark 0:87aab40d5806 421 {
tobyspark 0:87aab40d5806 422 if (debug) debug->printf("Menu changed by %i\r\n", menuChange);
tobyspark 0:87aab40d5806 423
tobyspark 0:87aab40d5806 424 *selectedMenu = selectedMenu->selectedIndex() + menuChange;
tobyspark 0:87aab40d5806 425
tobyspark 0:87aab40d5806 426 // update OLED line 2 here
tobyspark 0:87aab40d5806 427 screen.clearBufferRow(kMenuLine2);
tobyspark 0:87aab40d5806 428 screen.textToBuffer(selectedMenu->selectedString(), kMenuLine2);
tobyspark 0:87aab40d5806 429
tobyspark 0:87aab40d5806 430 if (debug) debug->printf("%s \r\n", selectedMenu->selectedString().c_str());
tobyspark 0:87aab40d5806 431 }
tobyspark 0:87aab40d5806 432
tobyspark 0:87aab40d5806 433 // Action menu item
tobyspark 0:87aab40d5806 434 if (menuEnc.hasPressed())
tobyspark 0:87aab40d5806 435 {
tobyspark 0:87aab40d5806 436 if (debug) debug->printf("Action Menu Item!\r\n");
tobyspark 0:87aab40d5806 437
tobyspark 0:87aab40d5806 438 // Are we changing menus?
tobyspark 0:87aab40d5806 439 if (selectedMenu->type() == menuOfMenus)
tobyspark 0:87aab40d5806 440 {
tobyspark 0:87aab40d5806 441 // point selected menu to the new menu
tobyspark 0:87aab40d5806 442 // FIXME. Make this function abstract virtual of base class or get dynamic_cast working. BTW: C++ sucks / Obj-c rocks / Right now.
tobyspark 0:87aab40d5806 443 if (selectedMenu == &mainMenu) selectedMenu = mainMenu.selectedMenu();
tobyspark 0:87aab40d5806 444 else if (debug) debug->printf("FIXME: You've missed a SPKMenuOfMenus");
tobyspark 0:87aab40d5806 445
tobyspark 0:87aab40d5806 446 // reset the selection within that menu to the first position
tobyspark 0:87aab40d5806 447 (*selectedMenu) = 0;
tobyspark 0:87aab40d5806 448
tobyspark 0:87aab40d5806 449 // update OLED lines 1&2
tobyspark 0:87aab40d5806 450 screen.clearBufferRow(kMenuLine1);
tobyspark 0:87aab40d5806 451 screen.clearBufferRow(kMenuLine2);
tobyspark 0:87aab40d5806 452 screen.textToBuffer(selectedMenu->title, kMenuLine1);
tobyspark 0:87aab40d5806 453 screen.textToBuffer(selectedMenu->selectedString(), kMenuLine2);
tobyspark 0:87aab40d5806 454
tobyspark 0:87aab40d5806 455 if (debug)
tobyspark 0:87aab40d5806 456 {
tobyspark 0:87aab40d5806 457 debug->printf("\r\n");
tobyspark 0:87aab40d5806 458 debug->printf("%s \r\n", selectedMenu->title.c_str());
tobyspark 0:87aab40d5806 459 debug->printf("%s \r\n", selectedMenu->selectedString().c_str());
tobyspark 0:87aab40d5806 460 }
tobyspark 0:87aab40d5806 461 }
tobyspark 0:87aab40d5806 462 // Are we cancelling?
tobyspark 0:87aab40d5806 463 else if (selectedMenu->type() == payload && selectedMenu->selectedIndex() == 0)
tobyspark 0:87aab40d5806 464 {
tobyspark 0:87aab40d5806 465 selectedMenu = lastSelectedMenu;
tobyspark 0:87aab40d5806 466
tobyspark 0:87aab40d5806 467 // update OLED lines 1&2
tobyspark 0:87aab40d5806 468 screen.clearBufferRow(kMenuLine1);
tobyspark 0:87aab40d5806 469 screen.clearBufferRow(kMenuLine2);
tobyspark 0:87aab40d5806 470 screen.textToBuffer(selectedMenu->title, kMenuLine1);
tobyspark 0:87aab40d5806 471 screen.textToBuffer(selectedMenu->selectedString(), kMenuLine2);
tobyspark 0:87aab40d5806 472
tobyspark 0:87aab40d5806 473 if (debug)
tobyspark 0:87aab40d5806 474 {
tobyspark 0:87aab40d5806 475 debug->printf("\r\n");
tobyspark 0:87aab40d5806 476 debug->printf("%s \r\n", selectedMenu->title.c_str());
tobyspark 0:87aab40d5806 477 debug->printf("%s \r\n", selectedMenu->selectedString().c_str());
tobyspark 0:87aab40d5806 478 }
tobyspark 0:87aab40d5806 479 }
tobyspark 0:87aab40d5806 480 // With that out of the way, we should be actioning a specific menu's payload?
tobyspark 0:87aab40d5806 481 else if (selectedMenu == &mixModeMenu)
tobyspark 0:87aab40d5806 482 {
tobyspark 5:f8b285ca41ba 483 mixMode = mixModeMenu.selectedPayload1();
tobyspark 5:f8b285ca41ba 484
tobyspark 9:f83eadd8917a 485 bool ok = true;
tobyspark 0:87aab40d5806 486 std::string sentOK;
tobyspark 0:87aab40d5806 487 std::stringstream sentMSG;
tobyspark 0:87aab40d5806 488
tobyspark 11:0783cfbeb746 489 // Set Keyer
tobyspark 11:0783cfbeb746 490 if (mixModeMenu.selectedPayload1() < key)
tobyspark 11:0783cfbeb746 491 {
tobyspark 11:0783cfbeb746 492 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerEnable, false);
tobyspark 11:0783cfbeb746 493 sentMSG << "Keyer Off";
tobyspark 11:0783cfbeb746 494 }
tobyspark 11:0783cfbeb746 495 else
tobyspark 11:0783cfbeb746 496 {
tobyspark 11:0783cfbeb746 497 ok = ok && tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustKeyerEnable, true);
tobyspark 11:0783cfbeb746 498 sentMSG << "Keyer On";
tobyspark 11:0783cfbeb746 499
tobyspark 11:0783cfbeb746 500 int index = mixModeMenu.selectedPayload1() - key;
tobyspark 11:0783cfbeb746 501 ok = ok && setKeyParamsTo(index);
tobyspark 11:0783cfbeb746 502 sentMSG << " with " << index;
tobyspark 0:87aab40d5806 503 }
tobyspark 0:87aab40d5806 504
tobyspark 0:87aab40d5806 505 if (ok) sentOK = "Sent:";
tobyspark 0:87aab40d5806 506 else sentOK = "Send Error:";
tobyspark 0:87aab40d5806 507
tobyspark 1:f9fca21102e0 508 screen.clearBufferRow(kTVOneStatusLine);
tobyspark 1:f9fca21102e0 509 screen.textToBuffer(sentOK + sentMSG.str(), kTVOneStatusLine);
tobyspark 0:87aab40d5806 510
tobyspark 0:87aab40d5806 511 if (debug) { debug->printf("Changing mix mode"); }
tobyspark 0:87aab40d5806 512 }
tobyspark 0:87aab40d5806 513 else if (selectedMenu == &resolutionMenu)
tobyspark 0:87aab40d5806 514 {
tobyspark 9:f83eadd8917a 515 bool ok = true;
tobyspark 0:87aab40d5806 516
tobyspark 0:87aab40d5806 517 ok = tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustOutputsOutputResolution, resolutionMenu.selectedPayload1());
tobyspark 0:87aab40d5806 518 ok = ok && tvOne.command(kTV1SourceRGB1, kTV1WindowIDA, kTV1FunctionAdjustSourceEDID, resolutionMenu.selectedPayload2());
tobyspark 0:87aab40d5806 519 ok = ok && tvOne.command(kTV1SourceRGB2, kTV1WindowIDA, kTV1FunctionAdjustSourceEDID, resolutionMenu.selectedPayload2());
tobyspark 0:87aab40d5806 520
tobyspark 0:87aab40d5806 521 std::string sentOK;
tobyspark 0:87aab40d5806 522 if (ok) sentOK = "Sent: ";
tobyspark 0:87aab40d5806 523 else sentOK = "Send Error: ";
tobyspark 0:87aab40d5806 524
tobyspark 0:87aab40d5806 525 std::stringstream sentMSG;
tobyspark 0:87aab40d5806 526 sentMSG << "Res " << resolutionMenu.selectedPayload1() << ", EDID " << resolutionMenu.selectedPayload2();
tobyspark 0:87aab40d5806 527
tobyspark 1:f9fca21102e0 528 screen.clearBufferRow(kTVOneStatusLine);
tobyspark 1:f9fca21102e0 529 screen.textToBuffer(sentOK + sentMSG.str(), kTVOneStatusLine);
tobyspark 0:87aab40d5806 530
tobyspark 0:87aab40d5806 531 if (debug) { debug->printf("Changing resolution"); }
tobyspark 0:87aab40d5806 532 }
tobyspark 1:f9fca21102e0 533 else if (selectedMenu == &commsMenu)
tobyspark 1:f9fca21102e0 534 {
tobyspark 5:f8b285ca41ba 535 std::string commsTypeString = "Network: --";
tobyspark 1:f9fca21102e0 536 std::stringstream commsStatus;
tobyspark 1:f9fca21102e0 537
tobyspark 1:f9fca21102e0 538 // Tear down any existing comms
tobyspark 1:f9fca21102e0 539 // This is the action of commsNone
tobyspark 1:f9fca21102e0 540 // And also clears the way for other comms actions
tobyspark 5:f8b285ca41ba 541 if (osc) {delete osc; osc = NULL;}
tobyspark 5:f8b285ca41ba 542 if (ethernet) {delete ethernet; ethernet = NULL;}
tobyspark 5:f8b285ca41ba 543 if (artNet) {delete artNet; artNet = NULL;}
tobyspark 5:f8b285ca41ba 544 if (dmx) {delete dmx; dmx = NULL;}
tobyspark 5:f8b285ca41ba 545
tobyspark 5:f8b285ca41ba 546 // Ensure we can't change to comms modes the hardware isn't switched to
tobyspark 5:f8b285ca41ba 547 if (rj45Mode == rj45DMX && (commsMenu.selectedPayload1() == commsOSC || commsMenu.selectedPayload1() == commsArtNet))
tobyspark 1:f9fca21102e0 548 {
tobyspark 5:f8b285ca41ba 549 commsTypeString = "RJ45 not in Ethernet mode";
tobyspark 5:f8b285ca41ba 550 }
tobyspark 5:f8b285ca41ba 551 else if (rj45Mode == rj45Ethernet && (commsMenu.selectedPayload1() == commsDMXIn || commsMenu.selectedPayload1() == commsDMXOut))
tobyspark 5:f8b285ca41ba 552 {
tobyspark 5:f8b285ca41ba 553 commsTypeString = "RJ45 not in DMX mode";
tobyspark 5:f8b285ca41ba 554 }
tobyspark 5:f8b285ca41ba 555 // Action!
tobyspark 5:f8b285ca41ba 556 else if (commsMenu.selectedPayload1() == commsOSC)
tobyspark 5:f8b285ca41ba 557 {
tobyspark 5:f8b285ca41ba 558 commsMode = commsOSC;
tobyspark 5:f8b285ca41ba 559 commsTypeString = "OSC: ";
tobyspark 1:f9fca21102e0 560
tobyspark 1:f9fca21102e0 561 ethernet = new EthernetNetIf(
tobyspark 1:f9fca21102e0 562 IpAddr(kOSCMbedIPAddress),
tobyspark 1:f9fca21102e0 563 IpAddr(kOSCMbedSubnetMask),
tobyspark 1:f9fca21102e0 564 IpAddr(kOSCMbedGateway),
tobyspark 1:f9fca21102e0 565 IpAddr(kOSCMbedDNS)
tobyspark 1:f9fca21102e0 566 );
tobyspark 3:033d2b7768f3 567
tobyspark 1:f9fca21102e0 568 EthernetErr ethError = ethernet->setup();
tobyspark 1:f9fca21102e0 569 if(ethError)
tobyspark 1:f9fca21102e0 570 {
tobyspark 1:f9fca21102e0 571 if (debug) debug->printf("Ethernet setup error, %d", ethError);
tobyspark 1:f9fca21102e0 572 commsStatus << "Ethernet setup failed";
tobyspark 5:f8b285ca41ba 573 commsMenu = commsNone;
tobyspark 1:f9fca21102e0 574 // break out of here. this setup should be a function that returns a boolean
tobyspark 1:f9fca21102e0 575 }
tobyspark 1:f9fca21102e0 576
tobyspark 1:f9fca21102e0 577 osc = new OSCClass();
tobyspark 3:033d2b7768f3 578 osc->setReceiveMessage(&recMessage);
tobyspark 1:f9fca21102e0 579 osc->begin(kOSCMbedPort);
tobyspark 1:f9fca21102e0 580
tobyspark 3:033d2b7768f3 581 commsStatus << "Listening on " << kOSCMbedPort;
tobyspark 1:f9fca21102e0 582 }
tobyspark 1:f9fca21102e0 583 else if (commsMenu.selectedPayload1() == commsArtNet)
tobyspark 1:f9fca21102e0 584 {
tobyspark 5:f8b285ca41ba 585 commsMode = commsArtNet;
tobyspark 5:f8b285ca41ba 586 commsTypeString = "ArtNet: ";
tobyspark 3:033d2b7768f3 587
tobyspark 3:033d2b7768f3 588 artNet = new DmxArtNet();
tobyspark 1:f9fca21102e0 589
tobyspark 3:033d2b7768f3 590 artNet->BindIpAddress = IpAddr(kArtNetBindIPAddress);
tobyspark 3:033d2b7768f3 591 artNet->BCastAddress = IpAddr(kArtNetBroadcastAddress);
tobyspark 3:033d2b7768f3 592
tobyspark 3:033d2b7768f3 593 artNet->InitArtPollReplyDefaults();
tobyspark 3:033d2b7768f3 594
tobyspark 3:033d2b7768f3 595 artNet->ArtPollReply.PortType[0] = 128; // output
tobyspark 3:033d2b7768f3 596 artNet->ArtPollReply.PortType[2] = 64; // input
tobyspark 3:033d2b7768f3 597 artNet->ArtPollReply.GoodInput[2] = 4;
tobyspark 3:033d2b7768f3 598
tobyspark 3:033d2b7768f3 599 artNet->Init();
tobyspark 3:033d2b7768f3 600 artNet->SendArtPollReply(); // announce to art-net nodes
tobyspark 3:033d2b7768f3 601
tobyspark 3:033d2b7768f3 602 commsStatus << "Listening";
tobyspark 1:f9fca21102e0 603 }
tobyspark 5:f8b285ca41ba 604 else if (commsMenu.selectedPayload1() == commsDMXIn)
tobyspark 1:f9fca21102e0 605 {
tobyspark 5:f8b285ca41ba 606 commsMode = commsDMXIn;
tobyspark 5:f8b285ca41ba 607 commsTypeString = "DMX In: ";
tobyspark 1:f9fca21102e0 608
tobyspark 5:f8b285ca41ba 609 dmxDirectionDOUT = 0;
tobyspark 5:f8b285ca41ba 610
tobyspark 5:f8b285ca41ba 611 dmx = new DMX(kMBED_RS485_TTLTX, kMBED_RS485_TTLRX);
tobyspark 1:f9fca21102e0 612 }
tobyspark 5:f8b285ca41ba 613 else if (commsMenu.selectedPayload1() == commsDMXOut)
tobyspark 5:f8b285ca41ba 614 {
tobyspark 5:f8b285ca41ba 615 commsMode = commsDMXOut;
tobyspark 5:f8b285ca41ba 616 commsTypeString = "DMX Out: ";
tobyspark 5:f8b285ca41ba 617
tobyspark 5:f8b285ca41ba 618 dmxDirectionDOUT = 1;
tobyspark 5:f8b285ca41ba 619
tobyspark 5:f8b285ca41ba 620 dmx = new DMX(kMBED_RS485_TTLTX, kMBED_RS485_TTLRX);
tobyspark 5:f8b285ca41ba 621 }
tobyspark 5:f8b285ca41ba 622
tobyspark 1:f9fca21102e0 623 screen.clearBufferRow(kCommsStatusLine);
tobyspark 5:f8b285ca41ba 624 screen.textToBuffer(commsTypeString + commsStatus.str(), kCommsStatusLine);
tobyspark 1:f9fca21102e0 625 }
tobyspark 12:c270870bdd23 626 else if (selectedMenu == &advancedMenu)
tobyspark 12:c270870bdd23 627 {
tobyspark 12:c270870bdd23 628 if (advancedMenu.selectedPayload1() == advancedHDCPOff)
tobyspark 12:c270870bdd23 629 {
tobyspark 12:c270870bdd23 630 bool ok = false;
tobyspark 12:c270870bdd23 631
tobyspark 12:c270870bdd23 632 ok = tvOne.setHDCPOff();
tobyspark 12:c270870bdd23 633
tobyspark 12:c270870bdd23 634 std::string sendOK = ok ? "Sent: HDCP Off" : "Send Error: HDCP Off";
tobyspark 12:c270870bdd23 635
tobyspark 12:c270870bdd23 636 screen.clearBufferRow(kTVOneStatusLine);
tobyspark 12:c270870bdd23 637 screen.textToBuffer(sendOK, kTVOneStatusLine);
tobyspark 12:c270870bdd23 638 }
tobyspark 12:c270870bdd23 639 }
tobyspark 0:87aab40d5806 640 else
tobyspark 0:87aab40d5806 641 {
tobyspark 0:87aab40d5806 642 if (debug) { debug->printf("Warning: No action identified"); }
tobyspark 0:87aab40d5806 643 }
tobyspark 0:87aab40d5806 644 }
tobyspark 0:87aab40d5806 645
tobyspark 2:50043054e4f7 646 // Send any updates to the display
tobyspark 2:50043054e4f7 647 screen.sendBuffer();
tobyspark 5:f8b285ca41ba 648
tobyspark 0:87aab40d5806 649
tobyspark 5:f8b285ca41ba 650 //// MIX MIX MIX MIX MIX MIX MIX MIX MIX MIX MIX MIXMIX MIX MIXMIX MIX MIX MIX MIX MIXMIX MIX MIX
tobyspark 0:87aab40d5806 651
tobyspark 0:87aab40d5806 652 bool updateFade = false;
tobyspark 3:033d2b7768f3 653 float xFade = 0;
tobyspark 3:033d2b7768f3 654 float fadeUp = 1;
tobyspark 3:033d2b7768f3 655
tobyspark 3:033d2b7768f3 656 //// TASK: Process control surface
tobyspark 3:033d2b7768f3 657
tobyspark 0:87aab40d5806 658 // Get new states of tap buttons, remembering at end of loop() assign these current values to the previous variables
tobyspark 5:f8b285ca41ba 659 const bool tapLeft = !tapLeftDIN;
tobyspark 5:f8b285ca41ba 660 const bool tapRight = !tapRightDIN;
tobyspark 0:87aab40d5806 661
tobyspark 0:87aab40d5806 662 // We're going to cache the analog in reads, as have seen wierdness otherwise
tobyspark 5:f8b285ca41ba 663 const float xFadeAINCached = 1-xFadeAIN.read();
tobyspark 0:87aab40d5806 664 const float fadeUpAINCached = fadeUpAIN.read();
tobyspark 0:87aab40d5806 665
tobyspark 0:87aab40d5806 666 // When a tap is depressed, we can ignore any move of the crossfader but not fade to black
tobyspark 0:87aab40d5806 667 if (tapLeft || tapRight)
tobyspark 0:87aab40d5806 668 {
tobyspark 5:f8b285ca41ba 669 // If both are pressed, take to the one that is new, ie. not the first pressed.
tobyspark 0:87aab40d5806 670 if (tapLeft && tapRight)
tobyspark 0:87aab40d5806 671 {
tobyspark 5:f8b285ca41ba 672 xFade = tapLeftWasFirstPressed ? 1 : 0;
tobyspark 0:87aab40d5806 673 }
tobyspark 5:f8b285ca41ba 674 // If just one is pressed, take to that and remember which is pressed
tobyspark 5:f8b285ca41ba 675 else if (tapLeft)
tobyspark 5:f8b285ca41ba 676 {
tobyspark 5:f8b285ca41ba 677 xFade = 0;
tobyspark 5:f8b285ca41ba 678 tapLeftWasFirstPressed = 1;
tobyspark 5:f8b285ca41ba 679 }
tobyspark 5:f8b285ca41ba 680 else if (tapRight)
tobyspark 5:f8b285ca41ba 681 {
tobyspark 5:f8b285ca41ba 682 xFade = 1;
tobyspark 5:f8b285ca41ba 683 tapLeftWasFirstPressed = 0;
tobyspark 5:f8b285ca41ba 684 }
tobyspark 5:f8b285ca41ba 685 }
tobyspark 0:87aab40d5806 686 else xFade = fadeCalc(xFadeAINCached, xFadeTolerance);
tobyspark 0:87aab40d5806 687
tobyspark 0:87aab40d5806 688 fadeUp = 1.0 - fadeCalc(fadeUpAINCached, fadeUpTolerance);
tobyspark 0:87aab40d5806 689
tobyspark 3:033d2b7768f3 690 //// TASK: Process Network Comms
tobyspark 5:f8b285ca41ba 691 if (commsMode == commsOSC)
tobyspark 3:033d2b7768f3 692 {
tobyspark 3:033d2b7768f3 693 if (osc->newMessage)
tobyspark 3:033d2b7768f3 694 {
tobyspark 3:033d2b7768f3 695 osc->newMessage = false; // fixme!
tobyspark 3:033d2b7768f3 696 processOSC(xFade, fadeUp);
tobyspark 3:033d2b7768f3 697 }
tobyspark 3:033d2b7768f3 698 }
tobyspark 3:033d2b7768f3 699
tobyspark 5:f8b285ca41ba 700 if (commsMode == commsArtNet)
tobyspark 3:033d2b7768f3 701 {
tobyspark 3:033d2b7768f3 702 if (artNet->Work()) processArtNet(xFade, fadeUp);
tobyspark 3:033d2b7768f3 703 }
tobyspark 3:033d2b7768f3 704
tobyspark 5:f8b285ca41ba 705 if (commsMode == commsDMXIn)
tobyspark 5:f8b285ca41ba 706 {
tobyspark 5:f8b285ca41ba 707 processDMXIn(xFade, fadeUp);
tobyspark 5:f8b285ca41ba 708 }
tobyspark 5:f8b285ca41ba 709
tobyspark 5:f8b285ca41ba 710 if (commsMode == commsDMXOut)
tobyspark 5:f8b285ca41ba 711 {
tobyspark 5:f8b285ca41ba 712 processDMXOut(xFade, fadeUp);
tobyspark 5:f8b285ca41ba 713 }
tobyspark 0:87aab40d5806 714
tobyspark 0:87aab40d5806 715 // Calculate new A&B fade percents
tobyspark 0:87aab40d5806 716 int newFadeAPercent = 0;
tobyspark 0:87aab40d5806 717 int newFadeBPercent = 0;
tobyspark 0:87aab40d5806 718
tobyspark 11:0783cfbeb746 719 if (mixMode == blend)
tobyspark 11:0783cfbeb746 720 {
tobyspark 9:f83eadd8917a 721 if (fadeUp < 1.0)
tobyspark 9:f83eadd8917a 722 {
tobyspark 9:f83eadd8917a 723 // we need to set fade level of both windows as there is no way AFAIK to implement fade to black as a further window on top of A&B
tobyspark 9:f83eadd8917a 724 newFadeAPercent = (1.0-xFade) * fadeUp * 100.0;
tobyspark 9:f83eadd8917a 725 newFadeBPercent = xFade * fadeUp * 100.0;
tobyspark 9:f83eadd8917a 726 }
tobyspark 9:f83eadd8917a 727 else
tobyspark 9:f83eadd8917a 728 {
tobyspark 9:f83eadd8917a 729 // we can optimise and just fade A in and out over a fully up B, doubling the rate of fadeA commands sent.
tobyspark 9:f83eadd8917a 730 newFadeAPercent = (1.0-xFade) * 100.0;
tobyspark 9:f83eadd8917a 731 newFadeBPercent = 100.0;
tobyspark 9:f83eadd8917a 732 }
tobyspark 11:0783cfbeb746 733 }
tobyspark 11:0783cfbeb746 734 else if (mixMode == additive)
tobyspark 11:0783cfbeb746 735 {
tobyspark 9:f83eadd8917a 736 // we need to set fade level of both windows according to the fade curve profile (yet to implement - to do when tvone supply additive capability)
tobyspark 0:87aab40d5806 737 newFadeAPercent = (1.0-xFade) * fadeUp * 100.0;
tobyspark 0:87aab40d5806 738 newFadeBPercent = xFade * fadeUp * 100.0;
tobyspark 11:0783cfbeb746 739 }
tobyspark 11:0783cfbeb746 740 else if (mixMode >= key)
tobyspark 11:0783cfbeb746 741 {
tobyspark 0:87aab40d5806 742 newFadeAPercent = (1.0-xFade) * fadeUp * 100.0;
tobyspark 0:87aab40d5806 743 newFadeBPercent = fadeUp * 100.0;
tobyspark 0:87aab40d5806 744 }
tobyspark 0:87aab40d5806 745
tobyspark 0:87aab40d5806 746 // Send to TVOne if percents have changed
tobyspark 9:f83eadd8917a 747 // We want to send the higher first, otherwise black flashes can happen on taps
tobyspark 9:f83eadd8917a 748 if (newFadeAPercent != fadeAPercent && newFadeAPercent >= newFadeBPercent)
tobyspark 8:d46cc49f0f37 749 {
tobyspark 0:87aab40d5806 750 fadeAPercent = newFadeAPercent;
tobyspark 0:87aab40d5806 751 updateFade = true;
tobyspark 0:87aab40d5806 752
tobyspark 0:87aab40d5806 753 fadeAPO = fadeAPercent / 100.0;
tobyspark 0:87aab40d5806 754 tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustWindowsMaxFadeLevel, fadeAPercent);
tobyspark 0:87aab40d5806 755 }
tobyspark 0:87aab40d5806 756
tobyspark 8:d46cc49f0f37 757 if (newFadeBPercent != fadeBPercent)
tobyspark 8:d46cc49f0f37 758 {
tobyspark 0:87aab40d5806 759 fadeBPercent = newFadeBPercent;
tobyspark 0:87aab40d5806 760 updateFade = true;
tobyspark 0:87aab40d5806 761
tobyspark 0:87aab40d5806 762 fadeBPO = fadeBPercent / 100.0;
tobyspark 0:87aab40d5806 763 tvOne.command(0, kTV1WindowIDB, kTV1FunctionAdjustWindowsMaxFadeLevel, fadeBPercent);
tobyspark 0:87aab40d5806 764 }
tobyspark 0:87aab40d5806 765
tobyspark 9:f83eadd8917a 766 if (newFadeAPercent != fadeAPercent && newFadeAPercent < newFadeBPercent)
tobyspark 9:f83eadd8917a 767 {
tobyspark 9:f83eadd8917a 768 fadeAPercent = newFadeAPercent;
tobyspark 9:f83eadd8917a 769 updateFade = true;
tobyspark 9:f83eadd8917a 770
tobyspark 9:f83eadd8917a 771 fadeAPO = fadeAPercent / 100.0;
tobyspark 9:f83eadd8917a 772 tvOne.command(0, kTV1WindowIDA, kTV1FunctionAdjustWindowsMaxFadeLevel, fadeAPercent);
tobyspark 9:f83eadd8917a 773 }
tobyspark 9:f83eadd8917a 774
tobyspark 8:d46cc49f0f37 775 if (updateFade && debug)
tobyspark 8:d46cc49f0f37 776 {
tobyspark 0:87aab40d5806 777 debug->printf("\r\n");
tobyspark 0:87aab40d5806 778 //debug->printf("xFade = %3f fadeUp = %3f \r\n", xFadeAIN.read(), fadeUpAIN.read());
tobyspark 0:87aab40d5806 779 debug->printf("xFade = %3f fadeUp = %3f \r\n", xFadeAINCached, fadeUpAINCached);
tobyspark 0:87aab40d5806 780 debug->printf("xFade = %3f fadeUp = %3f fadeA% = %i fadeB% = %i \r\n", xFade, fadeUp, fadeAPercent, fadeBPercent);
tobyspark 0:87aab40d5806 781 }
tobyspark 5:f8b285ca41ba 782
tobyspark 0:87aab40d5806 783 }
tobyspark 0:87aab40d5806 784 }