Différences entre versions de « Rasp-Hack-Afficheur-LCD-Python »

De MCHobby - Wiki
Sauter à la navigation Sauter à la recherche
Ligne 1 : Ligne 1 :
 
{{Rasp-Hack-Afficheur-LCD-NAV}}
 
{{Rasp-Hack-Afficheur-LCD-NAV}}
  
== Code Python ==  
+
== Pre-requis ==
 +
Sur un Raspberry-Pi, vous aurez besoin d'installer le minimum logiciel pour pouvoir télécharger la bibliothèque Adafruit.
  
{{bloc-etroit
+
<nowiki>sudo apt-get update
  |text = Le code Python Raspberry-Pi produit par Adafruit pour l'afficheur LCDest disponible sur Github à
+
sudo apt-get install build-essential python-dev python-smbus python-pip git
[https://github.com/adafruit/Adafruit-Raspberry-Pi-Python-Code https://github.com/adafruit/Adafruit-Raspberry-Pi-Python-Code]
+
sudo pip install RPi.GPIO</nowiki>
  
Nous allons travailler avec deux fichiers:
+
== Installation de la bibliothèque ==
 +
Une fois les dépendances ci-dessus installées, vous pouvez installer le module LCD Alphanumerique en exécutant les commandes suivantes sur votre appareil:
  
* '''Adafruit_CharLCD.py''' : contient la classe python pour le contrôle LCD
+
<nowiki>cd ~
* '''Adafruit_CharLCD_IPclock_example.py''' : Code pour l'affichage de l'adresse IP et date/heure. Appelle les méthodes de  Adafruit_CharLCD.py
+
git clone https://github.com/adafruit/Adafruit_Python_CharLCD.git
 +
cd Adafruit_Python_CharLCD
 +
sudo python setup.py install</nowiki>
  
 
+
Ces commandes vont dupliquer (cloner) les [https://github.com/adafruit/Adafruit_Python_CharLCD source de la bibliothèque depuis GitHub] puis exécuter le script {{fname|setup.py}} pour installer la bibliothèque dans python.
Le premier fichier Adafruit_CharLCD.py est un mélange de deux code sources LCD différent. L'utilisateur lrvick sur Github à rassembler ces deux sources dans [https://github.com/lrvick/raspi-hd44780/blob/master/hd44780.py une excellente classe python]. Son travail est à la base de la librairie que nous proposons. Nous avons en effet adapté le code pour y inclure plus d'éléments de [https://github.com/arduino/Arduino/tree/master/libraries/LiquidCrystal la librairie LiquidCrystal d'Arduino].
 
 
 
La meilleure façon d'installer ce code sur votre Pi est d'y raccorder un cable Ethernet, et d'en prendre une copie (clone) directement en utilisant 'git', qui est installé par défaut sur beaucoup de distributions. Exécutez les commandes suivantes depuis un répertoire approprié (ex: "/home/pi"):
 
}}
 
 
 
<nowiki>apt-get install git
 
git clone git://github.com/adafruit/Adafruit-Raspberry-Pi-Python-Code.git
 
cd Adafruit-Raspberry-Pi-Python-Code
 
cd Adafruit_CharLCD</nowiki>
 
  
 
== Tester ==
 
== Tester ==

Version du 31 décembre 2016 à 10:12

Pre-requis

Sur un Raspberry-Pi, vous aurez besoin d'installer le minimum logiciel pour pouvoir télécharger la bibliothèque Adafruit.

sudo apt-get update
sudo apt-get install build-essential python-dev python-smbus python-pip git
sudo pip install RPi.GPIO

Installation de la bibliothèque

Une fois les dépendances ci-dessus installées, vous pouvez installer le module LCD Alphanumerique en exécutant les commandes suivantes sur votre appareil:

cd ~
git clone https://github.com/adafruit/Adafruit_Python_CharLCD.git
cd Adafruit_Python_CharLCD
sudo python setup.py install

Ces commandes vont dupliquer (cloner) les source de la bibliothèque depuis GitHub puis exécuter le script setup.py pour installer la bibliothèque dans python.

Tester

Vous pouvez tester le câblage réalisé lors des étapes précédentes en exécutant le code python de Adafruit_CharLCD.py . Il ne dispose que d'un peu de code... et si tout est raccordé correctement, vous verrez apparaître un message de test.

Si vous utilisez un Raspberry Pi Version 2,alors la broche #21 de la carte à été remplacée avec la broche #27. Il faudra donc modifier Adafruit_CharLCD.py et changer la ligne:

def __init__(self, pin_rs=25, pin_e=24, pins_db=[23, 17, 21, 22], GPIO = None):

par

def __init__(self, pin_rs=25, pin_e=24, pins_db=[23, 17, 27, 22], GPIO = None):


vous pouvez utiliser la commande nano Adafruit_CharLCD.py pour modifier le fichier

chmod +x Adafruit_CharLCD.py
sudo ./Adafruit_CharLCD.py

L'exemple Horloge + IP

#!/usr/bin/python
     
from Adafruit_CharLCD import Adafruit_CharLCD
from subprocess import *
from time import sleep, strftime
from datetime import datetime
     
lcd = Adafruit_CharLCD()
     
cmd = "ip addr show eth0 | grep inet | awk '{print $2}' | cut -d/ -f1"
     
lcd.begin(16,1)
     
def run_cmd(cmd):
    p = Popen(cmd, shell=True, stdout=PIPE)
    output = p.communicate()[0]
    return output
     
while 1:
    lcd.clear()
    ipaddr = run_cmd(cmd)
    lcd.message(datetime.now().strftime('%b %d %H:%M:%S\n'))
    lcd.message('IP %s' % ( ipaddr ) )
    sleep(2)

Executer le code

Démarrer l'exemple IP + horloge

$ sudo ./Adafruit_CharLCD_IPclock_example.py 

Résultat

Ce que vous devriez voir:

Rasp-Hack-Afficheur-LCD-Python-01.jpg


Source: Character LCD with Raspberry Pi or BeagleBone Black écrit par Tony Dicola pour Adafruit Industries.

Traduit avec l'autorisation d'AdaFruit Industries - Translated with the permission from Adafruit Industries - www.adafruit.com

Toute référence, mention ou extrait de cette traduction doit être explicitement accompagné du texte suivant : «  Traduction par MCHobby (www.MCHobby.be) - Vente de kit et composants » avec un lien vers la source (donc cette page) et ce quelque soit le média utilisé.

L'utilisation commercial de la traduction (texte) et/ou réalisation, même partielle, pourrait être soumis à redevance. Dans tous les cas de figures, vous devez également obtenir l'accord du(des) détenteur initial des droits. Celui de MC Hobby s'arrêtant au travail de traduction proprement dit.