Tutorial Display

From Sketching with Hardware at LMU Wiki
Jump to navigation Jump to search

Control the OLED Display on the ESP32[edit]

In this part of the tutorial, we explain how to control the display that is included on the ESP32 web kit module. The display is connected over I2C and we use the microPython module ssd1306.py as library.

Success criteria[edit]

  • you can write a string to the display
  • you can converts numbers to strings and write them to the display
  • you can clear the display or fill it
  • you can position text at different positions on the display

Required Module and Files[edit]

Related Components[edit]

The components are related to the LMUBox. For more components, see the Hardware List. Many of the pages on actuators and sensor include additional examples.

Microcontroller[edit]

Actuators[edit]

Instructional Videos[edit]

Writing to the OLED Display over I2C[edit]

In this video on youtube (22:00) we show how to write text to the OLED Display on the ESP32 module. We then show how to connect a poti to an analog input and display the value in a loop on the display: https://youtu.be/UbxwePvgX-U

Another Tutorial (in German) on writing to the OLED Display with some background[edit]

There is a tutorial with several parts at "the Die Hobbyelektroniker - Community" on Micropython with ESP32 https://community.hobbyelektroniker.ch/wbb/index.php?board/51-lektion-5-das-display/

Using the uPyCraft IDE to upload files[edit]

In this video on youtube (6:48), we show how to upload an run Python files with the uPyCraft IDE: https://youtu.be/MXfj_gWf0z4

Reading analog inputs[edit]

In this video on youtube (46:23 ) we show how to read an analog input and how to configure the ADC (there is also information on how to connect a resistor and about voltage dividers): https://youtu.be/gjj5KyK2qGI

Code Examples[edit]

Code Example: displaytest.py[edit]

from machine import I2C, Pin 
import ssd1306

# ESP32 reset pin for display must be 1 - this is pin16 
# should be done in ssd1306.py - if not uncommend the next 2 lines
#pin16 = Pin(16, Pin.OUT)
#pin16.value(1)


# Pins according the schematic https://heltec.org/project/wifi-kit-32/
i2c = I2C(-1, scl=Pin(15), sda=Pin(4))

#display size
oled_width = 128
oled_height = 64
oled = ssd1306.SSD1306_I2C(oled_width, oled_height, i2c)

#test text
oled.text('Hello, World', 0, 0)
oled.text('some more text!?', 0, 10)
oled.text('...even more :-)', 0, 20)

#show is required - otherwise you will not see it
oled.show()

Code Example: adc2disp.py[edit]

# test program to read in a analog value on Pin 32 on the ESP32 board
# and display it on the 0.96" OLED Display (Heltec ESP32 Web Kit)

from machine import ADC
from time import sleep
from machine import I2C, Pin 
import ssd1306

# ESP32 reset pin for display must be 1 - this is pin16 
# should be done in ssd1306.py - if not uncommend the next 2 lines
#pin16 = Pin(16, Pin.OUT)
#pin16.value(1)

# this is for ESP32
# Pins according the schematic https://heltec.org/project/wifi-kit-32/
i2c = I2C(-1, scl=Pin(15), sda=Pin(4))

# for ESP8266 it should be:
# i2c = I2C(-1, scl=Pin(5), sda=Pin(4))
 

#display size
oled_width = 128
oled_height = 64
oled = ssd1306.SSD1306_I2C(oled_width, oled_height, i2c)

# for ESP32 setup the ADC on Pin GPIO32
adc = ADC(Pin(32)) 
adc.atten(ADC.ATTN_11DB)    # set 11dB input attenuation (voltage range roughly 0.0v - 3.6v)

# for ESP8266 setup the ADC(0)
#adc = ADC(0) 

while True:
  # read in analog value in v
  v = adc.read()
  # print to serial line
  print(v)
  # empty display
  oled.fill(0)
  oled.show()
  # write v converted to a string onto the display at (0,0)
  oled.text(str(v), 0, 0)
  oled.show()
  sleep(1)