Raspberry Pi 16x2 ЖК-экран глюки через несколько секунд - PullRequest
0 голосов
/ 21 ноября 2018

У меня ЖК-экран 16x2, который отображает время и дату в реальном времени.Проблема в том, что он запускается автоматически при загрузке, но глючит при этом.

Что происходит при запуске при загрузке

В rc.local я добавилстрока, которая говорит (сон 10; python /home/pi/Document/LCD.py), который запустит его при загрузке.Я думаю, что это может начаться слишком рано в процессе.Что-то, что также заставляет меня поверить, это то, что когда я подключаю кабель дисплея, он имеет лучший показатель успеха.Может быть, этого достаточно, чтобы инициализировать контакты GPIO?Я пытался добавить его в качестве системной службы, но он не работает.

Мой код:

# The wiring for the LCD is as follows:
# 1 : GND
# 2 : 5V
# 3 : Contrast (0-5V)*
# 4 : RS (Register Select)
# 5 : R/W (Read Write)       - GROUND THIS PIN
# 6 : Enable or Strobe
# 7 : Data Bit 0             - NOT USED
# 8 : Data Bit 1             - NOT USED
# 9 : Data Bit 2             - NOT USED
# 10: Data Bit 3             - NOT USED
# 11: Data Bit 4
# 12: Data Bit 5
# 13: Data Bit 6
# 14: Data Bit 7
# 15: LCD Backlight +5V**
# 16: LCD Backlight GND

#import
import RPi.GPIO as GPIO
import time

# Define GPIO to LCD mapping
LCD_RS = 7
LCD_E  = 8
LCD_D4 = 25
LCD_D5 = 24
LCD_D6 = 23
LCD_D7 = 18


# Define some device constants
LCD_WIDTH = 16    # Maximum characters per line
LCD_CHR = True
LCD_CMD = False

LCD_LINE_1 = 0x80 # LCD RAM address for the 1st line
LCD_LINE_2 = 0xC0 # LCD RAM address for the 2nd line

# Timing constants
E_PULSE = 0.0005
E_DELAY = 0.0005

def main():
  # Main program block

  GPIO.setwarnings(False)
  GPIO.setmode(GPIO.BCM)       # Use BCM GPIO numbers
  GPIO.setup(LCD_E, GPIO.OUT)  # E
  GPIO.setup(LCD_RS, GPIO.OUT) # RS
  GPIO.setup(LCD_D4, GPIO.OUT) # DB4
  GPIO.setup(LCD_D5, GPIO.OUT) # DB5
  GPIO.setup(LCD_D6, GPIO.OUT) # DB6
  GPIO.setup(LCD_D7, GPIO.OUT) # DB7


  # Initialise display
  lcd_init()
  while True:
    e = time.strftime("%H:%M:%S")
    date = time.strftime("%Y:%m:%d") 

    # Send some test
    lcd_string(date,LCD_LINE_1) #Change 'text' to what you want.
    lcd_string(e,LCD_LINE_2)

def lcd_init():
  # Initialise display
  lcd_byte(0x33,LCD_CMD) # 110011 Initialise
  lcd_byte(0x32,LCD_CMD) # 110010 Initialise
  lcd_byte(0x06,LCD_CMD) # 000110 Cursor move direction
  lcd_byte(0x0C,LCD_CMD) # 001100 Display On,Cursor Off, Blink Off
  lcd_byte(0x28,LCD_CMD) # 101000 Data length, number of lines, font size
  lcd_byte(0x01,LCD_CMD) # 000001 Clear display
  time.sleep(E_DELAY)

def lcd_byte(bits, mode):
  # Send byte to data pins
  # bits = data
  # mode = True  for character
  #        False for command

  GPIO.output(LCD_RS, mode) # RS

  # High bits
  GPIO.output(LCD_D4, False)
  GPIO.output(LCD_D5, False)
  GPIO.output(LCD_D6, False)
  GPIO.output(LCD_D7, False)
  if bits&0x10==0x10:
    GPIO.output(LCD_D4, True)
  if bits&0x20==0x20:
    GPIO.output(LCD_D5, True)
  if bits&0x40==0x40:
    GPIO.output(LCD_D6, True)
  if bits&0x80==0x80:
    GPIO.output(LCD_D7, True)

  # Toggle 'Enable' pin
  lcd_toggle_enable()

  # Low bits
  GPIO.output(LCD_D4, False)
  GPIO.output(LCD_D5, False)
  GPIO.output(LCD_D6, False)
  GPIO.output(LCD_D7, False)
  if bits&0x01==0x01:
    GPIO.output(LCD_D4, True)
  if bits&0x02==0x02:
    GPIO.output(LCD_D5, True)
  if bits&0x04==0x04:
    GPIO.output(LCD_D6, True)
  if bits&0x08==0x08:
    GPIO.output(LCD_D7, True)

  # Toggle 'Enable' pin
  lcd_toggle_enable()

def lcd_toggle_enable():
  # Toggle enable
  time.sleep(E_DELAY)
  GPIO.output(LCD_E, True)
  time.sleep(E_PULSE)
  GPIO.output(LCD_E, False)
  time.sleep(E_DELAY)

def lcd_string(message,line):
  # Send string to display




  message = message.ljust(LCD_WIDTH," ")

  lcd_byte(line, LCD_CMD)

  for i in range(LCD_WIDTH):
    lcd_byte(ord(message[i]),LCD_CHR)

if __name__ == '__main__':

  try:
    main()
  except KeyboardInterrupt:
    pass
  finally:
    lcd_byte(0x01, LCD_CMD)
    lcd_string("Goodbye!",LCD_LINE_1)
    GPIO.cleanup()

Заранее спасибо.

1 Ответ

0 голосов
/ 21 ноября 2018

Я вижу три проблемы.

  1. Большинство дисплеев HD44780 (как этот дисплей) требуют ввода / вывода 5 В.Raspberry Pi использует 3.3VI / O, что может быть недостаточно для некоторых дисплеев.

  2. Соответственно: если дисплей ever переводится в режим чтения, он можетпопытаться подать 5V на шину данных.Это приведет к повреждению выводов ввода / вывода Pi.

  3. GPIO.cleanup() сбрасывает любые выходные выводы Pi на входы.Это оставит входные данные на дисплее плавающими, что приведет к неожиданному поведению.

Потенциальные решения:

  1. Используйте дисплей, который поддерживает 3.3VI /Изначально или со встроенным транслятором уровня или преобразователем протокола. (I2C "рюкзаки" для этих дисплеев являются распространенным решением; они также сэкономят вам пару контактов.)

  2. Добавьте преобразователь уровня между Pi и дисплеем и потяните контакт E на низкий уровень с помощью резистора, чтобы он не мог подняться высоко, пока Pi не управляется.

...