Taula de continguts:
2025 Autora: John Day | [email protected]. Última modificació: 2025-01-23 14:37
En el meu primer projecte amb Arduino Nano connectat a la pantalla tàctil de Nextion, havia escrit una llarga sèrie d’ordres per comunicar-les a Nextion mitjançant el port sèrie i això és inevitable si necessitem enviar ordres totalment independents, en moments aleatoris.
També he de reconèixer que vaig passar més temps "lluitant" amb les biblioteques que qualsevol altra cosa. Així doncs, vaig anar treballant a poc a poc sense les pesades biblioteques ITEAD.
Aviat em vaig adonar que no tenia urgència de comunicar a Nextion els canvis en els atributs dels objectes visuals, però prefereixo esperar a recollir-los i enviar-los a Nextion en general, quan vaig obtenir un grup complet.
Intentaré explicar-me millor.
Quan en el meu projecte compost per 16 indicacions textuals vull activar o desactivar algunes d'elles, ho faig aprofitant l'atribut "bco" que, per activar, passa (per exemple) de gris fosc a blanc (si està activat) un rectangle negre) i viceversa per apagar-se.
A la meva aplicació em va semblar inútil enviar 16 ordres al port sèrie en 16 moments diferents, una per a cada "bco" dels 16 senyals.
En lloc d'això, prefereixo que Arduino reculli quins senyals han d'estar "encès" (ALT) i quins han d'estar "apagats" (BAIX) en un registre de 16 bits, on cada bit correspon a una de les 16 senyalitzacions de Nextion.
Després d’actualitzar cada bit del registre, transmet el seu valor a Nextion, un missatge únic que conté una informació col·lectiva sobre 16 elements.
D’aquesta manera, la comunicació des d’Arduino i Nextion es redueix considerablement, ja que en aquell missatge únic que es transmet en sèrie a Nextion, es recull informació que d’altra manera hauria requerit la transmissió de 16 missatges.
És cert que no sempre cal actualitzar tots els informes, però estic segur que fer una altra cosa perdria més temps.
Naturalment, cada bit que conté l’enter rebut per Arduino, la pantalla Nextion l’haurà d’associar a l’atribut desitjat.
Això vol dir que el codi s'ha d'escriure a la pantalla de Nextion, però no s'ha d'espantar: si he tingut èxit …
Hi ha un doble avantatge: Arduino tindrà un codi més lleuger i participarà menys en la comunicació en sèrie amb Nextion.
Nextion després de rebre les dades en un sol missatge, les utilitzarà molt més ràpidament que si esperés 16 missatges. Per tant, l’encesa o apagada de 16 senyals serà gairebé contemporània respecte al mode més habitual, en què transcorre el temps per a un nombre desconegut de missatges entre l’execució de l’ordre per a la primera senyalització i l’ordre per a la darrera senyalització.
A la pantalla de Nextion vaig crear aquest sistema de manera clàssica, és a dir, girar un registre de "màscara" cada vegada us permet examinar cadascun dels 16 bits. Quan el bit examinat és ALT, el senyal associat amb aquest bit s'encén a la pantalla i s'apaga quan un bit és BAIX.
L'aspecte "negatiu" d'aquest sistema és que el codi escrit a la pantalla Nextion és menys convenient documentar-se que el codi Arduino. A més, el codi Nextion corre el risc de ser escampat per diversos objectes. Cal tenir cura de documentar el que feu immediatament.
Utilitzo Notepad ++ per escriure el codi que després copio a l’objecte Nextion que es troba gairebé exclusivament a tm0 de la pàgina 0.
La sintaxi del llenguatge Nextion té nombroses limitacions, però aconsegueix superar-les o evitar-les amb un mínim d’esforç i intentar veure els problemes des de punts de vista que també són inusuals.
Com a exemple, informo de la forma en què Arduino escriu el registre que es vol transmetre, escrit per mi de la manera més elemental possible.
Pas 1: Com es transmet el registre
Al fitxer ArduinoCode. PDF mostro tot el meu esbós. (Llegir el codi aquí avall no està tan clar)
A continuació, només vull mostrar de quina manera Arduino envia el registre de 16 bits a Nextion, sense l'ajut de les biblioteques, però només respectant la sintaxi descrita per ITEAD.
//***************************************************************************************
void NexUpd ()
//***************************************************************************************
{
SRSerial.print ("vINP.val =");
SRSerial.print (InpReg); // transmet els 16 bits recollits a la pantalla Nextion
SRSerial.print (InpReg); // transmet els 16 bits recollits a la pantalla Nextion
SRSerial.write (termin); // 255
SRSerial.write (termin); // 255
SRSerial.write (termin); // 255
}
//***************************************************************************************
Pas 2:.. Però abans …
Per descomptat, el codi comença amb totes les declaracions i la configuració ().
Les entrades són INPUT_PULLUP, de manera que els commutadors d’entrada normalment estan oberts i, quan estan tancats, apliquen el GND a l’entrada corresponent.
(Aquest és el meu primer instructiu i em sap greu mostrar-vos el meu codi d'aquesta mala manera. Si us plau, descarregueu el fitxer ArduinoCode. PDF que està molt clar.
Deixeu-me parlar-ne més
He desenvolupat la meva manera de "explicar" a la pantalla de Nextion què ha de fer. Normalment, l’MCU (Arduino en el meu cas) envia un missatge per a cada variació que s’aplica a l’atribut de qualsevol objecte. Aquest mètode perd molt de temps per fer coses que no sempre són tan urgents per carregar contínuament la línia de sèrie. Em va semblar més convenient que Arduino recollís en registres de 16 bits la informació sobre els atributs que poden variar a Nextion. Aproximadament cada 500 mS, el meu Arduino envia a Nextion un missatge que conté els 16 bits continguts a cada registre alhora. Viouslybviament, a Nextion necessitem el codi que gestioni el que s’ha d’executar. Aquesta distribució de la tasca (i del codi) permet obtenir molts altres avantatges. Per exemple, penseu com fer parpellejar una llum. Amb el meu enfocament és fàcil: introduïu una mica al registre Arduino i envieu-lo a Nextion. Els registres bessons de Nextion es podrien actualitzar des d’Arduino molt poques vegades, perquè la freqüència de parpelleig és independent de la comunicació; la freqüència de parpelleig depèn d'un objecte Timer a Nextion i pot funcionar amb una base de temps mínima propera als 50 mS. Així, amb el meu mètode podem parpellejar una llum a Nextion a una freqüència relativament alta (suposem que 2 Hz), fins i tot si el meu Arduino envia missatges cada 10 segons, només per un exemple extrem. Això pot suggerir el problema contrari: com fer-ho si la comunicació falla? Aquest no és l'objecte d'aquesta discussió, però ja he resolt aquest problema amb una mena de Watch Dog: un dins del codi Arduino i un altre al codi Nextion.
El parpelleig està regulat pel codi Nextion, on cada llum segueix les seves regles adequades: ON / OFF o VERD / VERMELL o també canviant l’interior escrit (o altres més). Podria explicar algunes coses més sobre el meu projecte, però prefereixo esperar les vostres preguntes abans d'afegir massa paraules que no em resultin tan fàcils de traduir com ho faria.
Pas 3: Edició dels objectes Nextion
Aquí teniu una part del codi que vaig escriure amb Nextion Editor a l’objecte tm0.
No s’escapa de l’avís que amb els 16 bits rebuts d’Arduino, la pantalla Nextion no només activa i desactiva els senyals. De moment omet les explicacions per no complicar la comprensió.
Sóc principiant i, per tant, és millor descarregar el codi de Nextion. PDF pàgina en lloc de llegir el codi confús aquí baix. (Ho sento, aquest és el meu primer instructable)
Si ho desitgeu, podeu descarregar el codi complet "HMI" d'aquesta aplicació. El nom del fitxer d'aquest codi és POW1225. HMI. Es pot executar a la pantalla Nextion NX4024T032, però per entendre-la heu de nedar en molts objectes i mirar el codi a la finestra petita de l'editor. Per tant, crec que serà més fàcil buscar el codi principal, escrit al fitxer Nextion code. PDF
// Projecte POW1225. HMI el 15 de maig de 2019
// VACC (va0) Acumulador
// vINP (va1) Registre d'entrada xxxx xxxx xxxx xxxx
tm0.en = 1 // tm0 Inici
tm0.tim = 50 // tm0 Base de temps 50 mS
// RDY ***************
vACC.val = vINP.val i 0x0001 // Màscara
if (vACC.val! = 0) // Prova RDY
{
tRDY.pco = BLAU // VERMELL
} altra cosa
{
tRDY.pco = GRIS // GRIS fosc
}
// PWR ***************
vACC.val = vINP.val i 0x0002
if (vACC.val! = 0) // Prova PWR
{
tPWR.pco = VERD // VERD clar
tPON.txt = "ACTIVAT" // ACTIVAT
tPON.pco = VERD // VERD clar
} altra cosa
{
tPWR.pco = GRIS // GRIS fosc 33808
tPON.txt = "DESACTIVAT" // DESACTIVAT
tPON.pco = GRIS // GRIS fosc 33808
}
// SEC ***************
vACC.val = vINP.val i 0x0004
if (vACC.val! = 0) // Prova DRY
{
tDRV.pco = BLAU // BLAU
tDRY.pco = BLAU // BLAU
} altra cosa
{
tDRV.pco = GRIS // GRIS fosc 33808
tDRY.pco = GRIS // GRIS fosc 33808
}
// CORRER ***************
vACC.val = vINP.val i 0x0018
if (vACC.val! = 0) // Prova RUN
{
tRUN.bco = VERMELL // MARCIA VERMELL (activat)
tRUN.pco = NEGRE // a NEGRE
tDIR.bco = VERMELL // DIR VERMELL
tDIR.pco = NEGRE // a NEGRE
} altra cosa
{
tRUN.bco = 32768 // MARCIA GREY (desactivat)
tRUN.pco = GRIS // sobre GRIS
tDIR.bco = 32768 // DIR GREEN fosc 1024
tDIR.pco = GRIS // DIR GRIS
tDIR.txt = "---" // STOP
}
// ESQUERRA **************
vACC.val = vINP.val i 0x0008
if (vACC.val! = 0) // Prova RUN Right
{
tDIR.txt = "<<<" // DIR ESQUERRA
}
// DRET *************
vACC.val = vINP.val i 0x0010
if (vACC.val! = 0) // Prova RUN left
{
tDIR.txt = ">>>" // DIR DRET
}
// TOTS DOS **************
vACC.val = vINP.val i 0x0018
if (vACC.val == 24) // Prova RUN tots dos
{
tDIR.txt = ">>! <<" // DIR AMB
}
// TEST **************
vACC.val = vINP.val i 0x0020
if (vACC.val! = 0) // Prova TEST
{
tTEST.pco = BLANC // BLANC
tsw tTEST, 1 // Activa els esdeveniments tàctils
} altra cosa
{
tTEST.pco = GRIS // GRIS fosc 33808
tsw tTEST, 0 // Desactiva els esdeveniments tàctils
}
// FALL *************
vACC.val = vINP.val i 0x0040
if (vACC.val == 0) // FALTA de la prova
{
tFLT.pco = GRIS // FALLA absent
}
if (vACC.val! = 0)
{
tFLT.pco = GROC // FALL present
}
// EME ***************
vACC.val = vINP.val i 0x0080
if (vACC.val == 0) // Prova EME
{
tEME.pco = GRIS // EME absent
}
if (vACC.val! = 0)
{
tEME.pco = VERMELL // EME present
}
}
// FERMO *************
vACC.val = vINP.val i 0x0100
if (vACC.val! = 0) // Prova FERMO
{
tFER.pco = NEGRE // NEGRE
tFER.bco = VERD // VERD
} altra cosa
{
tFER.pco = GRIS // GRIS
tFER.bco = 672 // VERD fosc
}
// *******************
Reconeixement
Vull donar els meus agraïments a Gideon Rossouwv perquè llegint els seus instructables he guanyat ràpidament part dels meus objectius. Gràcies senyor. Gideon Rossouwv
Recomanat:
Lent macro de bricolatge amb AF (diferent a la resta de lents macro de bricolatge): 4 passos (amb imatges)
Lents macro de bricolatge amb AF (diferents a la resta de lents macro de bricolatge): he vist molta gent fabricant objectius macro amb un objectiu de kit estàndard (normalment de 18 a 55 mm). La majoria són objectius que només s’enganxen a la càmera cap enrere o s’elimina l’element frontal. Hi ha desavantatges per a aquestes dues opcions. Per muntar l'objectiu
La màquina inútil diferent: 6 passos (amb imatges)
La màquina inútil diferent: amb tantes màquines inútils, he intentat fer-ne una de diferent. En lloc de tenir un mecanisme que empeny l’interruptor alternatiu, aquesta màquina simplement gira l’interruptor de 180 graus. En aquest projecte he utilitzat un Nema 17 motor de pas, que
L'OLOID en moviment: una mascota diferent en diferents temps: 10 passos (amb imatges)
L’OLOID en moviment: una mascota diferent en diferents temps: la Corona ha canviat les nostres vides: ens exigeix una distància física que, al seu torn, condueix al distanciament social. Llavors, què podria ser una solució? Potser una mascota? Però no, Corona prové d’animals. Salvem-nos d’una altra Corona 2.0. Però si ja
Zocus: zoom i enfocament sense fils per a la càmera DSLR: 24 passos (amb imatges)
Zocus: zoom i enfocament sense fils per a la vostra càmera rèflex digital: Zocus us permet controlar sense fils el zoom i l'enfocament de la vostra càmera rèflex digital, mitjançant la ZocusApp habilitada per Bluetooth, a l'iPad o a l'iPhone (Android properament). Va ser desenvolupat originalment per a James Dunn, apassionat de la fotografia, però que també
Liberació del cable remot Olympus Evolt E510 (versió 2 amb enfocament automàtic al control remot): 6 passos (amb imatges)
Liberació del cable remot Olympus Evolt E510 (versió 2 amb enfocament automàtic al control remot): ahir vaig construir un comandament senzill amb un botó per al meu Olympus E510. La majoria de càmeres tenen un botó de disparador (el que premeu per fer una foto) que té dos modes. Si es prem el botó suaument, la càmera enfocarà automàticament i mesurarà la llum