mirror of
https://git.mirrors.martin98.com/https://github.com/luc-github/ESP3D.git
synced 2025-10-17 21:31:29 +08:00

Add Time Support (server + manual setup), only used for ESP32 FS currently as ESP8266 SPIFFS does not support Time, need to wait for LittleFS may be ? Add DHT support Add Pin reset support Add Base for Display Add libraries for new supported features Add /config handle as shortcut for [ESP420]plain to be used in embedded page Code refactoring for defines, use less Define as switches but more define as values for switches Clean warnings Lot of small bug fixes Add docs for [ESPXXX] commands
153 lines
4.6 KiB
C++
153 lines
4.6 KiB
C++
/**
|
|
* The MIT License (MIT)
|
|
*
|
|
* Copyright (c) 2016 by Daniel Eichhorn
|
|
* Copyright (c) 2016 by Fabrice Weinberg
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*
|
|
* Credits for parts of this code go to Mike Rankin. Thank you so much for sharing!
|
|
*/
|
|
|
|
#ifndef SH1106Wire_h
|
|
#define SH1106Wire_h
|
|
|
|
#include "OLEDDisplay.h"
|
|
#include <Wire.h>
|
|
|
|
#define SH1106_SET_PUMP_VOLTAGE 0X30
|
|
#define SH1106_SET_PUMP_MODE 0XAD
|
|
#define SH1106_PUMP_ON 0X8B
|
|
#define SH1106_PUMP_OFF 0X8A
|
|
//--------------------------------------
|
|
|
|
class SH1106Wire : public OLEDDisplay {
|
|
private:
|
|
uint8_t _address;
|
|
uint8_t _sda;
|
|
uint8_t _scl;
|
|
|
|
public:
|
|
SH1106Wire(uint8_t _address, uint8_t _sda, uint8_t _scl) {
|
|
this->_address = _address;
|
|
this->_sda = _sda;
|
|
this->_scl = _scl;
|
|
}
|
|
|
|
bool connect() {
|
|
Wire.begin(this->_sda, this->_scl);
|
|
// Let's use ~700khz if ESP8266 is in 160Mhz mode
|
|
// this will be limited to ~400khz if the ESP8266 in 80Mhz mode.
|
|
Wire.setClock(700000);
|
|
return true;
|
|
}
|
|
|
|
void display(void) {
|
|
#ifdef OLEDDISPLAY_DOUBLE_BUFFER
|
|
uint8_t minBoundY = ~0;
|
|
uint8_t maxBoundY = 0;
|
|
|
|
uint8_t minBoundX = ~0;
|
|
uint8_t maxBoundX = 0;
|
|
|
|
uint8_t x, y;
|
|
|
|
// Calculate the Y bounding box of changes
|
|
// and copy buffer[pos] to buffer_back[pos];
|
|
for (y = 0; y < (DISPLAY_HEIGHT / 8); y++) {
|
|
for (x = 0; x < DISPLAY_WIDTH; x++) {
|
|
uint16_t pos = x + y * DISPLAY_WIDTH;
|
|
if (buffer[pos] != buffer_back[pos]) {
|
|
minBoundY = _min(minBoundY, y);
|
|
maxBoundY = _max(maxBoundY, y);
|
|
minBoundX = _min(minBoundX, x);
|
|
maxBoundX = _max(maxBoundX, x);
|
|
}
|
|
buffer_back[pos] = buffer[pos];
|
|
}
|
|
optimistic_yield(10000);
|
|
}
|
|
|
|
// If the minBoundY wasn't updated
|
|
// we can savely assume that buffer_back[pos] == buffer[pos]
|
|
// holdes true for all values of pos
|
|
if (minBoundY == ~0) return;
|
|
|
|
// Calculate the colum offset
|
|
uint8_t minBoundXp2H = (minBoundX + 2) & 0x0F;
|
|
uint8_t minBoundXp2L = 0x10 | ((minBoundX + 2) >> 4 );
|
|
|
|
byte k = 0;
|
|
for (y = minBoundY; y <= maxBoundY; y++) {
|
|
sendCommand(0xB0 + y);
|
|
sendCommand(minBoundXp2H);
|
|
sendCommand(minBoundXp2L);
|
|
for (x = minBoundX; x <= maxBoundX; x++) {
|
|
if (k == 0) {
|
|
Wire.beginTransmission(_address);
|
|
Wire.write(0x40);
|
|
}
|
|
Wire.write(buffer[x + y * DISPLAY_WIDTH]);
|
|
k++;
|
|
if (k == 16) {
|
|
Wire.endTransmission();
|
|
k = 0;
|
|
}
|
|
}
|
|
if (k != 0) {
|
|
Wire.endTransmission();
|
|
k = 0;
|
|
}
|
|
optimistic_yield(10000);
|
|
}
|
|
|
|
if (k != 0) {
|
|
Wire.endTransmission();
|
|
}
|
|
#else
|
|
uint8_t * p = &buffer[0];
|
|
for (uint8_t y=0; y<8; y++) {
|
|
sendCommand(0xB0+y);
|
|
sendCommand(0x02);
|
|
sendCommand(0x10);
|
|
for( uint8_t x=0; x<8; x++) {
|
|
Wire.beginTransmission(_address);
|
|
Wire.write(0x40);
|
|
for (uint8_t k = 0; k < 16; k++) {
|
|
Wire.write(*p++);
|
|
}
|
|
Wire.endTransmission();
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
|
|
private:
|
|
inline void sendCommand(uint8_t command) __attribute__((always_inline)){
|
|
Wire.beginTransmission(_address);
|
|
Wire.write(0x80);
|
|
Wire.write(command);
|
|
Wire.endTransmission();
|
|
}
|
|
|
|
|
|
};
|
|
|
|
#endif
|