Dreameforce 2013 giveaway demo

Dependencies:   C12832_lcd EthernetInterface LM75B MMA7660 libxively mbed-rtos mbed

Fork of xively-dreamforce by Ilya Dmitrichenko

Revision:
15:7443df31ff5b
Parent:
11:bdf601a405fc
Child:
19:ca595d80895b
--- a/app_board_io.cpp	Sat Nov 09 10:15:50 2013 +0000
+++ b/app_board_io.cpp	Mon Nov 11 17:33:56 2013 +0000
@@ -1,4 +1,6 @@
+#include "mbed.h"
 #include "app_board_io.h"
+
 #include "C12832_lcd.h"
 
 extern C12832_LCD lcd;
@@ -16,4 +18,102 @@
     lcd.locate( 0, 3 );
     lcd.printf( buffer );
     //wait( 1.0 );
+}
+
+/**
+  * Demo for the RGB Led on the mbed Lab Board
+  * Pot 2 changes the color 
+  * Pot 1 changes the value
+  * the saturation is set to maximum
+  * 
+  * Based on:
+  * https://mbed.org/users/dreschpe/code/app-board-RGB2/
+  *
+  * Copyright (c) 2012 Peter Drescher - DC2PD
+  */
+
+/* the led's are connected to vcc, so a PwmOut of 100% will shut off the led and 0% will let it shine ! */
+PwmOut r (p23);
+PwmOut g (p24);
+PwmOut b (p25);
+
+AnalogIn pot1(p19);
+AnalogIn pot2(p20);
+
+// function to convert hue , saturation and  value to RGB
+// see http://en.wikipedia.org/wiki/HSL_and_HSV
+void hsv2rgb(float H,float S, float V)
+{
+    float f,h,p,q,t;
+    int i;
+    if( S == 0.0) {
+        r = 1.0 - V;  // invert pwm !
+        g = 1.0 - V;
+        b = 1.0 - V;
+        return;
+    }
+    if(H > 360.0) H = 0.0;   // check values
+    if(S > 1.0) S = 1.0; 
+    if(S < 0.0) S = 0.0;
+    if(V > 1.0) V = 1.0;
+    if(V < 0.0) V = 0.0;
+    h = H / 60.0;
+    i = (int) h;
+    f = h - i;
+    p = V * (1.0 - S);
+    q = V * (1.0 - (S * f));
+    t = V * (1.0 - (S * (1.0 - f)));
+
+    switch(i) {
+        case 0:
+            r = 1.0 - V;  // invert pwm !
+            g = 1.0 - t;
+            b = 1.0 - p;
+            break;
+        case 1:
+            r = 1.0 - q;
+            g = 1.0 - V;
+            b = 1.0 - p;
+            break;
+        case 2:
+            r = 1.0 - p;
+            g = 1.0 - V;
+            b = 1.0 - t;
+            break;
+        case 3:
+            r = 1.0 - p;
+            g = 1.0 - q;
+            b = 1.0 - V;
+            break;
+        case 4:
+            r = 1.0 - t;
+            g = 1.0 - p;
+            b = 1.0 - V;
+            break;
+        case 5:
+        default:
+            r = 1.0 - V;
+            g = 1.0 - p;
+            b = 1.0 - q;
+            break;
+    }
+}
+
+void rgbpwm_thread(void const *args)
+{
+    float h, s, v;
+    
+    r.period(0.001);  // set pwm period
+    s = 1.0;
+    while(true){
+
+        h = (pot1.read_u16() >> 6) * 0.3515625;  // truncate to 10 bits and scale to 0 - 360;
+
+
+        v = (pot2.read_u16() >> 6) * 0.0009765624; // truncate and scale to 0 - 1;
+
+        hsv2rgb(h,s,v);
+        
+        wait_ms(500);
+    }
 }
\ No newline at end of file