Fork
Dependencies: Motordriver mbed-rtos mbed
Fork of ESP8266-WEB-Mbed-LPC1768-Controller by
Diff: main.cpp
- Revision:
- 2:d4c6bc0f2dc4
- Parent:
- 1:71ed1afbf344
- Child:
- 3:f7febfa77784
diff -r 71ed1afbf344 -r d4c6bc0f2dc4 main.cpp --- a/main.cpp Sun Feb 15 12:05:58 2015 +0000 +++ b/main.cpp Thu Feb 19 23:47:54 2015 +0000 @@ -6,53 +6,58 @@ Serial pc(USBTX, USBRX); Serial esp(PTE0, PTE1); // tx, rx +DS18B20 thermom(A0, DS18B20::RES_12_BIT); + // Standard Mbed LED definitions DigitalOut led1(LED_RED); // (PTB18) DigitalOut led2(LED_GREEN); // (PTB19) DigitalOut led3(LED_BLUE); // (PTD1) // Digital Out and In pins, can be configured to any suitable pin depending on Platform -DigitalOut Out1(PTC7); -DigitalOut Out2(PTC0); -DigitalOut Out3(PTC3); +DigitalOut Out1(D7); +DigitalOut Out2(D8); +DigitalOut Out3(D4); -DigitalIn In1(PTC12); -DigitalIn In2(PTC13); -DigitalIn In3(PTC16); +DigitalIn In1(A2); +DigitalIn In2(A3); +DigitalIn In3(A4); -AnalogIn BATin(PTC1); - -DS18B20 thermom(PTB0, DS18B20::RES_12_BIT); +PwmOut speaker(D5); +AnalogIn BATin(A1); Timer t1; Timer t2; struct tm t; -int buflen, DataRX, count, ended, servreq, timeout; -int bufl, ipdLen, linkID, weberror; +int buflen, DataRX, count, getcount, ended, servreq, timeout; +int bufl, ipdLen, linkID, weberror, webcounter; float temperature, AdcIn, Ht; float R1=100000, R2=10000; // resistor values to give a 10:1 reduction of measured AnalogIn voltage char Vcc[10]; char Temp[10]; char temp[10]; +char webcount[8]; +char lasthit[60]; char timebuf[30]; char type[16]; char type1[16]; char channel[2]; char snd[256]; char webdata[1024]; // This may need to be bigger depending on WEB browser used -char buf[2048]; // Currently using 1407 characters, Increase this if more web page data added +char buf[4096]; // Currently using 1407 characters, Increase this if more web page data added void SendCMD(),getreply(),ReadWebData(),startserver(),sendpage(),SendWEB(),sendcheck(); -void gettime(),gettemp(),getbattery(),setRTC(); +void gettime(),gettemp(),getbattery(),setRTC(),beep(); // manual set RTC values -int minute =58; // 0-59 -int hour =11; // 2-23 -int dayofmonth =15; // 1-31 +int minute =13; // 0-59 +int hour =15; // 2-23 +int dayofmonth =19; // 1-31 int month =2; // 1-12 int year =15; // last 2 digits + +int port =90; // set server port // Serial Interrupt read ESP data void callback() { @@ -65,38 +70,46 @@ pc.baud(115200); esp.baud(115200); // ESP8266 baudrate. if (time(NULL) < 1420070400) {setRTC();} - + beep(); startserver(); while(1){ if(DataRX==1){ ReadWebData(); + beep(); if (servreq == 1 && weberror == 0){sendpage();} pc.printf(" IPD Data:\r\n\n Link ID = %d,\r\n IPD Header Length = %d \r\n IPD Type = %s\r\n", linkID, ipdLen, type); pc.printf("\n\n HTTP Packet: \n\n%s\n", webdata); pc.printf(" Web Characters sent : %d\n\n", bufl); pc.printf(" -------------------------------------\n\n"); esp.attach(&callback); + strcpy(lasthit, timebuf); servreq=0; - } + } + if(t2.read()>900){startserver();} // restart server every 15 minutes after no activity in case of ESP lock out. } } // Static WEB page void sendpage() { - gettemp();getbattery();gettime(); -// WEB page data + gettemp();getbattery();gettime(); memset(buf, '\0', sizeof(buf)); - strcpy(buf, "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\nPragma: no-cache\r\n\r\n"); - strcat(buf, "<html><head><title>ESP8266 Mbed</title></head>\r\n"); - strcat(buf, "<body>\r\n"); - strcat(buf, "<h1>ESP8266 Mbed Web Controller</h1>\r\n"); - strcat(buf, "<br /><hr>\r\n"); + +// WEB page data + strcpy(buf, "<!DOCTYPE html>"); + strcat(buf, "<html><head><title>ESP8266 Mbed</title></head>"); + strcat(buf, "<body>"); + strcat(buf, "<div style=\"text-align:center; background-color:#F4F4F4; color:#00AEDB;\"><h1>ESP8266 Mbed Web Controller</h1>"); + strcat(buf, "Hit Count - "); + strcat(buf, webcount); + strcat(buf, "<br>Last Hit - "); + strcat(buf, lasthit); + strcat(buf, "</div><br /><hr>"); strcat(buf, "<h3>Mbed RTC Time - "); strcat(buf, timebuf); strcat(buf, "</h3>\r\n"); - strcat(buf, "<p><form method=\"POST\"><strong> Temperature: <input type=\"text\" size=4 value=\""); + strcat(buf, "<p><form method=\"POST\"><strong> Temperature: <input type=\"text\" size=6 value=\""); strcat(buf, Temp); strcat(buf, "\"> <sup>O</sup>C <form method=\"POST\"> <strong> Battery: <input type=\"text\" size=4 value=\""); strcat(buf, Vcc); @@ -122,20 +135,29 @@ if(In2==0){strcat(buf, "<br><input type=\"radio\" name=\"In2\" value=\"0\" > Digital In 2");} else{strcat(buf, "<br><input type=\"radio\" name=\"In2\" value=\"1\" checked> Digital In 2");} if(In3==0){strcat(buf, "<br><input type=\"radio\" name=\"In3\" value=\"0\" > Digital In 3");} - else{strcat(buf, "<br><input type=\"radio\" name=\"In3\" value=\"1\" checked> Digital In 3");} - strcat(buf, "</strong><p><input type=\"submit\"></form></span>"); - strcat(buf, "</body>\r\n</html>\r\n"); + else{strcat(buf, "<br><input type=\"radio\" name=\"In3\" value=\"1\" checked> Digital In 3");} + strcat(buf, "</strong><p><input type=\"submit\" value=\"send-refresh\" style=\"background: #3498db;"); + strcat(buf, "background-image:-webkit-linear-gradient(top, #3498db, #2980b9);"); + strcat(buf, "background-image:linear-gradient(to bottom, #3498db, #2980b9);"); + strcat(buf, "-webkit-border-radius:12;border-radius: 12px;font-family: Arial;color:#ffffff;font-size:20px;padding:"); + strcat(buf, "10px 20px 10px 20px; border:solid #103c57 3px;text-decoration: none;"); + strcat(buf, "background: #3cb0fd;"); + strcat(buf, "background-image:-webkit-linear-gradient(top,#3cb0fd,#1a5f8a);"); + strcat(buf, "background-image:linear-gradient(to bottom,#3cb0fd,#1a5f8a);"); + strcat(buf, "text-decoration:none;\"></form></span>"); strcat(buf, "<p/><h2>How to use:</h2><ul>"); strcat(buf, "<li>Select the Radio buttons to control the digital out pins.</li>"); - strcat(buf, "<li>Click 'Submit Query' to send.</li>"); - strcat(buf, "<li>Use the 'Submit Query' button to refresh the page.</li>"); + strcat(buf, "<li>Click 'Send-Refresh' to send.</li>"); + strcat(buf, "<li>Use the 'Send-Refresh' button to refresh the data.</li>"); strcat(buf, "</ul>"); + strcat(buf, "</body></html>"); // end of WEB page data bufl = strlen(buf); // get total page buffer length sprintf(snd,"AT+CIPSEND=%s,%d\r\n", channel, bufl); // send IPD link channel and buffer character length. SendCMD(); wait_ms(100); SendWEB(); // send web page + memset(buf, '\0', sizeof(buf)); sendcheck(); } @@ -148,7 +170,7 @@ getreply(); if (strstr(buf, "SEND OK") != NULL) {weberror=0;} // wait for valid SEND OK } - t2.stop(); + t2.reset(); if(weberror==1){ pc.printf("\n\n\n ++++++++++ WEB Connect Error, restarting ... ++++++++++\n\n"); NVIC_SystemReset();} @@ -178,8 +200,10 @@ sprintf(channel, "%d",linkID); if (strstr(webdata, "GET") != NULL) {servreq=1;} if (strstr(webdata, "POST") != NULL) {servreq=1;} + webcounter++; + sprintf(webcount, "%d",webcounter); } - else {strcpy(webdata, buf);weberror=1;} + else {strcpy(webdata, buf);weberror=1;} led3=1; } // Starts and restarts webserver if errors detected. @@ -192,19 +216,22 @@ pc.printf("++++++++++ Resetting ESP ++++++++++\r\n"); strcpy(snd,"AT+RST\r\n"); SendCMD(); - timeout=2000; + timeout=2000;getcount=336; getreply(); if (strstr(buf, "ready") != NULL) { pc.printf("\n++++++++++ Starting Server ++++++++++\r\n"); strcpy(snd, "AT+CIPMUX=1\r\n"); // set multiple connections. SendCMD(); - wait_ms(50); - strcpy(snd, "AT+CIPSERVER=1,80\r\n"); // set to port 80, you can change this to what you want. + timeout=500;getcount=10; + getreply(); + strcpy(snd, "AT+CIPSERVER=1,90\r\n"); + //sprintf(snd,"AT+CIPSERVER=1,%d\r\n", port); SendCMD(); - wait_ms(200); + timeout=500;getcount=10; + getreply(); pc.printf("\n Getting Server IP \r\n"); strcpy(snd, "AT+CIFSR\r\n"); - timeout=500; + timeout=1000;getcount=50; while(weberror==0){ SendCMD();getreply(); if (strstr(buf, "0.0.0.0") == NULL) {weberror=1;} // wait for valid IP @@ -212,7 +239,7 @@ pc.printf("\n Enter WEB address in your browser \r\n\n"); buf[strlen(buf) - 8] = '\0'; char* IP = buf + 5; - sprintf(snd," http://%s:80", IP); + sprintf(snd," http://%s:%d", IP, port); pc.printf(snd); while (esp.readable()){esp.getc();} buflen=200;count=0; @@ -224,7 +251,8 @@ else{ pc.printf("\n++++++++++ ESP8266 error, check power/connections ++++++++++\r\n"); while(1){} - } + } + t2.reset();t2.start();beep(); } // ESP Command data send void SendCMD() @@ -243,27 +271,25 @@ void getreply() { memset(buf, '\0', sizeof(buf)); - t1.start(); + t1.reset(); t1.start(); ended=0;count=0; - while(!ended) { + while(t1.read_ms()< timeout && count < getcount) { if(esp.readable()) { buf[count] = esp.getc();count++; } - if(t1.read_ms() > timeout) { - ended = 1;t1.stop();t1.reset(); - } - } + } + t1.stop(); } // Analog in example void getbattery() { AdcIn=BATin.read(); - Ht = (AdcIn*3.328*(R1+R2)/R2); // set the numeric to the exact MCU analog reference voltage for greater accuracy + Ht = (AdcIn*3.328f*(R1+R2)/R2); // set the numeric to the exact MCU analog reference voltage for greater accuracy sprintf(Vcc,"%2.3f",Ht); } // Temperature example void gettemp() -{ +{ temperature=thermom.GetTemperature(); // comment this out if no sensor connected //temperature = 21.357; // include for dummy value sprintf(Temp,"%3.3f",temperature); @@ -275,6 +301,14 @@ strftime(timebuf,50,"%H:%M:%S %a %d %b %y", localtime(&seconds)); } +void beep() +{ + speaker.period(1.0/2000); // 2000hz period + speaker = 0.5; //50% duty cycle - max volume + wait_ms(60); + speaker=0.0; // turn off audio +} + void setRTC() { t.tm_sec = (0); // 0-59