Rasp-Hack-BMP085-Python-Lib
Introduction
Le code Python du BMP085 pour Raspberry Pi est disponible sur le le dépôt GitHub Adafruit-Raspberry-Pi-Python-Code
Même si une partie des pilotes et classes sont toujours en cours d'évolution -- AdaFruit investit beaucoup de temps pour accéder à la couche matériel de façon aussi simple que possible -- le code actuel est un excellent point de départ pour comprendre comment accéder aux périphériques SMBus/I2C de votre Pi, et obtenir des données depuis votre BMP085/BMP180.
Télécharger le code depuis GitHub
Utiliser le senseur BMP sensor avec Raspberry Pi ou Beaglebone Black est facile grâce à la bibliothèque Adafruit Python BMP. Pour commencer, assurez vous que votre nano-ordinateur est allumé et dispose d'un accès à internet (via une connexion filaire ou WiFi). Connectez vous ensuite sur une session terminal et déplacez vous dans le répertoire où vous téléchargerez la bibliothèque (comme /home/pi sur Raspberry Pi ou /root sur Beaglebone Black).
Pour finir, exécutez les commandes suivantes pour télécharger les dépendences et installer la bibliothèque:
sudo apt-get update sudo apt-get install git build-essential python-dev python-smbus git clone https://github.com/adafruit/Adafruit_Python_BMP.git cd Adafruit_Python_BMP sudo python setup.py install
Tester la bibliothèque
Si vous utiliser un Pi version 2 (512 Mega de RAM) alors vous aurez besoin de changer l'adresse du bus I2C (puisque ce dernier est passé de la broche #0 à #1 dans la version version 2).
Le code Adafruit_I2C.py est capable de détecter automatiquement la révision de votre Raspberry Pi.
Si pour une raison quelconque votre périphérique I2C ne répond pas, vous pouvez toujours HardCoder le numéro de broche à utiliser sur bus (c'est une méthode que nous avons déjà utilisé chez MCHobby).
Editez le fichier Adafruit_I2C.py avec la commande nano Adafruit_I2C.py et changez la ligne suivante
def __init__(self, address, busnum=-1, debug=False):
en
def __init__(self, address, busnum=1, debug=False):
Une fois que vous avez téléchargé le code dans le bon répertoire, et que vous avez votre BMP raccordé correctement ALORS vous pouvez commencer à lire quelques données en utilisant la commande suivante (le pilote inclus un simple programme d'exemple):
sudo python Adafruit_BMP085_example.py
Qui devrait produire un résultat similaire à ceci:
Crédit: AdaFruit Industries www.adafruit.com
Modifier le code
La bibliothèque BMP085 (BMP180) est organisé en deux classes séparée. Il y a une classe qui gère la communication de bas niveau sur le SMBus/I2C (Adafruit_I2C), et une autre classe pour gérer les fonctionnalités spécifiques au BMP085/BMP180.
La bibliothèque inclus l'exemple ci-dessous, mais vous pouvez également adapter un peu le code pour obtenir des informations de débug (utile au cas où vous auriez des problèmes), ou modifier l'adresse ou utiliser le BMP085/180 dans l'un des 4 différents modes (ULTRALOWPOWER, STANDARD, HIRES, and ULTRAHIRES). Voyez les différents commentaires dans le code ci-dessous:
#!/usr/bin/python from Adafruit_BMP085 import BMP085 # =========================================================================== # Example Code # =========================================================================== # Initialise le BMP085/BMP180 et utilise le mode STANDARD (valeur par défaut) # L'adresse du BMP sur le BUS est ici 0x77. # bmp = BMP085(0x77, debug=True) bmp = BMP085(0x77) # Pour utiliser un mode différent avec le BMP, vous pouvez décommenter l'une # des lignes suivantes: # bmp = BMP085(0x77, 0) # Mode ULTRALOWPOWER (super basse consommation) # bmp = BMP085(0x77, 1) # Mode STANDARD # bmp = BMP085(0x77, 2) # Mode HIRES (haute résolution) # bmp = BMP085(0x77, 3) # Mode ULTRAHIRES (Ultra haute résolution) temp = bmp.readTemperature() # Lecture de la température pressure = bmp.readPressure() # Lecture de la pression altitude = bmp.readAltitude() # Lecture de l'altitude print "Température: %.2f C" % temp print "Pression: %.2f hPa" % (pressure / 100.0) print "Altitude: %.2f" % altitude
Source: Using BMP085 with Raspberry Pi. Créé par Kevin Townsend pour AdaFruit Industries.
Traduction et corrections réalisée par Meurisse D pour MCHobby.be.
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.
Traduit avec l'autorisation d'AdaFruit Industries - Translated with the permission from Adafruit Industries - www.adafruit.com