HowTo - Esp-12F Mini WiFi Modul ESP8266 18650 Nodemcu Batterie 0.96”OLED DEMO Via Arduino GUI: 4 Steps
HowTo - Esp-12F Mini WiFi Modul ESP8266 18650 Nodemcu Batterie 0.96”OLED DEMO Via Arduino GUI: 4 Steps
Anonim
HowTo - Esp-12F Mini WiFi Modul ESP8266 18650 Nodemcu Batterie 0.96”OLED DEMO Via Arduino GUI
HowTo - Esp-12F Mini WiFi Modul ESP8266 18650 Nodemcu Batterie 0.96”OLED DEMO Via Arduino GUI

Hola, hier möchte ich Euch zeigen wie Ihr das mit auf der Hauptplatine verbaute OLED Display benutzen / ansteuern könnt. Um es möglichst einfach zu halten, benutze ich die ARDUINO GUI zum schreiben des CODEs und zum hochladen der Firmware.

Pas 1: Einstellen / Einrichten Der ARDUINO GUI

Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI
Einstellen / Einrichten Der ARDUINO GUI

Als erstes muss das ESP8266 Board in der ARDUINO GUI verfügbar gemacht werden.

Dazu gehen wir in die Einstellungen (Datei Einstellungen / Bild 1) der GUI und tragen unter

"URL del Boardverwalter de Zusätzliche:"

ein (Bild 2). Damit bekommen wir den benötigten Zugang zu dem passenden Boardtreiber.

Jetzt können wir den Passenden Boardtreiber installieren

(Junta de Werkzeuge: Boardverwaltung / Bild 3)

  • Dort im Suchfeld "esp8266" eintragen
  • Dann "esp8266 by ESP8266 Community" auswählen und die aktuellste Versió instal·lada (Bild 4)
  • Die ARDUINO GUI neu starten
  • Danach das passende Board auswählen (z. B.: WeMos D1 R2 & mini)

Pas 2: I2C Schnittstelle Scannen

I2C Schnittstelle Scannen
I2C Schnittstelle Scannen
I2C Schnittstelle Scannen
I2C Schnittstelle Scannen

Podeu veure els PINs OLED-Display angeschlossen wurde, scannen wir zuerst die I2C-Schnittstelle. So können wir auch sehen ob noch weitere I2C-Parts angeschlossen sind.

Den Sketch (Bild 1) auf den ESP Hochladen, den "Seriellen-Monitor" öffnen und auf die Ausgabe warten. Dort könnt Ihr dann sehen, welches Device wo gefunden wurde. (Bild 2 - DigitalPIN Scan)

Das Ergebnis merken.

A la tardor: SDA = D1: SCL = D2 a l'adreça 0x3c

Pas 3: Demo-Sketch Anpassen Und Auf Den ESP Hochladen

Das ist der Code for OLED-Display DEMO

Im 5. Abschnitt findet Ihr die Stelle an der der Code ggf. modifiziert werden muss.

També moriu Konfiguration für die I2C-Schnittstelle.

Aus diesem Code könnt Ihr euch auch viele Infos über die Benutzung eines OLEDs capableiten.

/ ** * La llicència MIT (MIT) * * Copyright (c) 2016 de Daniel Eichhorn * * Es concedeix permís gratuïtament a qualsevol persona que obtingui una còpia * d'aquest programari i dels fitxers de documentació associats (el "Programari")), per tractar * amb el programari sense restriccions, incloent-hi sense limitació els drets * d’utilitzar, copiar, modificar, fusionar, publicar, distribuir, subllicenciar i / o vendre * còpies del programari i permetre a les persones a qui el programari * es proporciona * per fer-ho, subjecte a les següents condicions: * * L'avís de copyright anterior i aquest avís de permís s'inclouran a totes les * còpies o parts importants del programari. * * EL PROGRAMARI ES PROPORCIONA "TAL COM ÉS", SENSE GARANTIA DE CAP MENA, EXPRESA O * IMPLÍCITA, INCLOSA PER NOT NO LIMITADA A LES GARANTIES DE COMERCIALITAT, * IDONEITAT PER A UN FINALITAT PARTICULAR I NO INFRACCIÓ. En cap cas, els * autors o titulars de drets d’autor seran responsables de cap reclamació, dany o qualsevol altre tipus de responsabilitat *, SIGUI EN UNA ACCIÓ DE CONTRACTE, TORT O ALTRES, DERIVATS DE, * FER O EN CONNEXIÓ AMB EL PROGRAMARI O L’ÚS O UN ALTRE OFERTES AL * PROGRAMARI. * *

/ Incloeu la biblioteca de visualització correcta

// Per a una connexió mitjançant I2C mitjançant Wire, inclosa #include // per a I2C Wire #include "SSD1306.h" // àlies de `#include" SSD1306Wire.h "`

// Inclou imatges personalitzades

#include "images.h"

// Inicialitzeu la pantalla OLED mitjançant brzo_i2c

// D3 -> SDA // D5 -> Visualització SCL // SSD1306 (0x3c, D1, D2); o pantalla SSD1306 (0x3c, 5, 4); o pantalla SSD1306 (0x3c, GPIO5, GPIO4);

**************************************************************************************************

An der folgenden Stelle werden dann die PINs for I2C Schnittstelle konfiguriert

// Inicialitzeu la pantalla OLED mitjançant la biblioteca de filferro

Pantalla SSD1306 (0x3c, D1, D2);

***************************************************************************************************

#define DEMO_DURATION 3000

typedef void (* Demo) (void);

int demoMode = 0;

int comptador = 1;

configuració nul·la () {

Serial.begin (9600); Serial.println ("OLED_DEMO"); Serial.println ("Inicieu el DEMO");

// Si inicieu la IU, també s'iniciarà la visualització.

display.init ();

display.flipScreenVertically ();

display.setFont (ArialMT_Plain_10);

}

void drawFontFaceDemo () {

// Font Demo1 Serial.println ("Font DEMO 1"); // creeu més tipus de lletra a https://oleddisplay.squix.ch/ display.setTextAlignment (TEXT_ALIGN_LEFT); display.setFont (ArialMT_Plain_10); display.drawString (0, 0, "ProMoScout"); display.setFont (ArialMT_Plain_16); display.drawString (0, 10, "ProMoScout"); display.setFont (ArialMT_Plain_24); display.drawString (0, 26, "ProMoScout"); }

void drawTextFlowDemo () {

Serial.println ("drawTextFlowDemo"); display.setFont (ArialMT_Plain_10); display.setTextAlignment (TEXT_ALIGN_LEFT); display.drawStringMaxWidth (0, 0, 128, "Els robots són / n el futur i el futur és ara. Però no oblideu la naturalesa"); }

void drawTextAlignmentDemo () {

Serial.println ("drawTextAlignmentDemo"); // demostració d'alineació de text display.setFont (ArialMT_Plain_10); // Schriftart und -größe einstellen

// Les coordenades defineixen el punt de partida esquerre del text

display.setTextAlignment (TEXT_ALIGN_LEFT); // Text_Ausrichtung einstellen display.drawString (0, 10, "alineat a l'esquerra (0, 10)");

// Les coordenades defineixen el centre del text

display.setTextAlignment (TEXT_ALIGN_CENTER); display.drawString (64, 22, "Alineació central (64, 22)");

// Les coordenades defineixen l'extrem dret del text

display.setTextAlignment (TEXT_ALIGN_RIGHT); display.drawString (128, 33, "alineat a la dreta (128, 33)"); }

void drawRectDemo () {

Serial.println ("drawRectDemo"); // Dibuixeu un píxel en la posició donada per a (int i = 0; i <10; i ++) {display.setPixel (i, i); display.setPixel (10 - i, i); } display.drawRect (12, 12, 20, 20);

// Ompliu el rectangle

display.fillRect (14, 14, 17, 17);

// Dibuixeu una línia horitzontalment

display.drawHorizontalLine (0, 40, 20);

// Dibuixeu una línia horitzontalment

display.drawVerticalLine (40, 0, 20); }

void drawCircleDemo () {

Serial.println ("drawCircleDemo"); per a (int i = 1; i <8; i ++) {display.setColor (BLANC); display.drawCircle (32, 32, i * 3); if (i% 2 == 0) {display.setColor (NEGRE); } display.fillCircle (96, 32, 32 - i * 3); }}

void drawProgressBarDemo () {

Serial.println ("drawProgressBarDemo"); int progress = (comptador / 5)% 100; // dibuixeu la barra de progrés display.drawProgressBar (0, 32, 120, 10, progress);

// dibuixa el percentatge com a Cadena

display.setTextAlignment (TEXT_ALIGN_CENTER); display.drawString (64, 15, Cadena (progrés) + "%"); }

Der folgende Link im Kommentar kann helfen ein Bild oder Logo so umzuwandeln, das es auf dem Display angezeigt werden kann …

void drawImageDemo () {

Serial.println ("drawImageDemo"); // consulteu https://blog.squix.org/2015/05/esp8266-nodemcu-how… // sobre com crear fitxers xbm display.drawXbm (34, 0, Logo_width, Logo_height, Logo_bits); }

Demostracions de demostració = {drawFontFaceDemo, drawTextFlowDemo, drawTextAlignmentDemo, drawRectDemo, drawCircleDemo, drawProgressBarDemo, drawImageDemo};

int demoLength = (sizeof (demos) / sizeof (Demo)); long timeSinceLastModeSwitch = 0;

bucle buit () {

// esborreu la pantalla display.clear (); // dibuixar el mètode de demostració actual demos [demoMode] ();

display.setTextAlignment (TEXT_ALIGN_RIGHT);

display.drawString (10, 128, String (millis ())); // escriviu el buffer a la pantalla display.display ();

if (millis () - timeSinceLastModeSwitch> DEMO_DURATION) {

demoMode = (demoMode + 1)% demoLength; timeSinceLastModeSwitch = millis (); } comptador ++; retard (10); }

Pas 4: Eines, enllaços i coneixements / Literaturhinweis

Ich möchte mich bei allen bedanken die an dem ein oder anderen Code mit gewirkt haben.

Die Grundlagen für diese Anleitung habe ich gefunden unter:

www.instructables.com/id/ESP8266-I2C-PORT-…

github.com/ThingPulse/esp8266-oled-ssd1306…

Viele Grüße

McUtty