LCD 2004 i2c Raspberry PI
1- Necesario
- una pantalla de 4 × 20 I²C ( de este tipo )
- un convertidor lógico 3.3v-5v a 70 centavos ( ejemplo )
- un convertidor lógico 3.3v-5v a 70 centavos ( ejemplo )
2- Conexiones
Iremos cada vez que el convertidor, será lo más sencillo de explicar.
Lado 5V:
conecte AVCC a + 5v desde Pi
conecte AVCC a + 5v desde pantalla
conecte AGND a GND desde PI
conecte AGND a GND desde pantalla
conecte ASCL a SCL desde pantalla
conecte ASDA a SDA desde pantalla
conecte AVCC a + 5v desde Pi
conecte AVCC a + 5v desde pantalla
conecte AGND a GND desde PI
conecte AGND a GND desde pantalla
conecte ASCL a SCL desde pantalla
conecte ASDA a SDA desde pantalla
Lado de
3,3 V : conecte BVCC a Pi + 3,3 V
conecte BGND a Pi GND
conecte BSCL a PI's SCL
conecte BSDA a Pi SDA
3,3 V : conecte BVCC a Pi + 3,3 V
conecte BGND a Pi GND
conecte BSCL a PI's SCL
conecte BSDA a Pi SDA
Gracias a este conjunto, es posible agregar tantos componentes / módulos I²C como desee (casi), ya sea en 3.3V o 5V: los módulos de 5V están conectados al lado A del convertidor, los módulos 3.3V (incluyendo la Pi) se conectan en el lado B.
2- Activación y configuración del módulo de software I²C.
Aquí, me repetiré especialmente ... Ya hemos preparado todo en el tutorial sobre el reloj RTC.
Añadimos los módulos al inicio:
sudo nano /etc/modules
Añade estas 2 líneas:
i2c-bcm2708 i2c-dev
Reiniciamos:
sudo reboot
Instalamos las herramientas necesarias:
sudo apt-get install python-smbus i2c-tools
Eliminamos los módulos I²C de la lista negra (si es el caso):
sudo nano /etc/modprobe.d/raspi-blacklist.conf
la línea
blacklist i2c-bcm2708
se convierte en
#blacklist i2c-bcm2708
Reiniciamos, y el Raspi debería estar listo para usar dispositivos I²C.
3- Prueba de interfaz I²C
Usaremos el comando i2cdetect, que permite ver la lista de dispositivos I²C conectados a Pi. El comando es diferente si usa una Raspberry Pi Rev 1 o Rev 2 (la dirección del bus I²C es diferente), así que elija la correcta :
sudo i2cdetect -y 0 (pour la Rev 1)
sudo i2cdetect -y 1 (pour la Rev 2)
En esta captura, podemos ver que tengo 3 componentes I²C:
- la pantalla en la dirección # 27
- el chip AT24C32 del reloj RTC en la dirección # 50
- el chip DS1307 del reloj RTC en dirección # 68 (está marcada como "UU" porque está en uso)
Es posible que su pantalla tenga una dirección diferente, ya la he visto en 24 y 28. Anote esta dirección si es diferente A partir del 27, lo necesitaremos más adelante para configurar el driver.
- la pantalla en la dirección # 27
- el chip AT24C32 del reloj RTC en la dirección # 50
- el chip DS1307 del reloj RTC en dirección # 68 (está marcada como "UU" porque está en uso)
Es posible que su pantalla tenga una dirección diferente, ya la he visto en 24 y 28. Anote esta dirección si es diferente A partir del 27, lo necesitaremos más adelante para configurar el driver.
4- Instalación del controlador
Usaremos un pequeño controlador de Python para comunicarnos con la pantalla. Comprenderás, si queremos comunicarnos con la pantalla, estará en python.
En una carpeta, crearemos 2 archivos:
En una carpeta, crearemos 2 archivos:
sudo nano i2c_lib.py
import smbus from time import * class i2c_device: def __init__(self, addr, port=1): self.addr = addr self.bus = smbus.SMBus(port) # Write a single command def write_cmd(self, cmd): self.bus.write_byte(self.addr, cmd) sleep(0.0001) # Write a command and argument def write_cmd_arg(self, cmd, data): self.bus.write_byte_data(self.addr, cmd, data) sleep(0.0001) # Write a block of data def write_block_data(self, cmd, data): self.bus.write_block_data(self.addr, cmd, data) sleep(0.0001) # Read a single byte def read(self): return self.bus.read_byte(self.addr) # Read def read_data(self, cmd): return self.bus.read_byte_data(self.addr, cmd) # Read a block of data def read_block_data(self, cmd): return self.bus.read_block_data(self.addr, cmd)
sudo nano lcddriver.py
import i2c_lib from time import * # LCD Address ADDRESS = 0x27 # commands LCD_CLEARDISPLAY = 0x01 LCD_RETURNHOME = 0x02 LCD_ENTRYMODESET = 0x04 LCD_DISPLAYCONTROL = 0x08 LCD_CURSORSHIFT = 0x10 LCD_FUNCTIONSET = 0x20 LCD_SETCGRAMADDR = 0x40 LCD_SETDDRAMADDR = 0x80 # flags for display entry mode LCD_ENTRYRIGHT = 0x00 LCD_ENTRYLEFT = 0x02 LCD_ENTRYSHIFTINCREMENT = 0x01 LCD_ENTRYSHIFTDECREMENT = 0x00 # flags for display on/off control LCD_DISPLAYON = 0x04 LCD_DISPLAYOFF = 0x00 LCD_CURSORON = 0x02 LCD_CURSOROFF = 0x00 LCD_BLINKON = 0x01 LCD_BLINKOFF = 0x00 # flags for display/cursor shift LCD_DISPLAYMOVE = 0x08 LCD_CURSORMOVE = 0x00 LCD_MOVERIGHT = 0x04 LCD_MOVELEFT = 0x00 # flags for function set LCD_8BITMODE = 0x10 LCD_4BITMODE = 0x00 LCD_2LINE = 0x08 LCD_1LINE = 0x00 LCD_5x10DOTS = 0x04 LCD_5x8DOTS = 0x00 # flags for backlight control LCD_BACKLIGHT = 0x08 LCD_NOBACKLIGHT = 0x00 En = 0b00000100 # Enable bit Rw = 0b00000010 # Read/Write bit Rs = 0b00000001 # Register select bit class lcd: #initializes objects and lcd def __init__(self): self.lcd_device = i2c_lib.i2c_device(ADDRESS) self.lcd_write(0x03) self.lcd_write(0x03) self.lcd_write(0x03) self.lcd_write(0x02) self.lcd_write(LCD_FUNCTIONSET | LCD_2LINE | LCD_5x8DOTS | LCD_4BITMODE) self.lcd_write(LCD_DISPLAYCONTROL | LCD_DISPLAYON) self.lcd_write(LCD_CLEARDISPLAY) self.lcd_write(LCD_ENTRYMODESET | LCD_ENTRYLEFT) sleep(0.2) # clocks EN to latch command def lcd_strobe(self, data): self.lcd_device.write_cmd(data | En | LCD_BACKLIGHT) sleep(.0005) self.lcd_device.write_cmd(((data & ~En) | LCD_BACKLIGHT)) sleep(.0001) def lcd_write_four_bits(self, data): self.lcd_device.write_cmd(data | LCD_BACKLIGHT) self.lcd_strobe(data) # write a command to lcd def lcd_write(self, cmd, mode=0): self.lcd_write_four_bits(mode | (cmd & 0xF0)) self.lcd_write_four_bits(mode | ((cmd << 4) & 0xF0)) # put string function def lcd_display_string(self, string, line): if line == 1: self.lcd_write(0x80) if line == 2: self.lcd_write(0xC0) if line == 3: self.lcd_write(0x94) if line == 4: self.lcd_write(0xD4) for char in string: self.lcd_write(ord(char), Rs) # clear lcd and set to home def lcd_clear(self): self.lcd_write(LCD_CLEARDISPLAY) self.lcd_write(LCD_RETURNHOME)
En este último archivo, puede ajustar la dirección de su pantalla si no es 27:
# LCD Address ADDRESS = 0x27
5- Usando la pantalla
Esto es lo más fácil ...
Cuando desee utilizar la pantalla en un script, solo tiene que incluir los 2 archivos del controlador en la carpeta de su script. Aquí está el mínimo a utilizar para operar la pantalla:
Cuando desee utilizar la pantalla en un script, solo tiene que incluir los 2 archivos del controlador en la carpeta de su script. Aquí está el mínimo a utilizar para operar la pantalla:
# on importe le pilote import lcddriver from time import * # on initialise le lcd lcd = lcddriver.lcd() # on reinitialise le lcd lcd.lcd_clear() # on affiche des caracteres sur chaque ligne lcd.lcd_display_string(" Hello world !", 1) lcd.lcd_display_string(" Je suis", 2) lcd.lcd_display_string(" un", 3) lcd.lcd_display_string(" Raspberry Pi !", 4)
Comentarios
Publicar un comentario