first
							parent
							
								
									71b3cd5d87
								
							
						
					
					
						commit
						d98c683418
					
				
										
											Binary file not shown.
										
									
								
							|  | @ -0,0 +1,134 @@ | ||||||
|  | /*
 | ||||||
|  |  * @Author: dugulingping | ||||||
|  |  * @Date: 2022-06-09 17:14:49 | ||||||
|  |  * @LastEditTime: 2022-06-17 13:21:04 | ||||||
|  |  * @LastEditors: dugulingping | ||||||
|  |  * @Description:  | ||||||
|  |  * @FilePath: \project\BaFa_lutai_switch\BaFa_lutai_switch.ino | ||||||
|  |  */ | ||||||
|  | #include <ESP8266WiFi.h> | ||||||
|  | #include "PubSubClient.h" | ||||||
|  | 
 | ||||||
|  | // 引脚定义
 | ||||||
|  | #define LED_LOCAL 2 | ||||||
|  | #define SWITCH_PIN 0 | ||||||
|  | 
 | ||||||
|  | void turnOn(); | ||||||
|  | void turnOff(); | ||||||
|  | 
 | ||||||
|  | const char* ssid = "mdd520";           //修改,你的路由去WIFI名字
 | ||||||
|  | const char* password = "mj1688888888";     //你的WIFI密码
 | ||||||
|  | #define ID_MQTT  "ba6c540974354e998818b47472a8407d"     //用户私钥,控制台获取
 | ||||||
|  | const char*  topic = "lutaiValveSwitch006";     //主题名字
 | ||||||
|  | 
 | ||||||
|  | const char* mqtt_server = "bemfa.com"; //默认,MQTT服务器
 | ||||||
|  | const int mqtt_server_port = 9501;      //默认,MQTT服务器
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | WiFiClient espClient; | ||||||
|  | PubSubClient client(espClient); | ||||||
|  | 
 | ||||||
|  | void Bink_led(int ms){ | ||||||
|  |     Serial.print(">"); | ||||||
|  |     digitalWrite(LED_LOCAL, 0); | ||||||
|  |     delay(ms); | ||||||
|  |     digitalWrite(LED_LOCAL, 1); | ||||||
|  |     delay(ms); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void setup_wifi() { | ||||||
|  |   delay(10); | ||||||
|  |   Serial.println(); | ||||||
|  |   Serial.print("Connecting to "); | ||||||
|  |   Serial.println(ssid); | ||||||
|  |   WiFi.begin(ssid, password); | ||||||
|  |   while (WiFi.status() != WL_CONNECTED) { | ||||||
|  |     Bink_led(100); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   Serial.println(""); | ||||||
|  |   Serial.println("WiFi connected"); | ||||||
|  |   Serial.println("IP address: "); | ||||||
|  |   Serial.println(WiFi.localIP()); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void callback(char* topic, byte* payload, unsigned int length) { | ||||||
|  |     Serial.print("Topic:"); | ||||||
|  |     Serial.println(topic); | ||||||
|  |     String msg = ""; | ||||||
|  |     for (int i = 0; i < length; i++) { | ||||||
|  |         msg += (char)payload[i]; | ||||||
|  |     } | ||||||
|  |     Serial.print("Msg:"); | ||||||
|  |     Serial.println(msg); | ||||||
|  |     if (msg == "on") {        //on
 | ||||||
|  |         turnOn();                   //开
 | ||||||
|  |     } else if (msg == "off") {    //off
 | ||||||
|  |         turnOff();               //关
 | ||||||
|  |     } | ||||||
|  |     msg = ""; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void reconnect() { | ||||||
|  |     int num = 0; | ||||||
|  |     // Loop until we're reconnected
 | ||||||
|  |     while (!client.connected()) { | ||||||
|  |         Serial.print("Attempting MQTT connection..."); | ||||||
|  |         Bink_led(500); | ||||||
|  |         // Attempt to connect
 | ||||||
|  |         if (client.connect(ID_MQTT)) { | ||||||
|  |             Serial.println("connected"); | ||||||
|  |             Serial.print("subscribe:"); | ||||||
|  |             Serial.println(topic); | ||||||
|  |             //订阅主题,如果需要订阅多个主题,
 | ||||||
|  |             //可发送多条订阅指令client.subscribe(topic2);client.subscribe(topic3);
 | ||||||
|  |             client.subscribe(topic); | ||||||
|  |         } | ||||||
|  |         else if(num >= 100){ | ||||||
|  |             delay(5000); | ||||||
|  |             ESP.restart(); | ||||||
|  |         } else { | ||||||
|  |             Serial.print("failed, rc="); | ||||||
|  |             Serial.print(client.state()); | ||||||
|  |             Serial.println(" try again in 5 seconds"); | ||||||
|  |             delay(5000); | ||||||
|  |         } | ||||||
|  |         num++; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //开
 | ||||||
|  | void turnOn() { | ||||||
|  |     Serial.println("turn on swich"); | ||||||
|  |     digitalWrite(SWITCH_PIN, LOW); | ||||||
|  | } | ||||||
|  | //关
 | ||||||
|  | void turnOff() { | ||||||
|  |     Serial.println("turn off swich"); | ||||||
|  |     digitalWrite(SWITCH_PIN, HIGH); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void setup() { | ||||||
|  |     Serial.begin(115200); | ||||||
|  |     pinMode(LED_LOCAL, OUTPUT); | ||||||
|  |     pinMode(SWITCH_PIN, OUTPUT); | ||||||
|  |     delay(500); | ||||||
|  |     turnOff();      // 关闭
 | ||||||
|  |     setup_wifi(); | ||||||
|  |     client.setServer(mqtt_server, mqtt_server_port);//设置mqtt服务器
 | ||||||
|  |     client.setCallback(callback); //mqtt消息处理
 | ||||||
|  |      | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void loop() { | ||||||
|  |     if (WiFi.status() != WL_CONNECTED) { | ||||||
|  |         setup_wifi(); | ||||||
|  |         reconnect(); | ||||||
|  |     } | ||||||
|  |     if (!client.connected()){ | ||||||
|  |         reconnect(); | ||||||
|  |     } | ||||||
|  |     client.loop(); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | @ -0,0 +1,590 @@ | ||||||
|  | /*
 | ||||||
|  |   PubSubClient.cpp - A simple client for MQTT. | ||||||
|  |   Nick O'Leary | ||||||
|  |   http://knolleary.net
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | #include "PubSubClient.h" | ||||||
|  | #include "Arduino.h" | ||||||
|  | 
 | ||||||
|  | PubSubClient::PubSubClient() { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     this->_client = NULL; | ||||||
|  |     this->stream = NULL; | ||||||
|  |     setCallback(NULL); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient::PubSubClient(Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient::PubSubClient(IPAddress addr, uint16_t port, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(addr, port); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(IPAddress addr, uint16_t port, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(addr,port); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(IPAddress addr, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(addr, port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(IPAddress addr, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(addr,port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient::PubSubClient(uint8_t *ip, uint16_t port, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(ip, port); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(uint8_t *ip, uint16_t port, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(ip,port); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(uint8_t *ip, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(ip, port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(uint8_t *ip, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(ip,port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient::PubSubClient(const char* domain, uint16_t port, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(domain,port); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(const char* domain, uint16_t port, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(domain,port); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(const char* domain, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(domain,port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     this->stream = NULL; | ||||||
|  | } | ||||||
|  | PubSubClient::PubSubClient(const char* domain, uint16_t port, MQTT_CALLBACK_SIGNATURE, Client& client, Stream& stream) { | ||||||
|  |     this->_state = MQTT_DISCONNECTED; | ||||||
|  |     setServer(domain,port); | ||||||
|  |     setCallback(callback); | ||||||
|  |     setClient(client); | ||||||
|  |     setStream(stream); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::connect(const char *id) { | ||||||
|  |     return connect(id,NULL,NULL,0,0,0,0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::connect(const char *id, const char *user, const char *pass) { | ||||||
|  |     return connect(id,user,pass,0,0,0,0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::connect(const char *id, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage) { | ||||||
|  |     return connect(id,NULL,NULL,willTopic,willQos,willRetain,willMessage); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::connect(const char *id, const char *user, const char *pass, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage) { | ||||||
|  |     if (!connected()) { | ||||||
|  |         int result = 0; | ||||||
|  | 
 | ||||||
|  |         if (domain != NULL) { | ||||||
|  |             result = _client->connect(this->domain, this->port); | ||||||
|  |         } else { | ||||||
|  |             result = _client->connect(this->ip, this->port); | ||||||
|  |         } | ||||||
|  |         if (result == 1) { | ||||||
|  |             nextMsgId = 1; | ||||||
|  |             // Leave room in the buffer for header and variable length field
 | ||||||
|  |             uint16_t length = 5; | ||||||
|  |             unsigned int j; | ||||||
|  | 
 | ||||||
|  | #if MQTT_VERSION == MQTT_VERSION_3_1 | ||||||
|  |             uint8_t d[9] = {0x00,0x06,'M','Q','I','s','d','p', MQTT_VERSION}; | ||||||
|  | #define MQTT_HEADER_VERSION_LENGTH 9 | ||||||
|  | #elif MQTT_VERSION == MQTT_VERSION_3_1_1 | ||||||
|  |             uint8_t d[7] = {0x00,0x04,'M','Q','T','T',MQTT_VERSION}; | ||||||
|  | #define MQTT_HEADER_VERSION_LENGTH 7 | ||||||
|  | #endif | ||||||
|  |             for (j = 0;j<MQTT_HEADER_VERSION_LENGTH;j++) { | ||||||
|  |                 buffer[length++] = d[j]; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             uint8_t v; | ||||||
|  |             if (willTopic) { | ||||||
|  |                 v = 0x06|(willQos<<3)|(willRetain<<5); | ||||||
|  |             } else { | ||||||
|  |                 v = 0x02; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if(user != NULL) { | ||||||
|  |                 v = v|0x80; | ||||||
|  | 
 | ||||||
|  |                 if(pass != NULL) { | ||||||
|  |                     v = v|(0x80>>1); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             buffer[length++] = v; | ||||||
|  | 
 | ||||||
|  |             buffer[length++] = ((MQTT_KEEPALIVE) >> 8); | ||||||
|  |             buffer[length++] = ((MQTT_KEEPALIVE) & 0xFF); | ||||||
|  |             length = writeString(id,buffer,length); | ||||||
|  |             if (willTopic) { | ||||||
|  |                 length = writeString(willTopic,buffer,length); | ||||||
|  |                 length = writeString(willMessage,buffer,length); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if(user != NULL) { | ||||||
|  |                 length = writeString(user,buffer,length); | ||||||
|  |                 if(pass != NULL) { | ||||||
|  |                     length = writeString(pass,buffer,length); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             write(MQTTCONNECT,buffer,length-5); | ||||||
|  | 
 | ||||||
|  |             lastInActivity = lastOutActivity = millis(); | ||||||
|  | 
 | ||||||
|  |             while (!_client->available()) { | ||||||
|  |                 unsigned long t = millis(); | ||||||
|  |                 if (t-lastInActivity >= ((int32_t) MQTT_SOCKET_TIMEOUT*1000UL)) { | ||||||
|  |                     _state = MQTT_CONNECTION_TIMEOUT; | ||||||
|  |                     _client->stop(); | ||||||
|  |                     return false; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             uint8_t llen; | ||||||
|  |             uint16_t len = readPacket(&llen); | ||||||
|  | 
 | ||||||
|  |             if (len == 4) { | ||||||
|  |                 if (buffer[3] == 0) { | ||||||
|  |                     lastInActivity = millis(); | ||||||
|  |                     pingOutstanding = false; | ||||||
|  |                     _state = MQTT_CONNECTED; | ||||||
|  |                     return true; | ||||||
|  |                 } else { | ||||||
|  |                     _state = buffer[3]; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             _client->stop(); | ||||||
|  |         } else { | ||||||
|  |             _state = MQTT_CONNECT_FAILED; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     return true; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // reads a byte into result
 | ||||||
|  | boolean PubSubClient::readByte(uint8_t * result) { | ||||||
|  |    uint32_t previousMillis = millis(); | ||||||
|  |    while(!_client->available()) { | ||||||
|  |      uint32_t currentMillis = millis(); | ||||||
|  |      if(currentMillis - previousMillis >= ((int32_t) MQTT_SOCKET_TIMEOUT * 1000)){ | ||||||
|  |        return false; | ||||||
|  |      } | ||||||
|  |    } | ||||||
|  |    *result = _client->read(); | ||||||
|  |    return true; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // reads a byte into result[*index] and increments index
 | ||||||
|  | boolean PubSubClient::readByte(uint8_t * result, uint16_t * index){ | ||||||
|  |   uint16_t current_index = *index; | ||||||
|  |   uint8_t * write_address = &(result[current_index]); | ||||||
|  |   if(readByte(write_address)){ | ||||||
|  |     *index = current_index + 1; | ||||||
|  |     return true; | ||||||
|  |   } | ||||||
|  |   return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint16_t PubSubClient::readPacket(uint8_t* lengthLength) { | ||||||
|  |     uint16_t len = 0; | ||||||
|  |     if(!readByte(buffer, &len)) return 0; | ||||||
|  |     bool isPublish = (buffer[0]&0xF0) == MQTTPUBLISH; | ||||||
|  |     uint32_t multiplier = 1; | ||||||
|  |     uint16_t length = 0; | ||||||
|  |     uint8_t digit = 0; | ||||||
|  |     uint16_t skip = 0; | ||||||
|  |     uint8_t start = 0; | ||||||
|  | 
 | ||||||
|  |     do { | ||||||
|  |         if(!readByte(&digit)) return 0; | ||||||
|  |         buffer[len++] = digit; | ||||||
|  |         length += (digit & 127) * multiplier; | ||||||
|  |         multiplier *= 128; | ||||||
|  |     } while ((digit & 128) != 0); | ||||||
|  |     *lengthLength = len-1; | ||||||
|  | 
 | ||||||
|  |     if (isPublish) { | ||||||
|  |         // Read in topic length to calculate bytes to skip over for Stream writing
 | ||||||
|  |         if(!readByte(buffer, &len)) return 0; | ||||||
|  |         if(!readByte(buffer, &len)) return 0; | ||||||
|  |         skip = (buffer[*lengthLength+1]<<8)+buffer[*lengthLength+2]; | ||||||
|  |         start = 2; | ||||||
|  |         if (buffer[0]&MQTTQOS1) { | ||||||
|  |             // skip message id
 | ||||||
|  |             skip += 2; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     for (uint16_t i = start;i<length;i++) { | ||||||
|  |         if(!readByte(&digit)) return 0; | ||||||
|  |         if (this->stream) { | ||||||
|  |             if (isPublish && len-*lengthLength-2>skip) { | ||||||
|  |                 this->stream->write(digit); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (len < MQTT_MAX_PACKET_SIZE) { | ||||||
|  |             buffer[len] = digit; | ||||||
|  |         } | ||||||
|  |         len++; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (!this->stream && len > MQTT_MAX_PACKET_SIZE) { | ||||||
|  |         len = 0; // This will cause the packet to be ignored.
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return len; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::loop() { | ||||||
|  |     if (connected()) { | ||||||
|  |         unsigned long t = millis(); | ||||||
|  |         if ((t - lastInActivity > MQTT_KEEPALIVE*1000UL) || (t - lastOutActivity > MQTT_KEEPALIVE*1000UL)) { | ||||||
|  |             if (pingOutstanding) { | ||||||
|  |                 this->_state = MQTT_CONNECTION_TIMEOUT; | ||||||
|  |                 _client->stop(); | ||||||
|  |                 return false; | ||||||
|  |             } else { | ||||||
|  |                 buffer[0] = MQTTPINGREQ; | ||||||
|  |                 buffer[1] = 0; | ||||||
|  |                 _client->write(buffer,2); | ||||||
|  |                 lastOutActivity = t; | ||||||
|  |                 lastInActivity = t; | ||||||
|  |                 pingOutstanding = true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (_client->available()) { | ||||||
|  |             uint8_t llen; | ||||||
|  |             uint16_t len = readPacket(&llen); | ||||||
|  |             uint16_t msgId = 0; | ||||||
|  |             uint8_t *payload; | ||||||
|  |             if (len > 0) { | ||||||
|  |                 lastInActivity = t; | ||||||
|  |                 uint8_t type = buffer[0]&0xF0; | ||||||
|  |                 if (type == MQTTPUBLISH) { | ||||||
|  |                     if (callback) { | ||||||
|  |                         uint16_t tl = (buffer[llen+1]<<8)+buffer[llen+2]; | ||||||
|  |                         char topic[tl+1]; | ||||||
|  |                         for (uint16_t i=0;i<tl;i++) { | ||||||
|  |                             topic[i] = buffer[llen+3+i]; | ||||||
|  |                         } | ||||||
|  |                         topic[tl] = 0; | ||||||
|  |                         // msgId only present for QOS>0
 | ||||||
|  |                         if ((buffer[0]&0x06) == MQTTQOS1) { | ||||||
|  |                             msgId = (buffer[llen+3+tl]<<8)+buffer[llen+3+tl+1]; | ||||||
|  |                             payload = buffer+llen+3+tl+2; | ||||||
|  |                             callback(topic,payload,len-llen-3-tl-2); | ||||||
|  | 
 | ||||||
|  |                             buffer[0] = MQTTPUBACK; | ||||||
|  |                             buffer[1] = 2; | ||||||
|  |                             buffer[2] = (msgId >> 8); | ||||||
|  |                             buffer[3] = (msgId & 0xFF); | ||||||
|  |                             _client->write(buffer,4); | ||||||
|  |                             lastOutActivity = t; | ||||||
|  | 
 | ||||||
|  |                         } else { | ||||||
|  |                             payload = buffer+llen+3+tl; | ||||||
|  |                             callback(topic,payload,len-llen-3-tl); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } else if (type == MQTTPINGREQ) { | ||||||
|  |                     buffer[0] = MQTTPINGRESP; | ||||||
|  |                     buffer[1] = 0; | ||||||
|  |                     _client->write(buffer,2); | ||||||
|  |                 } else if (type == MQTTPINGRESP) { | ||||||
|  |                     pingOutstanding = false; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::publish(const char* topic, const char* payload) { | ||||||
|  |     return publish(topic,(const uint8_t*)payload,strlen(payload),false); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::publish(const char* topic, const char* payload, boolean retained) { | ||||||
|  |     return publish(topic,(const uint8_t*)payload,strlen(payload),retained); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::publish(const char* topic, const uint8_t* payload, unsigned int plength) { | ||||||
|  |     return publish(topic, payload, plength, false); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::publish(const char* topic, const uint8_t* payload, unsigned int plength, boolean retained) { | ||||||
|  |     if (connected()) { | ||||||
|  |         if (MQTT_MAX_PACKET_SIZE < 5 + 2+strlen(topic) + plength) { | ||||||
|  |             // Too long
 | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         // Leave room in the buffer for header and variable length field
 | ||||||
|  |         uint16_t length = 5; | ||||||
|  |         length = writeString(topic,buffer,length); | ||||||
|  |         uint16_t i; | ||||||
|  |         for (i=0;i<plength;i++) { | ||||||
|  |             buffer[length++] = payload[i]; | ||||||
|  |         } | ||||||
|  |         uint8_t header = MQTTPUBLISH; | ||||||
|  |         if (retained) { | ||||||
|  |             header |= 1; | ||||||
|  |         } | ||||||
|  |         return write(header,buffer,length-5); | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::publish_P(const char* topic, const uint8_t* payload, unsigned int plength, boolean retained) { | ||||||
|  |     uint8_t llen = 0; | ||||||
|  |     uint8_t digit; | ||||||
|  |     unsigned int rc = 0; | ||||||
|  |     uint16_t tlen; | ||||||
|  |     unsigned int pos = 0; | ||||||
|  |     unsigned int i; | ||||||
|  |     uint8_t header; | ||||||
|  |     unsigned int len; | ||||||
|  | 
 | ||||||
|  |     if (!connected()) { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     tlen = strlen(topic); | ||||||
|  | 
 | ||||||
|  |     header = MQTTPUBLISH; | ||||||
|  |     if (retained) { | ||||||
|  |         header |= 1; | ||||||
|  |     } | ||||||
|  |     buffer[pos++] = header; | ||||||
|  |     len = plength + 2 + tlen; | ||||||
|  |     do { | ||||||
|  |         digit = len % 128; | ||||||
|  |         len = len / 128; | ||||||
|  |         if (len > 0) { | ||||||
|  |             digit |= 0x80; | ||||||
|  |         } | ||||||
|  |         buffer[pos++] = digit; | ||||||
|  |         llen++; | ||||||
|  |     } while(len>0); | ||||||
|  | 
 | ||||||
|  |     pos = writeString(topic,buffer,pos); | ||||||
|  | 
 | ||||||
|  |     rc += _client->write(buffer,pos); | ||||||
|  | 
 | ||||||
|  |     for (i=0;i<plength;i++) { | ||||||
|  |         rc += _client->write((char)pgm_read_byte_near(payload + i)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     lastOutActivity = millis(); | ||||||
|  | 
 | ||||||
|  |     return rc == tlen + 4 + plength; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::write(uint8_t header, uint8_t* buf, uint16_t length) { | ||||||
|  |     uint8_t lenBuf[4]; | ||||||
|  |     uint8_t llen = 0; | ||||||
|  |     uint8_t digit; | ||||||
|  |     uint8_t pos = 0; | ||||||
|  |     uint16_t rc; | ||||||
|  |     uint16_t len = length; | ||||||
|  |     do { | ||||||
|  |         digit = len % 128; | ||||||
|  |         len = len / 128; | ||||||
|  |         if (len > 0) { | ||||||
|  |             digit |= 0x80; | ||||||
|  |         } | ||||||
|  |         lenBuf[pos++] = digit; | ||||||
|  |         llen++; | ||||||
|  |     } while(len>0); | ||||||
|  | 
 | ||||||
|  |     buf[4-llen] = header; | ||||||
|  |     for (int i=0;i<llen;i++) { | ||||||
|  |         buf[5-llen+i] = lenBuf[i]; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | #ifdef MQTT_MAX_TRANSFER_SIZE | ||||||
|  |     uint8_t* writeBuf = buf+(4-llen); | ||||||
|  |     uint16_t bytesRemaining = length+1+llen;  //Match the length type
 | ||||||
|  |     uint8_t bytesToWrite; | ||||||
|  |     boolean result = true; | ||||||
|  |     while((bytesRemaining > 0) && result) { | ||||||
|  |         bytesToWrite = (bytesRemaining > MQTT_MAX_TRANSFER_SIZE)?MQTT_MAX_TRANSFER_SIZE:bytesRemaining; | ||||||
|  |         rc = _client->write(writeBuf,bytesToWrite); | ||||||
|  |         result = (rc == bytesToWrite); | ||||||
|  |         bytesRemaining -= rc; | ||||||
|  |         writeBuf += rc; | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | #else | ||||||
|  |     rc = _client->write(buf+(4-llen),length+1+llen); | ||||||
|  |     lastOutActivity = millis(); | ||||||
|  |     return (rc == 1+llen+length); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::subscribe(const char* topic) { | ||||||
|  |     return subscribe(topic, 0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::subscribe(const char* topic, uint8_t qos) { | ||||||
|  |     if (qos < 0 || qos > 1) { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     if (MQTT_MAX_PACKET_SIZE < 9 + strlen(topic)) { | ||||||
|  |         // Too long
 | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     if (connected()) { | ||||||
|  |         // Leave room in the buffer for header and variable length field
 | ||||||
|  |         uint16_t length = 5; | ||||||
|  |         nextMsgId++; | ||||||
|  |         if (nextMsgId == 0) { | ||||||
|  |             nextMsgId = 1; | ||||||
|  |         } | ||||||
|  |         buffer[length++] = (nextMsgId >> 8); | ||||||
|  |         buffer[length++] = (nextMsgId & 0xFF); | ||||||
|  |         length = writeString((char*)topic, buffer,length); | ||||||
|  |         buffer[length++] = qos; | ||||||
|  |         return write(MQTTSUBSCRIBE|MQTTQOS1,buffer,length-5); | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::unsubscribe(const char* topic) { | ||||||
|  |     if (MQTT_MAX_PACKET_SIZE < 9 + strlen(topic)) { | ||||||
|  |         // Too long
 | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     if (connected()) { | ||||||
|  |         uint16_t length = 5; | ||||||
|  |         nextMsgId++; | ||||||
|  |         if (nextMsgId == 0) { | ||||||
|  |             nextMsgId = 1; | ||||||
|  |         } | ||||||
|  |         buffer[length++] = (nextMsgId >> 8); | ||||||
|  |         buffer[length++] = (nextMsgId & 0xFF); | ||||||
|  |         length = writeString(topic, buffer,length); | ||||||
|  |         return write(MQTTUNSUBSCRIBE|MQTTQOS1,buffer,length-5); | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void PubSubClient::disconnect() { | ||||||
|  |     buffer[0] = MQTTDISCONNECT; | ||||||
|  |     buffer[1] = 0; | ||||||
|  |     _client->write(buffer,2); | ||||||
|  |     _state = MQTT_DISCONNECTED; | ||||||
|  |     _client->stop(); | ||||||
|  |     lastInActivity = lastOutActivity = millis(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint16_t PubSubClient::writeString(const char* string, uint8_t* buf, uint16_t pos) { | ||||||
|  |     const char* idp = string; | ||||||
|  |     uint16_t i = 0; | ||||||
|  |     pos += 2; | ||||||
|  |     while (*idp) { | ||||||
|  |         buf[pos++] = *idp++; | ||||||
|  |         i++; | ||||||
|  |     } | ||||||
|  |     buf[pos-i-2] = (i >> 8); | ||||||
|  |     buf[pos-i-1] = (i & 0xFF); | ||||||
|  |     return pos; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | boolean PubSubClient::connected() { | ||||||
|  |     boolean rc; | ||||||
|  |     if (_client == NULL ) { | ||||||
|  |         rc = false; | ||||||
|  |     } else { | ||||||
|  |         rc = (int)_client->connected(); | ||||||
|  |         if (!rc) { | ||||||
|  |             if (this->_state == MQTT_CONNECTED) { | ||||||
|  |                 this->_state = MQTT_CONNECTION_LOST; | ||||||
|  |                 _client->flush(); | ||||||
|  |                 _client->stop(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return rc; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setServer(uint8_t * ip, uint16_t port) { | ||||||
|  |     IPAddress addr(ip[0],ip[1],ip[2],ip[3]); | ||||||
|  |     return setServer(addr,port); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setServer(IPAddress ip, uint16_t port) { | ||||||
|  |     this->ip = ip; | ||||||
|  |     this->port = port; | ||||||
|  |     this->domain = NULL; | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setServer(const char * domain, uint16_t port) { | ||||||
|  |     this->domain = domain; | ||||||
|  |     this->port = port; | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setCallback(MQTT_CALLBACK_SIGNATURE) { | ||||||
|  |     this->callback = callback; | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setClient(Client& client){ | ||||||
|  |     this->_client = &client; | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | PubSubClient& PubSubClient::setStream(Stream& stream){ | ||||||
|  |     this->stream = &stream; | ||||||
|  |     return *this; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int PubSubClient::state() { | ||||||
|  |     return this->_state; | ||||||
|  | } | ||||||
|  | @ -0,0 +1,144 @@ | ||||||
|  | /*
 | ||||||
|  |  PubSubClient.h - A simple client for MQTT. | ||||||
|  |   Nick O'Leary | ||||||
|  |   http://knolleary.net
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | #ifndef PubSubClient_h | ||||||
|  | #define PubSubClient_h | ||||||
|  | 
 | ||||||
|  | #include <Arduino.h> | ||||||
|  | #include "IPAddress.h" | ||||||
|  | #include "Client.h" | ||||||
|  | #include "Stream.h" | ||||||
|  | 
 | ||||||
|  | #define MQTT_VERSION_3_1      3 | ||||||
|  | #define MQTT_VERSION_3_1_1    4 | ||||||
|  | 
 | ||||||
|  | // MQTT_VERSION : Pick the version
 | ||||||
|  | //#define MQTT_VERSION MQTT_VERSION_3_1
 | ||||||
|  | #ifndef MQTT_VERSION | ||||||
|  | #define MQTT_VERSION MQTT_VERSION_3_1_1 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | // MQTT_MAX_PACKET_SIZE : Maximum packet size
 | ||||||
|  | #ifndef MQTT_MAX_PACKET_SIZE | ||||||
|  | #define MQTT_MAX_PACKET_SIZE 128 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | // MQTT_KEEPALIVE : keepAlive interval in Seconds
 | ||||||
|  | #ifndef MQTT_KEEPALIVE | ||||||
|  | #define MQTT_KEEPALIVE 15 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | // MQTT_SOCKET_TIMEOUT: socket timeout interval in Seconds
 | ||||||
|  | #ifndef MQTT_SOCKET_TIMEOUT | ||||||
|  | #define MQTT_SOCKET_TIMEOUT 15 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | // MQTT_MAX_TRANSFER_SIZE : limit how much data is passed to the network client
 | ||||||
|  | //  in each write call. Needed for the Arduino Wifi Shield. Leave undefined to
 | ||||||
|  | //  pass the entire MQTT packet in each write call.
 | ||||||
|  | //#define MQTT_MAX_TRANSFER_SIZE 80
 | ||||||
|  | 
 | ||||||
|  | // Possible values for client.state()
 | ||||||
|  | #define MQTT_CONNECTION_TIMEOUT     -4 | ||||||
|  | #define MQTT_CONNECTION_LOST        -3 | ||||||
|  | #define MQTT_CONNECT_FAILED         -2 | ||||||
|  | #define MQTT_DISCONNECTED           -1 | ||||||
|  | #define MQTT_CONNECTED               0 | ||||||
|  | #define MQTT_CONNECT_BAD_PROTOCOL    1 | ||||||
|  | #define MQTT_CONNECT_BAD_CLIENT_ID   2 | ||||||
|  | #define MQTT_CONNECT_UNAVAILABLE     3 | ||||||
|  | #define MQTT_CONNECT_BAD_CREDENTIALS 4 | ||||||
|  | #define MQTT_CONNECT_UNAUTHORIZED    5 | ||||||
|  | 
 | ||||||
|  | #define MQTTCONNECT     1 << 4  // Client request to connect to Server
 | ||||||
|  | #define MQTTCONNACK     2 << 4  // Connect Acknowledgment
 | ||||||
|  | #define MQTTPUBLISH     3 << 4  // Publish message
 | ||||||
|  | #define MQTTPUBACK      4 << 4  // Publish Acknowledgment
 | ||||||
|  | #define MQTTPUBREC      5 << 4  // Publish Received (assured delivery part 1)
 | ||||||
|  | #define MQTTPUBREL      6 << 4  // Publish Release (assured delivery part 2)
 | ||||||
|  | #define MQTTPUBCOMP     7 << 4  // Publish Complete (assured delivery part 3)
 | ||||||
|  | #define MQTTSUBSCRIBE   8 << 4  // Client Subscribe request
 | ||||||
|  | #define MQTTSUBACK      9 << 4  // Subscribe Acknowledgment
 | ||||||
|  | #define MQTTUNSUBSCRIBE 10 << 4 // Client Unsubscribe request
 | ||||||
|  | #define MQTTUNSUBACK    11 << 4 // Unsubscribe Acknowledgment
 | ||||||
|  | #define MQTTPINGREQ     12 << 4 // PING Request
 | ||||||
|  | #define MQTTPINGRESP    13 << 4 // PING Response
 | ||||||
|  | #define MQTTDISCONNECT  14 << 4 // Client is Disconnecting
 | ||||||
|  | #define MQTTReserved    15 << 4 // Reserved
 | ||||||
|  | 
 | ||||||
|  | #define MQTTQOS0        (0 << 1) | ||||||
|  | #define MQTTQOS1        (1 << 1) | ||||||
|  | #define MQTTQOS2        (2 << 1) | ||||||
|  | 
 | ||||||
|  | #ifdef ESP8266 | ||||||
|  | #include <functional> | ||||||
|  | #define MQTT_CALLBACK_SIGNATURE std::function<void(char*, uint8_t*, unsigned int)> callback | ||||||
|  | #else | ||||||
|  | #define MQTT_CALLBACK_SIGNATURE void (*callback)(char*, uint8_t*, unsigned int) | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | class PubSubClient { | ||||||
|  | private: | ||||||
|  |    Client* _client; | ||||||
|  |    uint8_t buffer[MQTT_MAX_PACKET_SIZE]; | ||||||
|  |    uint16_t nextMsgId; | ||||||
|  |    unsigned long lastOutActivity; | ||||||
|  |    unsigned long lastInActivity; | ||||||
|  |    bool pingOutstanding; | ||||||
|  |    MQTT_CALLBACK_SIGNATURE; | ||||||
|  |    uint16_t readPacket(uint8_t*); | ||||||
|  |    boolean readByte(uint8_t * result); | ||||||
|  |    boolean readByte(uint8_t * result, uint16_t * index); | ||||||
|  |    boolean write(uint8_t header, uint8_t* buf, uint16_t length); | ||||||
|  |    uint16_t writeString(const char* string, uint8_t* buf, uint16_t pos); | ||||||
|  |    IPAddress ip; | ||||||
|  |    const char* domain; | ||||||
|  |    uint16_t port; | ||||||
|  |    Stream* stream; | ||||||
|  |    int _state; | ||||||
|  | public: | ||||||
|  |    PubSubClient(); | ||||||
|  |    PubSubClient(Client& client); | ||||||
|  |    PubSubClient(IPAddress, uint16_t, Client& client); | ||||||
|  |    PubSubClient(IPAddress, uint16_t, Client& client, Stream&); | ||||||
|  |    PubSubClient(IPAddress, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client); | ||||||
|  |    PubSubClient(IPAddress, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client, Stream&); | ||||||
|  |    PubSubClient(uint8_t *, uint16_t, Client& client); | ||||||
|  |    PubSubClient(uint8_t *, uint16_t, Client& client, Stream&); | ||||||
|  |    PubSubClient(uint8_t *, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client); | ||||||
|  |    PubSubClient(uint8_t *, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client, Stream&); | ||||||
|  |    PubSubClient(const char*, uint16_t, Client& client); | ||||||
|  |    PubSubClient(const char*, uint16_t, Client& client, Stream&); | ||||||
|  |    PubSubClient(const char*, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client); | ||||||
|  |    PubSubClient(const char*, uint16_t, MQTT_CALLBACK_SIGNATURE,Client& client, Stream&); | ||||||
|  | 
 | ||||||
|  |    PubSubClient& setServer(IPAddress ip, uint16_t port); | ||||||
|  |    PubSubClient& setServer(uint8_t * ip, uint16_t port); | ||||||
|  |    PubSubClient& setServer(const char * domain, uint16_t port); | ||||||
|  |    PubSubClient& setCallback(MQTT_CALLBACK_SIGNATURE); | ||||||
|  |    PubSubClient& setClient(Client& client); | ||||||
|  |    PubSubClient& setStream(Stream& stream); | ||||||
|  | 
 | ||||||
|  |    boolean connect(const char* id); | ||||||
|  |    boolean connect(const char* id, const char* user, const char* pass); | ||||||
|  |    boolean connect(const char* id, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); | ||||||
|  |    boolean connect(const char* id, const char* user, const char* pass, const char* willTopic, uint8_t willQos, boolean willRetain, const char* willMessage); | ||||||
|  |    void disconnect(); | ||||||
|  |    boolean publish(const char* topic, const char* payload); | ||||||
|  |    boolean publish(const char* topic, const char* payload, boolean retained); | ||||||
|  |    boolean publish(const char* topic, const uint8_t * payload, unsigned int plength); | ||||||
|  |    boolean publish(const char* topic, const uint8_t * payload, unsigned int plength, boolean retained); | ||||||
|  |    boolean publish_P(const char* topic, const uint8_t * payload, unsigned int plength, boolean retained); | ||||||
|  |    boolean subscribe(const char* topic); | ||||||
|  |    boolean subscribe(const char* topic, uint8_t qos); | ||||||
|  |    boolean unsubscribe(const char* topic); | ||||||
|  |    boolean loop(); | ||||||
|  |    boolean connected(); | ||||||
|  |    int state(); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -0,0 +1,5 @@ | ||||||
|  | .pio | ||||||
|  | .vscode/.browse.c_cpp.db* | ||||||
|  | .vscode/c_cpp_properties.json | ||||||
|  | .vscode/launch.json | ||||||
|  | .vscode/ipch | ||||||
|  | @ -0,0 +1,10 @@ | ||||||
|  | { | ||||||
|  |     // See http://go.microsoft.com/fwlink/?LinkId=827846 | ||||||
|  |     // for the documentation about the extensions.json format | ||||||
|  |     "recommendations": [ | ||||||
|  |         "platformio.platformio-ide" | ||||||
|  |     ], | ||||||
|  |     "unwantedRecommendations": [ | ||||||
|  |         "ms-vscode.cpptools-extension-pack" | ||||||
|  |     ] | ||||||
|  | } | ||||||
|  | @ -0,0 +1,39 @@ | ||||||
|  | 
 | ||||||
|  | This directory is intended for project header files. | ||||||
|  | 
 | ||||||
|  | A header file is a file containing C declarations and macro definitions | ||||||
|  | to be shared between several project source files. You request the use of a | ||||||
|  | header file in your project source file (C, C++, etc) located in `src` folder | ||||||
|  | by including it, with the C preprocessing directive `#include'. | ||||||
|  | 
 | ||||||
|  | ```src/main.c | ||||||
|  | 
 | ||||||
|  | #include "header.h" | ||||||
|  | 
 | ||||||
|  | int main (void) | ||||||
|  | { | ||||||
|  |  ... | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Including a header file produces the same results as copying the header file | ||||||
|  | into each source file that needs it. Such copying would be time-consuming | ||||||
|  | and error-prone. With a header file, the related declarations appear | ||||||
|  | in only one place. If they need to be changed, they can be changed in one | ||||||
|  | place, and programs that include the header file will automatically use the | ||||||
|  | new version when next recompiled. The header file eliminates the labor of | ||||||
|  | finding and changing all the copies as well as the risk that a failure to | ||||||
|  | find one copy will result in inconsistencies within a program. | ||||||
|  | 
 | ||||||
|  | In C, the usual convention is to give header files names that end with `.h'. | ||||||
|  | It is most portable to use only letters, digits, dashes, and underscores in | ||||||
|  | header file names, and at most one dot. | ||||||
|  | 
 | ||||||
|  | Read more about using header files in official GCC documentation: | ||||||
|  | 
 | ||||||
|  | * Include Syntax | ||||||
|  | * Include Operation | ||||||
|  | * Once-Only Headers | ||||||
|  | * Computed Includes | ||||||
|  | 
 | ||||||
|  | https://gcc.gnu.org/onlinedocs/cpp/Header-Files.html | ||||||
|  | @ -0,0 +1,46 @@ | ||||||
|  | 
 | ||||||
|  | This directory is intended for project specific (private) libraries. | ||||||
|  | PlatformIO will compile them to static libraries and link into executable file. | ||||||
|  | 
 | ||||||
|  | The source code of each library should be placed in a an own separate directory | ||||||
|  | ("lib/your_library_name/[here are source files]"). | ||||||
|  | 
 | ||||||
|  | For example, see a structure of the following two libraries `Foo` and `Bar`: | ||||||
|  | 
 | ||||||
|  | |--lib | ||||||
|  | |  | | ||||||
|  | |  |--Bar | ||||||
|  | |  |  |--docs | ||||||
|  | |  |  |--examples | ||||||
|  | |  |  |--src | ||||||
|  | |  |     |- Bar.c | ||||||
|  | |  |     |- Bar.h | ||||||
|  | |  |  |- library.json (optional, custom build options, etc) https://docs.platformio.org/page/librarymanager/config.html | ||||||
|  | |  | | ||||||
|  | |  |--Foo | ||||||
|  | |  |  |- Foo.c | ||||||
|  | |  |  |- Foo.h | ||||||
|  | |  | | ||||||
|  | |  |- README --> THIS FILE | ||||||
|  | | | ||||||
|  | |- platformio.ini | ||||||
|  | |--src | ||||||
|  |    |- main.c | ||||||
|  | 
 | ||||||
|  | and a contents of `src/main.c`: | ||||||
|  | ``` | ||||||
|  | #include <Foo.h> | ||||||
|  | #include <Bar.h> | ||||||
|  | 
 | ||||||
|  | int main (void) | ||||||
|  | { | ||||||
|  |   ... | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | PlatformIO Library Dependency Finder will find automatically dependent | ||||||
|  | libraries scanning project source files. | ||||||
|  | 
 | ||||||
|  | More information about PlatformIO Library Dependency Finder | ||||||
|  | - https://docs.platformio.org/page/librarymanager/ldf.html | ||||||
|  | @ -0,0 +1,15 @@ | ||||||
|  | ; PlatformIO Project Configuration File | ||||||
|  | ; | ||||||
|  | ;   Build options: build flags, source filter | ||||||
|  | ;   Upload options: custom upload port, speed and extra flags | ||||||
|  | ;   Library options: dependencies, extra library storages | ||||||
|  | ;   Advanced options: extra scripting | ||||||
|  | ; | ||||||
|  | ; Please visit documentation for the other options and examples | ||||||
|  | ; https://docs.platformio.org/page/projectconf.html | ||||||
|  | 
 | ||||||
|  | [env:nodemcuv2] | ||||||
|  | platform = espressif8266 | ||||||
|  | board = nodemcuv2 | ||||||
|  | framework = arduino | ||||||
|  | monitor_speed = 115200 | ||||||
|  | @ -0,0 +1,46 @@ | ||||||
|  | /*
 | ||||||
|  |  * @Author: dugulingping | ||||||
|  |  * @Date: 2022-06-09 17:14:49 | ||||||
|  |  * @LastEditTime: 2022-06-15 22:03:52 | ||||||
|  |  * @LastEditors: dugulingping | ||||||
|  |  * @Description:  | ||||||
|  |  * @FilePath: \test\SmartComfigWIFI\SmartComfigWIFI.ino | ||||||
|  |  */ | ||||||
|  | #include <ESP8266WiFi.h> | ||||||
|  | void smartConfig() | ||||||
|  | { | ||||||
|  |   WiFi.mode(WIFI_STA); //设置WIFI模块为STA模式
 | ||||||
|  |   Serial.begin(115200); | ||||||
|  |   Serial.println("\r\nWaiting for connection"); | ||||||
|  |   //smartconfig进行初始化
 | ||||||
|  |   WiFi.beginSmartConfig(); | ||||||
|  |   while (1) //等待连接成功
 | ||||||
|  |   { | ||||||
|  |     Serial.print(">"); | ||||||
|  |     digitalWrite(LED_BUILTIN, 0); | ||||||
|  |     delay(100); | ||||||
|  |     digitalWrite(LED_BUILTIN, 1); | ||||||
|  |     delay(100); | ||||||
|  |     //如果连接成功后就打印出连接的WIFI信息
 | ||||||
|  |     if (WiFi.smartConfigDone()) | ||||||
|  |     { | ||||||
|  |     Serial.println("SmartConfig Success"); | ||||||
|  |     Serial.printf("SSID:%s", WiFi.SSID().c_str()); | ||||||
|  |     Serial.printf("PW:%s", WiFi.psk().c_str());//打印出密码
 | ||||||
|  |     break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void setup() { | ||||||
|  |   pinMode(LED_BUILTIN, OUTPUT);      | ||||||
|  |   smartConfig(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void loop() { | ||||||
|  |   digitalWrite(LED_BUILTIN, LOW);   // Turn the LED on (Note that LOW is the voltage level
 | ||||||
|  |   delay(1000);                      // Wait for a second
 | ||||||
|  |   digitalWrite(LED_BUILTIN, HIGH);  // Turn the LED off by making the voltage HIGH
 | ||||||
|  |   delay(1000);                      // Wait for two seconds (to demonstrate the active low LED)
 | ||||||
|  | } | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | 
 | ||||||
|  | This directory is intended for PlatformIO Test Runner and project tests. | ||||||
|  | 
 | ||||||
|  | Unit Testing is a software testing method by which individual units of | ||||||
|  | source code, sets of one or more MCU program modules together with associated | ||||||
|  | control data, usage procedures, and operating procedures, are tested to | ||||||
|  | determine whether they are fit for use. Unit testing finds problems early | ||||||
|  | in the development cycle. | ||||||
|  | 
 | ||||||
|  | More information about PlatformIO Unit Testing: | ||||||
|  | - https://docs.platformio.org/en/latest/advanced/unit-testing/index.html | ||||||
|  | @ -0,0 +1,116 @@ | ||||||
|  | /*
 | ||||||
|  |  * @Author: dugulingping | ||||||
|  |  * @Date: 2022-04-17 16:00:40 | ||||||
|  |  * @LastEditTime: 2022-06-16 02:38:58 | ||||||
|  |  * @LastEditors: dugulingping | ||||||
|  |  * @Description:  | ||||||
|  |  * @FilePath: \project\asd\asd.ino | ||||||
|  |  */ | ||||||
|  | #include "DHT.h" | ||||||
|  | // DHT11
 | ||||||
|  | #define DHTPIN 4 | ||||||
|  | #define DHTTYPE DHT22   // DHT 11
 | ||||||
|  | //LED
 | ||||||
|  | #define SCLK 14 | ||||||
|  | #define RCLK 13 | ||||||
|  | #define DIO 15 | ||||||
|  | 
 | ||||||
|  | DHT dht(DHTPIN, DHTTYPE); | ||||||
|  | //定义字库
 | ||||||
|  | unsigned char LED_0F[] = { | ||||||
|  |     // 0	 1	  2	   3	4	 5	  6	   7	8	 9	  A	   b	C    d	  E    F    -
 | ||||||
|  |     0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x8C,0xBF,0xC6,0xA1,0x86,0xFF,0xbf | ||||||
|  | }; | ||||||
|  | //定义位
 | ||||||
|  | unsigned char LED_BIT[] = { | ||||||
|  |     //  1   2   3   4   1+2   3+4   1~4
 | ||||||
|  |     0x01,0x02,0x04,0x08,0x03,0x0C,0x0F | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | //定义dht数据
 | ||||||
|  | int dhtdata[3] = {0}; | ||||||
|  | 
 | ||||||
|  | void setup() { | ||||||
|  |     Serial.begin(115200); | ||||||
|  |     dht.begin(); | ||||||
|  |     //让三个脚都是输出状态
 | ||||||
|  |     pinMode(SCLK,OUTPUT); | ||||||
|  |     pinMode(RCLK,OUTPUT); | ||||||
|  |     pinMode(DIO,OUTPUT);  | ||||||
|  | 
 | ||||||
|  |    | ||||||
|  | } | ||||||
|  | //定时
 | ||||||
|  | int delay_date = 0; | ||||||
|  | void loop() { | ||||||
|  |     if(delay_date < 2000){ | ||||||
|  |         delay_date+=4; | ||||||
|  |     }else{ | ||||||
|  |         delay_date = 0; | ||||||
|  |         DHT_Data(); | ||||||
|  |     } | ||||||
|  |     if(!dhtdata[1]||!dhtdata[2]){ | ||||||
|  |         LED_display(LED_BIT[6], 0xBF); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |     int num1 = dhtdata[0]%10; | ||||||
|  |     int num2 = dhtdata[0]/10; | ||||||
|  |     int num3 = dhtdata[2]%10; | ||||||
|  |     int num4 = dhtdata[2]/10; | ||||||
|  | 
 | ||||||
|  |     LED_display(LED_BIT[2], LED_0F[num1]-128); | ||||||
|  |     LED_display(LED_BIT[3], LED_0F[num2]); | ||||||
|  |     LED_display(LED_BIT[0], LED_0F[num3]-128); | ||||||
|  |     LED_display(LED_BIT[1], LED_0F[num4]); | ||||||
|  | 
 | ||||||
|  |     //LED_display(LED_BIT[2], LED_0F[data_split(dhtdata[0])[0]]-128);
 | ||||||
|  |     //LED_display(LED_BIT[1], LED_0F[data_split(dhtdata[2])[1]]);
 | ||||||
|  |     //LED_display(LED_BIT[0], LED_0F[data_split(dhtdata[2])[0]]);
 | ||||||
|  |      | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void LED_display(unsigned char bit, unsigned char digit ){ | ||||||
|  |     LED_OUT(digit); | ||||||
|  |     LED_OUT(bit); | ||||||
|  |     digitalWrite(RCLK,LOW); | ||||||
|  |     digitalWrite(RCLK,HIGH); | ||||||
|  |     delay(1); | ||||||
|  | } | ||||||
|  | void LED_OUT(unsigned char X){ | ||||||
|  |     unsigned char i; | ||||||
|  |     for(i=8;i>=1;i--) | ||||||
|  |     { | ||||||
|  |         if(X&0x80) | ||||||
|  |             digitalWrite(DIO,HIGH); | ||||||
|  |         else | ||||||
|  |             digitalWrite(DIO,LOW); | ||||||
|  |         X<<=1; | ||||||
|  |         digitalWrite(SCLK,LOW); | ||||||
|  |         digitalWrite(SCLK,HIGH); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int * data_split(int num){ | ||||||
|  |     int res[2] = {0}; | ||||||
|  |     for(int i = 0; num > 0; i++){ | ||||||
|  |         res[i] = num%10; | ||||||
|  |     } | ||||||
|  |     return res; | ||||||
|  | } | ||||||
|  | void DHT_Data(){ | ||||||
|  |     float h = dht.readHumidity(); | ||||||
|  |     float t = dht.readTemperature(false); | ||||||
|  |     float hic = dht.computeHeatIndex(t, h, false); | ||||||
|  | 
 | ||||||
|  |     if (isnan(h) || isnan(t)){ | ||||||
|  |         Serial.println(F("Failed to read from DHT sensor!")); | ||||||
|  |         dhtdata[0] = 0; | ||||||
|  |         dhtdata[1] = 0; | ||||||
|  |         dhtdata[2] = 0; | ||||||
|  |     return; | ||||||
|  |     } | ||||||
|  |     dhtdata[0] = h; | ||||||
|  |     dhtdata[1] = t; | ||||||
|  |     dhtdata[2] = hic; | ||||||
|  |     Serial.println(h); | ||||||
|  | } | ||||||
|  | @ -0,0 +1,21 @@ | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  |  * @Author: dugulingping | ||||||
|  |  * @Date: 2022-04-13 03:06:22 | ||||||
|  |  * @LastEditTime: 2022-06-16 17:48:41 | ||||||
|  |  * @LastEditors: dugulingping | ||||||
|  |  * @Description: testLED | ||||||
|  |  * @FilePath: \project\test\test.ino | ||||||
|  |  */ | ||||||
|  | int LED = 0; | ||||||
|  | void setup(){ | ||||||
|  |   pinMode(LED,OUTPUT); | ||||||
|  |   digitalWrite(LED,0); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | void loop(){ | ||||||
|  |   digitalWrite(LED,1); | ||||||
|  |   delay(1000); | ||||||
|  |   digitalWrite(LED,0); | ||||||
|  |   delay(1000); | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue