Vue normale

Hier — 17 janvier 2025Raspberry-pi

RetroGaming : Les indispensables de la Super Nintendo

Par :Régis
17 janvier 2025 à 07:30

Dans le cadre de notre série d’articles sur les jeux incontournables à intégrer à votre console de rétro-gaming, nous allons aujourd’hui nous pencher sur la Super Nintendo Entertainment System (SNES). Cette console emblématique a marqué l’histoire du jeu vidéo et continue d’être chérie par les fans du monde entier. L’Histoire de la Super Nintendo Lancée au […]

L’article RetroGaming : Les indispensables de la Super Nintendo est apparu en premier sur Windtopik.

À partir d’avant-hierRaspberry-pi

Biais d’optimisme : les dangers d’une vision trop rose de l’avenir

Par :Régis
14 janvier 2025 à 07:30

Le biais d’optimisme est un phénomène fascinant qui influence notre perception du monde et nos décisions quotidiennes. En tant qu’individus, nous avons souvent tendance à croire que nous sommes moins exposés aux événements négatifs que les autres et que les résultats positifs sont plus probables pour nous. Dans cet article, nous allons explorer ce biais […]

L’article Biais d’optimisme : les dangers d’une vision trop rose de l’avenir est apparu en premier sur Windtopik.

MicroPython: réutiliser un afficheur VFD du lecteur CD CDP-CX350 (partie 2)

 

Bonjour amis Maker,

Le précédent article sur les tubes VFD (Vaccum Fluorescent Display) c'était le contrôleur VFD M9202 (aussi appelé MSM9202) de mon ancien Sony compact disk player CDP-CX35.


Poursuite du hacking

Après la prise en main de l'afficheur VFD, je veux maintenant prendre le contrôle du restant de la facade... cela concerne les LEDs, les encodeurs rotatifs et les boutons.
Sony compact disk player CDP-CX350


Interface Clavier

Le connecteur principal était déjà partiellement décodée pour l'afficheur VFD.

CDP-CX350 - détail de la carte principale

En poursuivant les investigations, j'ai découvert que les LEDs étaient contrôlées par un GPIO expander 16 bits (M66310). Pour leur part les boutons sont raccordés en grappe.

Voici donc le complément d'information concernant le connecteur principal (CON1) et le connecteur vers la carte fille (CON2).


On peut y voir que les broches DataIn, ShiftClk, Reset de l'afficheur VFD sont ici utilisées pour contrôler le GPIO Expander M66310 (plus le signal LatchClk).

Contrôler les LEDs

Pour prendre le contrôle des LEDs, il faut donc envoyer les 16 bits de données vers le M66310 puis activer le signal LatchClk pour mettre à jour les sorties sur le GPIO Expander.


Les données sont envoyés en utilisant les mêmes signaux DataIn, ShiftLck que l'afficheur VFD. Le contrôleur VFD a son ChipSelect désactivé durant la communication avec le M66310.

Comme déjà précisé, une fois les 16 bits de données envoyés vers le M66310, une impulsion est envoyé sur LatchClk pour envoyer les bits sur les sorties.

En suivant les traces, il est alors possible de relier LEDs et GPIOs du MF66310.

Une fois la bibliothèque m66310.py rédigée, le contrôle du GPIO expander est relativement simple.

from machine import Pin
from m66310 import M66310
import time

_reset = Pin(Pin.board.GP18, Pin.OUT, value=True ) # Reset désactivé
_cs = Pin( Pin.board.GP14, Pin.OUT, value=True ) # VFD désactivé
_sdata = Pin( Pin.board.GP13, Pin.OUT )
_sck = Pin( Pin.board.GP16, Pin.OUT, value=True )

# M66310 GPIO Expander, Latch on raising edge
_latch = Pin( Pin.board.GP20, Pin.OUT, value=True ) 

# Modifier tous les bits en un fois (sous forme de nombre)
leds = M66310( _sdata, _sck, _latch, _reset )
leds.data = data = 0b0000000000011100 # 16 bits.
leds.update()
time.sleep_ms( 500 )
leds.clear()
leds.update()

# Modification bit à bit
for bit_idx in range( 2, 16 ):
	print( bit_idx )
	leds[bit_idx]=True
	leds.update()
	time.sleep_ms(100)
	leds[bit_idx]=False
	leds.update()
leds.clear()
leds.update()

Détecter les boutons pressés

Dès le début de ce projet, je suis assez étonné de trouver deux entrées 5V et deux masses totalement distinctes sur le connecteur principal.

Il m'aura fallu attendre le décodage de la partie bouton pour me rendre compte que les boutons sont raccordés en grappe chacun avec une résistance d'une valeur différente.

En voici un exemple d'une série de boutons branché sur la broche "key1".

Raccordement des boutons en grappe

Il faut donc ajouter une résistance pour compléter un pont diviseur et ainsi obtenir une tension (qui dépend du bouton pressé).

Cela explique aussi la raison pour laquelle il existe deux masses et deux sources 5V. Un circuit est destiné à la lecture analogique et un autre circuit est destiné au circuits logiques et contrôleurs.
Le circuit analogique ne peut pas être perturbé par des parasites, variation de tension ou courant qu'il est plus facile de rencontrer sur le circuit logique (surtout à cause du contrôleur VFD).

La quantité de boutons sur le panneau fait qu'ils sont regroupés sur différentes grappes indépendantes. C'est ainsi que la carte présente les sorties Key0, Key1, Key2, Key3, Key4. Les encodeurs étant également des boutons un peu spéciaux, ceux-cis sont également repris sur les grappes.

J'ai documenté toutes les grappes dans le dépôt micropython-M9202-VFD.

Ensuite

  1. Je dois toujours réaliser un étage d'alimentation pour rendre un projet VFD autonome (j'avance sur ce point).
    Cela me facilitera aussi la vie lors du test d'autres VDF.
  2. La réalisation d'une carte personnalité permettra d'interagir facilement avec les éléments de ce panneau.

Ressources

Saint-Brock Robot Race le 29 Mars 2025 à Saint-Brieuc : Course de robot autonomre

Le 29 mars 2025 à Saint-Brieuc, pour la deuxième année, une course de robot mobile autonome sera organisée par Mace Robotics & Saint-Brieuc Factory (Fab Lab de Saint-Brieuc). Pour cette deuxième édition, venez avec votre robot DIY et participez à cette course. Des robots pourront aussi être prêtés si nécessaire pour l’événement. Cette course est […]

Cet article Saint-Brock Robot Race le 29 Mars 2025 à Saint-Brieuc : Course de robot autonomre a été publié en premier sur Framboise 314, le Raspberry Pi à la sauce française.....

RetroGaming : Les jeux indispensables de la Nintendo (NES)

Par :Régis
10 janvier 2025 à 07:30

Si vous êtes passionné(e) par le rétro-gaming et que vous voulez redécouvrir les classiques qui ont marqué l’histoire du jeu vidéo, alors cet article est fait pour vous ! La Nintendo Entertainment System (NES), sortie dans les années 80, a révolutionné le monde vidéoludique grâce à ses jeux emblématiques et son design novateur. Dans cet […]

L’article RetroGaming : Les jeux indispensables de la Nintendo (NES) est apparu en premier sur Windtopik.

Un Raspberry Pi 5 avec 16 Go de RAM !

La Fondation Raspberry Pi annonce la sortie d’un nouveau Raspberry Pi 5 équipé de 16Go de RAM. On avait déjà « de la place » avec la version 8Go et là, on double d’un coup la mémoire disponible ! A quoi ça pourra servir ? Pour commencer, seul un système d’exploitation 64 bits pourra gérer 16 Go […]

Cet article Un Raspberry Pi 5 avec 16 Go de RAM ! a été publié en premier sur Framboise 314, le Raspberry Pi à la sauce française.....

16 Go de RAM pour mon Raspberry-Pi 5

Bonjour à tous,

Cela aura prit un certain temps mais ça y est, il l'ont enfin sorti, le Raspberry-Pi 5 de 16 Go est enfin là.

Raspberry-Pi 5 de 16 Go

Le lecteur attentif remarquera que le PCB porte la mention 16GB RAM.
Il s'agit d'une PCB spécialement modifié pour supporter le module de 16 Go RAM.

Utilité de 16 Go RAM

Il n'est pas rare de rencontrer 16 Go de RAM sur un ordinateur. 

As t'on vraiment besoin de 16 Go de RAM?
La réponse serait: cela dépend de votre application. 

Le port PCIe permet déjà d'ajouter un disque NVME offrant ainsi des taux de transfert justifiant l'intérêt d'une capacité RAM plus importante.

Les applications gourmandes en RAM apprécieront cet espace supplémentaire.
Parmi elles, nous retrouvons:

  • Navigation internet : toujours aussi gourmande en ressource
  • LLM :  les grand modèle linguistique ont besoin de beaucoup de mémoire.
  • La virtualisation
  • Déploiement Kubernetes (conteneurs)
  • Conception graphique (modélisation 3D)
  • L'édition 4K : forcement gourmande en RAM.
  • Simulations : programmes gourmand en ressources processeur mais aussi en RAM.
  • Windows : probablement les plus RAMivore de tous les OS existant.
  • Mais aussi l'amélioration de la compilation d'application.

Où acheter

Chez l'un des Approved Reseller de la fondation comme MC Hobby.


Payconiq : crise de confiance chez les clients de Web-Marchand

Chers clients,
Chers Amis WebMarchand,
Chers Bancontact,

"Payconiq" - ca rime avec "Panique" !

A la veille d'une sortie cruciale, c'est très agacé que j'écris cet article qui, une fois de plus, étale les conséquences d'un fondamental manque de réflexion chez Payconiq/Banksys!

En effet, une récente modification technique chez Payconiq créée la panique chez les clients du WebMarchand MC Hobby.

Depuis quelques jours, Payconiq : spécialiste du paiement sûr et facile, très apprécié des belges, a étendu sa fenêtre de réponse aux WebMarchands de 2 heures!

En gros, vous payez tout de suite... mais le WebMarchand n'aura confirmation du paiement que dans un intervalle de 2 heures (ce qui est confirmé, 2 heures, vraiment!).

Et puisque le WebShop ne reçoit pas de confirmation, le panier n'est pas transformé en commande. D'autant que le prélèvement sur le compte bancaire du client est immédiat!
Pour une méthode de paiement instantané... "Ca la fout mal!".

Conséquence:

Nous avons des appels de clients débités sur leur compte bancaire qui ne comprennent pas  pourquoi il n'ont pas la commande correspondante dans le web-shop après leur paiement!

Web-marchand prit au piège:

Comme la solution Payconiq est liée à Bancontact, il est impossible de désactiver l'un sans désactiver l'autre.

Si le WebMarchand veux garder le moyen de paiement Bancontact (c'est dans son intérêt), il présente de-facto les paiement PayConiq.

Le mot de la fin

Espérons que Payconiq/Banksys se rendra rapidement compte de leur erreur!

Dominique





MicroPython: réutiliser un afficheur VFD du lecteur CD CDP-CX350 avec un Pico sous MicroPython

Bonjour amis Maker,

Je n'arrête décidément plus mes expérimentations avec les tubes VFD (Vaccum Fluorescent Display).
Cette fois, je me suis penché que contrôleur VFD M9202 (aussi appelé MSM9202) qui a sa propre petite histoire.


Introduction

Il y a bien des années, je me suis payé un Sony compact disk player CDP-CX350, un carrousel capable de contenir 300 Compact Discs. J'adorai ce lecteur.

Sony compact disk player CDP-CX350

Je parle au passé car ce magnifique appareil n'a pas survécu à ses multiples déménagements. C'est que 300 CD, cela fait son poids et jeunesse aidant j'ai habité divers endroits.
Et c'est avec désolation que j'ai découvert que mon génial lecteur CD avait mécaniquement dépassé tout espoir de réparation.toute lecture... nous étions en 2005!

Le maker était en sommeil

Bien qu'en 2005 je n'y connaissais pas grand chose en programmation microcontrôleur, j'ai procédé à la récupération de la face avant me disant qu'un jour, peut-être, je pourrai le recycler.

Sony compact disk player CDP-CX350 (face avant)

Sony compact disk player CDP-CX350 (face avant)

De nos jours

Nous sommes en 2025, j'ai ressorti la face avant du lecteur (photos ci-dessus) en vue d'un recyclage complet de l'afficheur VFD mais aussi les boutons, les LEDs, les encodeurs rotatifs, etc!

La carte principale à l'afficheur VFD est visible ci-dessous

CDP-CX350 Carte principale

De haut en bas, la carte reprend les éléments suivants:

  • Connecteur d'interface : en haut a gauche, destiné à recevoir un ruban. Ce connecteur 23 contacts permet de communiquer avec tous les éléments de la carte principale et carte fille.
  • Connecteur carte fille : ce connecteur bleu (toujours en haut) permet de connecter les éléments de la carte fille (encodeurs rotatifs, bouton play/pause/...)
  • Récepteur infrarouge : en haut à droite, permet de réceptionner les signaux de la télécommande.
  • L'afficheur VFD : superbe comme tous les autres et contenant de nombreux symboles. Ce VFD est piloté par un contrôleur VFD M9202 (OKI).
  • LEDs oranges : contrôlée avec un GPIO expander 16 bits M66310FP. Ce GPIO expander est aussi un LED Driver. Les deux contrôleurs M66310FP & M9202 partagent le même bus de communication.
  • Boutons : les nombreux boutons présent sur cette carte (comme la carte fille) sont regroupés par lot sur 5 lignes "keys" distinctes. Chacun de ces boutons ayant une résistance pull-down spécifique (dans son groupe), il faut utiliser une entrée analogique pour déterminer quel bouton est pressé dans un groupe donné.
  • Emetteur infrarouge : les 5 LEDs "bleues" sont en fait des émetteurs infrarouges accompagnés de leur circuit de puissance (les transistors) et connecteur d'interface (en bas à gauche)

Le contrôleur VFD M9202

CDP-CX350 - détail de la carte principale

A partir de la fiche technique du M9202, j'ai pu identifier les différentes connexions nécessaires au contrôle de l'afficheur.

C'est en lisant la fiche technique du M9202 (MSM9202) que j'ai remarqué que le protocole est identique à celui utilisé pour le ChipSet PT6302 de Princeton Technology.


CDP-CX350 - Contrôle du VFD

Si vous ne savez pas comment fonctionne un VFD, je conseille vivement la lecture du tout premier article sur les VFD.

Le connecteur reprend les signaux:

  • Clk : signal d'horloge du M9202 utilisé pour la transmission de données.
  • DataIn : signal de données du M9202 (communiqués bit-à-bit en commençant par le bit le moins significatif)
  • ChipSelect : activation du M9202. Nécessaire lorsque le microcontrôleur doit envoyer des données.
  • VFL : tension négative permettant de contrôler les grilles ( -25V est suffisant).
  • Heater1 & 2 : filament de chauffe (5 Ω), alimenté en 2.9V (consommation 170mA).

Les signaux identifiés, voici comment brancher le Pico pour contrôler le VFD.

  • Un 74AHCT125 est utilisé pour convertir les signaux logiques.
  • Le circuit Cut-off bias voltage est réalisé à l'aide de 2 diodes Zener et résistance de 2.2K
    il m'a fallu un certain temps pour me rendre compte que j'avais oublié de le monter... raison pour laquelle l'afficheur n'affichait absolument rien.

Le montage réalisé et la bibliothèque installée, il est possible de tester l'un des nombreux scripts d'exemples disponibles dans le dépôt.

Il est maintenant possible de tester les Digits et d'identifier leurs positions.
La disposition des caractères est un peu bizarre mais n'empêche en rien la représentation de texte.


Comme pour les autres VFD, le contrôle individuel des segments permet aussi de contrôler les divers symboles (voir le Digit #16 ci-dessous).

Contrôle des segments 0 à 34 d'un digit.

L'exemple test_btn_segment.py montre justement comment prendre le contrôle des segments sur le Digit #16.

Pour la première fois, j'utilise aussi l'ADRAM du contrôleur VFD.

ADRAM, 2 bits complémentaires par digits

l'ADRAM est un espace mémoire de deux bits supplémentaires par Digits (donc 35 segments + 2 bits ADRAM). Ces bits additionnels peuvent être utilisés pour activer/désactiver des symboles (ou points) supplémentaires.

Les bits ADRAM sont souvent utilisés pour activer un point décimal, double-point ou un curseur sur l'afficheur. 

Dans le cas présent l'ADRAM est utilisé pour activer un symbole supplémentaire sur l'écran. Ainsi, en fixant l'ADRAM du Digit #8 à 0b01, le libellé "GROUP" est illuminé au dessus du Digit #8.

M9202 : code et exemples

Le dépôt github micropython-M9202-VFD dispose des informations nécessaires à la prise de contrôle de l'afficheur VFD avec le contrôleur OKI M9202. 

La bibliothèque utilisée est vfd_pt63.py disponible dans le dépôt micropython-PT6302-VFD.

Dépôt GitHub micropython-M9202-VFD

Le dépôt contient plusieurs exemples utilisés pour tester l'afficheur VFD.

  • test_display_all.py : active le mode de test du VFD illuminant toutes les segments.
  • test_display_chars.py : les caractères A à Z sur les 16 positions du VFD.
  • test_display_str.py : affiche la chaîne de caractères "ABCDEFGHIJKLMNOP" sur l'afficheur à partir de la position 1. Très pratique pour deintifier la position de chaque Digit.
  • test_custom_char.py : création et affichage d'un caractère personnalisé.
  • test_segments.py : active progressivement les segments 0 à 34 du digit sélectionné.
  • test_btn_segment.py : utilise un bouton Up et Down (sur GPIO 0 et 1) pour contrôler le segment allumé entre 0 et 34.
  • test_adram.py : modifie les bits ADRAM des digits de 1 à 16. Permet d'identifier les éléments/symboles activés par les combinaisons binaires testées.
  • test_adram_raw.py : manipulation brut de l'ADRAM par envoi direct des messages. Uniquement à des fins de démonstration.
  • test_btn_adram.py : Utilise un bouton Up et Down (sur GPIO 0 et 1) pour contrôler le Digit (de 1 à 16) dont l'ADRAM est modifié.
  • test_raw.py : test brut de l'afficheur VFD en envoyant des messages brutes. Uniquement à des fins de démonstration.

Boutons, encodeurs et LEDs

Le décodage de ces éléments est en cours. Le dépôt contient déjà des informations mais il reste encore un travail non négligeable à réaliser.
Cela fera l'objet d'un autre article.

Ressources

N'hésitez pas à partager vos commentaires et suggestions.

Dominique

Biais d’attribution : comment il influence nos jugements et nos relations

Par :Régis
7 janvier 2025 à 07:30

Dans notre vie quotidienne, nous faisons souvent des jugements sur les comportements des autres et sur les nôtres. L’un des biais cognitifs les plus répandus qui influence ces jugements est le biais d’attribution. Ce biais nous pousse à attribuer les échecs des autres à leurs caractéristiques personnelles tout en expliquant nos propres échecs par des facteurs […]

L’article Biais d’attribution : comment il influence nos jugements et nos relations est apparu en premier sur Windtopik.

MicroPython: réutiliser un afficheur VFD Proximus TV avec un Pico sous MicroPython

Bonjour Amis Maker Belge,

Cet article intéresse certainement tous les Makers mais les Belges se sentiront privilégié ;-)
Après le contrôleur VFD M660004 dans le précédent article, cette fois, c'est le contrôleur VFD PT6302 qui est à l'honneur.


Introduction

Mon tout premier afficheur VFD (Vaccum FLuorescent Display) fût récupéré sur un décodeur Belgacom TV (aujourd'hui Proximus TV) de 4ieme génération.

En 2022, je démontais le décodeur pour le transformer en alimentation d'établi. A cette occasion, je mettais l'afficheur de côté en espérant pourvoir le hacker.

Fort de ma toute récente expérience avec le VFD de Sony, j'ai embrayé sur celui de Belgacom/Proximus TV que l'on peu admirer dans toute sa gloire ci-dessous!

Source: le dépôt micropython-PT6302-VFD

Fonctionnement d'un VFD

Si vous ne savez pas encore comment cela fonctionne, je vous invite à lire la section "Fonctionnement des Vaccum Fluorescent Display" dans mon précédent article.

Préparer la carte Belgacom

A l'évidence, la carte est équipée des éléments nécessaires pour générer la tension négative pour les grilles ainsi que l'alimentation du filament.
Diandre! Je ne suis jamais arrivé à la faire fonctionner!

J'ai donc sorti mon fer à souder et j'ai éliminé tous les composants entre les boutons poussoirs et le bord opposé de la carte!  J'ai bien entendu préservé le contrôleur et les composants directement attachés.

Eliminer/déssouder les composants non essentiels!
Source: le dépôt micropython-PT6302-VFD

De la sorte, je me mets à l'abri de comportements électroniques indésirables lorsque je prendrais le contrôle du contrôleur VFD.

A partir de la fiche technique du contrôleur PT6302 (disponible dans le dépôt), j'ai repéré les signaux utiles et les broches correspondants.

Cliquer pour agrandir
Source: le dépôt micropython-PT6302-VFD
  • VDD: Tension logique (5V).
  • VEE: Tension négative utilisé pour fixer le potentiel du filament de chauffe (-25 à -35 volts)
  • VSS: masse commune.
  • RSTB: Reset du contrôleur
  • CSB: Chip Select. Placez le au niveau bas pour communiquer avec le composant.
  • CLKB: signal d'horloge. L'acquisition du bit de données se fait sur le flan montant du signal d'horloge.
  • DIN: Data Input=entrée de donnée. Les données sont envoyée bit à bit (LSBF = bit le moins significatif en premier).

Brancher sur un Pico

Avant d'envisager le branchement sur un Pico, il faut:

  1. Recréer le circuit de polarisation du filament de tungstène. C'est qu'en enlevant tous les composants... j'ai aussi enlevé ces éléments.
  2. Récupérer les signaux  VDD, VEE, VSS, RSTB, CLKB, DIN du contrôleur (sans oublier ceux du filament de chauffe).

Polarisation du filament

Par expérimentation, une tension de 2.9V est suffisant (le courant de chauffe atteint 150mA). Deux résistance de 500 Ohms sont utilisés (appris avec le VFD de Sony)

Par expérience, encore, une tension VEE (ou VP) de -25V est suffisante pour un fonctionnement correct.
Une tension de -35V est également convenable mais fait un peu trop chauffer la résistance de 2.2K (1/4W). Avec VEE de -25V, la tension bias est alors de -19V, un différence de 6V qui s'est révélée suffisante à l'usage.

Récupération des signaux

Vient ensuite la localisation de tous les signaux VDD, VEE, VSS, RSTB, CLKB, DIN sur le contrôleur (où différents endroits de la carte).




Brancher sur Raspberry-Pi Pico

Ayant décidé de garder une tension logique de 5V pour le contrôleur VFD, il faut donc utiliser un LevelShifter (un 74AHCT125) pour adapter les tensions.

Source: le dépôt micropython-PT6302-VFD

Bibliothèque MicroPython

Il fallait s'en douter... ce projet devait inévitablement déraper vers MicroPython.

Le dépôt GitHub micropython-PT6302-VFD contient la bibliothèque composée de deux fichiers:

  • vfd_pt63.py : contrôle des fonctions essentielles du contrôleur VFD.
  • vfd_proximus.py : fonctions avancées facilitant la prise en main de l'afficheur utilisé sur Proximus TV / Belgacom TV.

Scripts d'exemple

le dépôt reprend de nombreux exemples mais c'est principalement ceux relatifs à ProximusTV qui sont les plus intéressants.

Ce premier exemple indique comment afficher du texte et allumer/éteindre les symboles de l'écran.

from vfd_proximus import *
from machine import Pin
import time

d = VFD_Proximus( sck_pin=Pin.board.GP16, sdata_pin=Pin.board.GP13, cs_pin=Pin.board.GP14, reset_pin=Pin.board.GP18 )
d.print("VFD Proximus") 

# affiche toutes les options une par une
#   TITLE, CHANNEL, TRACK, STEREO, RECORD, CLOCK, ANTENNA, AM, FM
for option in ALL_OPTIONS:
	d.options += option
	time.sleep_ms( 500 )

for option in ALL_OPTIONS:
	d.options -= option
	time.sleep_ms( 500 )

d.clrscr()
d.print("Done !")

Alors, l'afficheur de Belgacom TV / Proximus TV dispose de trois sections d'affichage sur le dessus de l'écran. C'est trois sections sont accessibles par l'intermédiaire des propriétés left , center , right .

Source: le dépôt micropython-PT6302-VFD

Il existe pas mal de moyen d'y afficher des informations, y compris des entiers et nombre décimaux comme l'indique l'exemple ci-dessous.

from vfd_proximus import *
from machine import Pin
import time

d = VFD_Proximus( sck_pin=Pin.board.GP16, sdata_pin=Pin.board.GP13, cs_pin=Pin.board.GP14, reset_pin=Pin.board.GP18 )
d.print("Show float")

VALUES =  [1.25,15.2,32,133.78,73.1,5.2]

for value in VALUES:
	d.center.float( value )
	d.update()
	time.sleep(1)
d.center.clear()
d.update()

for value in VALUES:
	d.left.float( value )
	d.update()
	time.sleep(1)
d.left.clear()
d.update()

d.clrscr()
d.print('Done!')

Ce second exemple se concentre sur le disque dans la section de droite. Le script fait d'abord clignoter le disque... puis fait tourner un secteur sur le disque.

from vfd_proximus import *
from machine import Pin
import time

d = VFD_Proximus( sck_pin=Pin.board.GP16, sdata_pin=Pin.board.GP13, cs_pin=Pin.board.GP14, reset_pin=Pin.board.GP18 )
d.print("Show DISC")

# Allumer éteindre le disque
for i in range( 10 ):
  d.right.disc( i%2 )
  d.right.update()
  time.sleep_ms( 500 )
d.right.disc( False )

# Rotation du disque
d.right.disc_start()
d.update()
while True:
  d.right.disc_step()
  d.update()
  time.sleep_ms( 50 )
d.right.disc( False )


Enfin, un exemple simple mais celui que je préfère.... afficher l'heure.
Les heures et minutes sont affichées sur la section centrale... tandis que les secondes sont affichées sur la section de droite.

from vfd_proximus import *
from machine import Pin, RTC
import time

rtc = RTC()

d = VFD_Proximus( sck_pin=Pin.board.GP16, sdata_pin=Pin.board.GP13, cs_pin=Pin.board.GP14, reset_pin=Pin.board.GP18 )
d.print("VFD Time") 
d.center.separator = COLON
d.right.separator = COLON

while True:
	year, month, day, weekday, hours, minutes, seconds, subseconds = rtc.datetime()
	d.center.set( digit_group2=hours, digit_group1=minutes )
	d.right.set( seconds )
	d.update()
	time.sleep_ms( 200 )

Ressources

Si le sujet vous intéresse, voyez le dépôt GitHub contient d'autres informations.

MCHobby investit du temps et de l'argent dans la réalisation de traduction et/ou documentation. C'est un travail long et fastidieux réalisé dans l'esprit Open-Source... donc gratuit et librement accessible. 

SI vous aimez nos traductions et documentations ALORS aidez nous à en produire plus en achetant vos produits chez MCHobby.

Red Wings – Aces of the Skys : Revivez les batailles aériennes de 14-18

Par :Régis
3 janvier 2025 à 07:30

Dans le monde des jeux vidéo, il est rare de trouver des titres qui combinent une expérience de jeu accessible avec une touche d’histoire. Red Wings: Aces of the Sky est l’un de ces jeux. Développé par All in! Games, ce jeu d’action arcade vous plonge dans les cieux tumultueux de la Première Guerre mondiale, où vous […]

L’article Red Wings – Aces of the Skys : Revivez les batailles aériennes de 14-18 est apparu en premier sur Windtopik.

❌
❌