Sommario:

HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96" tramite la GUI di Arduino: 4 passaggi
HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96" tramite la GUI di Arduino: 4 passaggi

Video: HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96" tramite la GUI di Arduino: 4 passaggi

Video: HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96
Video: OLED with Arduino | OLED with NodeMCU | OLED Display Tutorial with Arduino and NodeMCU 2024, Dicembre
Anonim
HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96
HowTo - Modulo Esp-12F Mini WiFi ESP8266 18650 Nodemcu Batterie DEMO OLED da 0,96

ciao, 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 e zum hochladen der Firmware.

Fase 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

"Zusätzliche Boardverwalter-URLs:"

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

Jetzt können wir den Passenden Boardtreiber installieren

(Board Werkzeuge: Boardverwaltung / Bild 3)

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

Fase 2: Scansione Schnittstelle I2C

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

Um zu sehen an welche PINs das 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 - Scansione PIN digitale)

Das Ergebnis Merken.

In autunno: SDA = D1: SCL = D2 bei Adresse 0x3c

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

Questo è il codice per il display OLED DEMO

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

Anche la Konfiguration für die I2C-Schnittstelle.

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

/** * The MIT License (MIT) * * Copyright (c) 2016 by Daniel Eichhorn * * Con la presente viene concessa l'autorizzazione, a titolo gratuito, a chiunque ottenga una copia * di questo software e dei file di documentazione associati (il "Software"), per trattare * nel Software senza restrizioni, inclusi senza limitazione i diritti * di utilizzare, copiare, modificare, unire, pubblicare, distribuire, concedere in licenza e/o vendere * copie del Software e per consentire alle persone a cui il Software è * fornito a tale scopo, soggetto alle seguenti condizioni: * * L'avviso di copyright di cui sopra e il presente avviso di autorizzazione devono essere inclusi in * tutte le copie o parti sostanziali del Software. * * IL SOFTWARE VIENE FORNITO "COS COM'È", SENZA ALCUN TIPO DI GARANZIA, ESPRESSA O * IMPLICITA, COMPRESE MA NON LIMITATE ALLE GARANZIE DI COMMERCIABILITÀ, * IDONEITÀ PER UNO SCOPO PARTICOLARE E NON VIOLAZIONE. IN NESSUN CASO GLI * AUTORI O TITOLARI DEL COPYRIGHT SARANNO RESPONSABILI PER QUALSIASI RECLAMO, DANNI O ALTRO * RESPONSABILITÀ, SIA IN UN'AZIONE CONTRATTUALE, ILLECITO O ALTRO, DERIVANTE DA, * DA O IN CONNESSIONE CON IL SOFTWARE O L'UTILIZZO O ALTRO RAPPORTI NEL * SOFTWARE. * *

/ Includi la libreria di visualizzazione corretta

// Per una connessione tramite I2C utilizzando Wire include #include // per I2C Wire #include "SSD1306.h" // alias per `#include "SSD1306Wire.h"`

// Includi immagini personalizzate

#include "immagini.h"

// Inizializza il display OLED usando brzo_i2c

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

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

An der folgenden Stelle werden dann die PINs für die I2C Schnittstelle konfiguriert

// Inizializza il display OLED usando la libreria Wire

Display SSD1306 (0x3c, D1, D2);

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

#define DEMO_DURATION 3000

typedef void (*Demo)(void);

int demoMode = 0;

contatore int = 1;

void setup() {

Serial.begin(9600); Serial.println("OLED_DEMO"); Serial.println("Avvia la DEMO");

// L'inizializzazione dell'interfaccia utente avvierà anche il display.

display.init();

display.flipScreenVerticalmente();

display.setFont(ArialMT_Plain_10);

}

void drawFontFaceDemo() {

// Carattere Demo1 Serial.println("Carattere DEMO 1"); // crea più caratteri su 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, "I robot sono \n il futuro, e il futuro è adesso. Ma non dimenticare la natura"); }

void drawTextAlignmentDemo() {

Serial.println("drawTextAlignmentDemo"); // Dimostrazione di allineamento del testo display.setFont(ArialMT_Plain_10); // Schriftart und -größe einstellen

// Le coordinate definiscono il punto iniziale sinistro del testo

display.setTextAlignment(TEXT_ALIGN_LEFT); // Text_Ausrichtung einstellen display.drawString(0, 10, "Allineato a sinistra (0, 10)");

// Le coordinate definiscono il centro del testo

display.setTextAlignment(TEXT_ALIGN_CENTER); display.drawString(64, 22, "Allineato al centro (64, 22)");

// Le coordinate definiscono l'estremità destra del testo

display.setTextAlignment(TEXT_ALIGN_RIGHT); display.drawString(128, 33, "Allineato a destra (128, 33)"); }

void drawRectDemo() {

Serial.println("drawRectDemo"); // Disegna un pixel in una data posizione for (int i = 0; i < 10; i++) { display.setPixel(i, i); display.setPixel(10 - io, io); } display.drawRect(12, 12, 20, 20);

// Riempi il rettangolo

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

// Disegna una linea orizzontalmente

display.drawHorizontalLine(0, 40, 20);

// Disegna una linea orizzontalmente

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

void drawCircleDemo() {

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

void drawProgressBarDemo() {

Serial.println("drawProgressBarDemo"); int avanzamento = (contatore / 5) % 100; // disegna la barra di avanzamento display.drawProgressBar(0, 32, 120, 10, progress);

// disegna la percentuale come String

display.setTextAlignment(TEXT_ALIGN_CENTER); display.drawString(64, 15, String(progresso) + "%"); }

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"); // vedi https://blog.squix.org/2015/05/esp8266-nodemcu-how… // su come creare file xbm display.drawXbm(34, 0, Logo_width, Logo_height, Logo_bits); }

Demo demo = {drawFontFaceDemo, drawTextFlowDemo, drawTextAlignmentDemo, drawRectDemo, drawCircleDemo, drawProgressBarDemo, drawImageDemo};

int demoLength = (sizeof(demos) / sizeof(Demo)); lungo tempoSinceLastModeSwitch = 0;

ciclo vuoto() {

// cancella il display display.clear(); // disegna il metodo demo corrente demos[demoMode]();

display.setTextAlignment(TEXT_ALIGN_RIGHT);

display.drawString(10, 128, String(millis())); // scrive il buffer sul display display.display();

if (millis() - timeSinceLastModeSwitch > DEMO_DURATION) {

demoMode = (demoMode + 1) % demoLength; timeSinceLastModeSwitch = millis(); } contatore++; ritardo(10); }

Passaggio 4: strumenti, collegamenti e Herkunft/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 Grusse

McUtty

Consigliato: