Pages

vendredi 30 novembre 2018

Utiliser un écran Nextion avec Flowcode et Arduino Mega

Suite à quelques articles sur l'écran Nextion, je vais montrer ici comment l'utiliser avec Flowcode et une Mega (plus pratique pour gérer un second UART).

Rappel : La famille d'écran Nextion a comme caractéristiques principales :

  • La facilité de mise en oeuvre : liaision Rx/Tx (pas de protocole spécial)
  • La variété de la gamme
  • Le logiciel simple à utiliser pour créer l'IHM
  • Le mode tactile efficace et rapide à mettre en place
Je vais ajouter dans cet article, donc dans le programme, une interruption. Pourquoi une interruption ?
Et.... qu'est-ce qu'une interruption ?

Une interruption, ben..... ça interrompt le programme. Voilà ! 
Pour faire simple, le programme principal tourne en boucle, fait son travail. Bref, tout se passe bien. Arrive un événement, qu'on attendait, bien sûr, mais on ne savait pas quand. Sans utiliser l'interruption, on risque tout simplement de le rater. Par contre, si on utilise l'interruption, le programme s'arrête net, lance un sous-programme défini à l'avance pour l'événement attendu et, dès que le sous programme est fini, le programme principal reprend là où il s'est arrêté.

Interruption (très) simplifiée :
Le programme se déroule, parfaitement, indéfiniment.... et ..... soudain, juste à la fin de l'action 2 survient l'événement attendu ! Le programme principal s'interrompt et le sous-programme d'interruption démarre. Quand celui-ci a fini, le programme principal reprend là ou il s'est arrête (on peut aussi le forcer à redémarrer à un autre endroit, en fonction des besoins)


Il est possible de déclencher une interruption de différentes manières et ici, on va la déclencher sur un changement de niveau d'une broche, en l'occurrence, la broche Rx3 (D14) de la Mega. Pourquoi ? Parce que c'est justement l'événement que l'on attend. 
Ah, je n'ai pas précisé quel était cet événement : l'appui sur un bouton du Nextion.

Dans mon exemple, je récupère la température issue d'un DHT11. Souci, ce composant bien que facile à utiliser présente un énorme défaut : il faut attendre une seconde entre chaque mesure. De ce fait, soit je mets une pause d'une seconde dans le programme, dans ce cas je peux rater l'arrivée d'une information sur le port série, soit je diminue la pause, mais dans ce cas, je ne sais pas quelle est la température....
D'où l'interruption : le programme fait son boulot, il mesure et affiche la température toutes les secondes et si un appui sur l'écran se produit, une interruption se déclenche.


IHM utilisée :
En mode simulation :

Vérification à l'analyseur logique (Avec Sigrok):

Le câblage :


Passons à Flowcode :

Le panneau utilisé :

Le programme se base sur le modèle IATR :

Initialisation :
Configuration de l'interruption :


Acquisition :
Traitement :
pour la ligne "n0.val=", il faut aller sur les autres articles Nextion de ce blog ;-)

Restitution :
Sous-programme "envoi"
Sous-programme d'interruption :
Et voilà :


En vidéo :
Désolé, pas facile de tenir le téléphone et l'écran tactile tout en visant bien ;-) ;-)



Une question ?









dimanche 11 novembre 2018

Utiliser un écran OLED I2C avec Flowcode et une Arduino UNO

Il est (assez) facile d'utiliser des écrans OLED de petite taille avec une carte Arduino avec la bonne bibliothèque.  De plus, ces écrans sont très bon marché et se connectent en I2C.
Je parle de ce type d'écran :
Mais comment les utiliser avec Flowcode ?
C'est simple, il suffit de connaître le contrôleur sur le circuit et regarder s'il existe dans le logiciel. En général, il s'agit d'un SSD1306 pour un modèle I2C.

1) Placer le composant dans le panneau et le configurer comme sur la capture ci-dessous :

Rappels : SDA sur A4 (PC4) et SCL sur A5 (PC5)
2) Réaliser le programme suivant :

3) Simulation :
Quelques ajustements sont à prévoir....

4) Câbler et téléverser vers la carte Arduino :


Sympa pour les projets !

A vous de tester.....






dimanche 4 novembre 2018

Obtenir Target3001! version "make" gratuitement

Petit article pour petite info :

Comme le titre l'indique, Target3001! Make peut être obtenu GRATUITEMENT à certaines dates :



Ah oui, sinon, Target3001!, c'est ça :




Note : je n'ai absolument pas été sponsorisé par cette société.....
Je partage une bonne expérience, c'est tout...
La version "Discover" reste gratuite pour tous !






jeudi 1 novembre 2018

Envoi et réception d'un SMS avec Flowcode et une Arduino Mega

Les fabricants de modules GSM sont assez sympa avec nous... ils produisent des cartes et des chips utilisant quasiment toujours les mêmes commandes AT (quasiment !). Cela est très pratique dans la conception d'un projet devant utiliser un module GSM/GPRS.

Ici, j'utilise ce module :

Il est tout à fait possible de programmer en C avec l'IDE d'Arduino ou avec un module USB-UART. Cependant, cette méthode est un peu.... fastidieuse. Heureusement, Flowcode permet de faire la même chose mais très simplement. Par contre, il est nécessaire d'utiliser une carte MEGA pour une raison simple : Flowcode ne propose pas d'émulation logiciel pour le GSM (ni le GPS). Il faut dont un deuxième UART matériel si on veut accéder au port série durant la mise au point. Après, le passage à la UNO est possible.


Mode opératoire :


Le programme qui fait tout ça :
Channel 3 correspond à RX2/TX2 sur la Mega

C'est tout ? ......Oui !

Détails :
Penser à bien changer le numéro de portable ;-)

Câblage : (pas besoin d'alimentation externe avec ce module, il ne consomme pas beaucoup de courant).


U_RXD sur TX2
U_TXD sur RX2
Vcc_In sur 5V
Gnd sur Gnd


Et voilà !!!!!




mardi 30 octobre 2018

Utiliser les Google Charts dans App Inventor

Le précédent article sur AI2 montre comment créer simplement une jauge en local.
Ici je vais présenter la version "élaborée" avec Google Charts (avec JavaScript (que je n'expliquerai pas ici))

Mode opératoire :



Avant tout, petite information :

Tout est dit !


Page Gallery de Google Charts :

En particulier, les jauges :


1) Cliquer sur

Le code source apparaît :

2) Copier le code et l'ouvrir dans NotePad++ par exemple :


Détail :



Avant de faire des modification, il est possible de tester en "live" les changements dans le code en cliquant ici :

On arrive sur cette page, on peut tout (ou presque) modifier :

Avant :


Après :



Je pense qu'il est préférable de tester en ligne puis de modifier le fichier dans NotePad++ quand on a atteint l'objectif... 


3) Créer un répertoire sur le dispositif où sera installé le fichier HTML incluant le Javascript :

Les noms des répertoires ont été créés pour mon smartphone, on peut donner les noms que l'on veut, à condition de bien reprendre le chemin après.


 Utiliser "Créer dossier" pour ..... créer un dossier....😊
On peut aussi utiliser AirDroid pour accéder directement au smartphone.....

4) Création de l'application :

Je vais faire varier la jauge en fonction d'un slide :

Attention, ne pas oublier le composant "FILE" qui va permettre de travailler sur un fichier interne.


Édition des blocs :


Détail :

 Attention, le chemin d'écriture de fichier est plus court que celui de la lecture, c'est pas moi qui le dit, c'est Android !

A partir de là, il suffit de récupérer le fichier APK par la méthode habituelle....






Un souci, une remarque ? un mail.....