Table des matières

Smartcitizen

Le Smart Citizen Kit est né de la collaboration entre les « Fab Labs » de Barcelone et l'Institut d'Architecture Avancée de Catalogne, tous deux experts de l'impact des nouvelles technologies sur l'habitat humain. Ce kit open source (librement reproductible) est capable de capter et d’analyser différentes données environnementales en temps réel : température, ensoleillement, humidité, CO2, NO2, décibel…

Le module électronique peut envoyer ses données environnementale sur la plateforme web proposée, il peut aussi marcher “off line” en écrivant les données sur une carte SD, ou se connecter à d'autres services en ligne commerciaux ou artisanaux, ou encore faire l'objet du développement d'une application Android avec Kivy pour visualiser les données.


Kit de mesure SmartCitizen - approches hardware et software

Voir la page dédiée aux recherches et expérimentations autour du kit SmartCitizen coté logiciel et matériel : extraction de données, envoi par client mqtt, connexion au réseau Lora, …

Application SmartCitizen Android avec Kivy

smartcitizen.apk

Ressources

apk

smartcitizen.apk du 16/02/2020

Les choses non réussies

Les difficultés rencontrées

L'accès à des variables d'une class depuis une autre

La class A peut accéder à la variable self.toto de la class B, mais pas l'inverse: la class B ne peut pas accéder à la variable self.truc de la class A. La solution utilisée dans cette application est un Clock dans A qui actualise la valeur de B.

Une solution plus élégante est utilisée dans accelerometer: main.py avec

class AccelerometerApp(App):
    def build(self):
        return Accelerometer(self)
 
class Accelerometer(BoxLayout):
    def __init__(self, app, **kwargs):
        super().__init__(**kwargs)
        self.app = app
        self.app.osc = OSC()
 
class OSC:
    def __init__(self):
        self.histo = []
        self.server = OSCThreadServer()
        self.server.bind(b'/histo', self.on_histo)
 
    def on_histo(self, *args):
        self.histo = ....
 
class Screen2:
    def __init__(self):
        self.app = App.get_running_app() # dans __init__()
        # et appel de l'attribut histo de OSC avec
        self.app.osc.histo
        Clock.schedule_once(self._once, 1)
 
    def _once(self, dt):
        Clock.schedule_interval(self.update, 0.1)
 
    def update(self, dt): 
        blabla = self.app.osc.histo 
        # blabla retrouve la valeur de histo de OSC !!!!

Création du graph dans le kv

Widgets Kivy utilisés

Une barre de menu

Widgets classiques

Widgets classiques pour interface utilisateur

Une image en background

Une image avec canal alpha sur un fond blanc dans un BoxLayout

Affichage d'info

Une belle courbe

buildozer.spec

[app]
title = Smart Citizen
package.name = smartcitizen
package.domain = org.test
source.dir = .
source.include_exts = py,png,jpg,kv,atlas
source.exclude_dirs = old, bin, recherche, garden_graph_example
source.include_patterns = images/*.jpg,images/*.png
version.regex = __version__ = ['"](.*)['"]
version.filename = %(source.dir)s/main.py
requirements = python3,kivy,requests,kivy_garden.graph
garden_requirements = graph
orientation = all
fullscreen = 1
android.permissions = INTERNET
android.arch = armeabi-v7a
[buildozer]
log_level = 2
warn_on_root = 1

Thread in Kivy

Pour stopper un thread à la fermeture de la fenêtre, le définir comme Salsa du démon

        thread_update = threading.Thread(target=self.update)
        thread_update.setDaemon(True)
        thread_update.start()

ou
class threading.Thread(group=None, target=None, name=None, args=(), kwargs={}, *, daemon=None)