Taula de continguts:
2025 Autora: John Day | [email protected]. Última modificació: 2025-01-23 14:38
Seguiu llegint si voleu poder crear els vostres propis gràfics IOT mitjançant 7 línies de codi.
Volia crear gràfics per mostrar les dades en un format gràfic a partir dels meus sensors IOT en una pàgina web. Anteriorment, per a això, havia utilitzat funcions de serveis de tercers (alguns de pagament) i gràfics de tercers per al meu sistema de bases de dades: Mysql, mitjançant un llenguatge de programació conegut com a Php. He trobat que aquests serveis de tercers són massa difícils o massa costosos de desplegar. Per tant, he escrit la meva pròpia funció Php senzilla que pren les dades com a matrius d’un fitxer de text o una taula de base de dades (potser de Mysql) i les mostra com a gràfic lineal en una pàgina web. He fet que tot el codi php estigui disponible a github: https://github.com/scanos/php-simple-chart. També he inclòs alguns dels codis aquí: el primer fitxer php - PhpSimpleChart2.php -conté el fitxer de funció de gràfic de línies; l’altre, PhpSimpleChart_ex1.php, és un fitxer d’exemple que mostra com utilitzar-lo. Us proposo que també visiteu la pàgina de github per obtenir actualitzacions de codi.
Estic implementant això al meu Raspberry Pi. Això és el que necessiteu:
1) Alguns coneixements sobre el desplegament d’un servidor web com ara Apache, una base de dades com Mysql i PHP. Col·lectivament, es coneixen com LAMP: Linux, Apache, Mysql i PHP. i hi ha una gran quantitat d’informació al web pel que fa al desplegament d’aquests en un Raspberry Pi. Per tant, no tractaré això aquí.
2) Un entorn Linux LAMP, de nou, com ara Raspberry Pi.
3) Un mitjà per carregar i crear fitxers al vostre entorn web, és a dir, les carpetes del vostre Raspberry Pi on desplegueu els fitxers php del programa.
A continuació, us mostraré com crear els vostres propis fitxers Php mitjançant els dos fitxers php als quals he al·ludit anteriorment.
Pas 1: el codi de la funció PHP: PhpSimpleChart2.php
Aquest fitxer s’anomena PhpSimpleChart2.php: l’haureu de descarregar des del dipòsit git fent clic al botó de descàrrega / clonació. Vegeu la imatge superior. Un cop fet això, transfereu els dos fitxers php al vostre servidor web mitjançant el vostre client FTP estàndard o potser heu configurat un recurs compartit de samba al vostre Raspberry Pi que fa que les vostres carpetes Pi semblin carpetes de Windows..
Realment no cal canviar el codi d’aquest fitxer principal de Php: PhpSimpleChart2.php. Aquesta és una funció de creació de gràfics de línies senzilla per a PHP. Bàsicament, es passen 2 matrius a la funció, així com altres arguments, com ara les dimensions del gràfic. La primera matriu conté els primers valors en brut, com ara la temperatura, etc. La segona matriu conté els valors de data associats. El programa intenta redimensionar automàticament el gràfic en funció de l'interval, el mínim, el màxim i els elements de la matriu. El gràfic resultant es pot tallar i enganxar als documents de MS Office com a gif, png, etc. Aquí es mostra un exemple de gif.
Un cop hàgiu carregat PhpSimpleChart2.php al vostre servidor web, podeu escriure el vostre propi script per utilitzar-lo. Això es mostra a la pàgina següent.
Pas 2: escriure el vostre propi programa basat en l'exemple de programa
He mostrat un exemple de programa, PhpSimpleChart_ex1.php, que de nou es troba al repositori de git. La primera línia del codi consisteix a trucar a l'script php que conté la funció de gràfics:
require ("PhpSimpleChart2.php");
En aquest cas, el fitxer PhpSimpleChart2.php es col·loca a la mateixa carpeta que l'script que esteu escrivint per anomenar-lo. Amb sort, sabreu que els fitxers php han de tenir les propietats de lectura / escriptura 755 correctes.
A continuació, heu de crear les fonts de dades i emplenar la matriu. A continuació es mostren les matrius d’exemple, una per a dades i una per a dates i hores associades. Viouslybviament, hi ha d’haver el mateix nombre de valors en ambdues matrius.
$ data_array = array ("12", "15", "18", "12", "11", "23", "11", "24", "15", "18", "12", " 11 "," 23 "," 11 "," 24 ");
$ date_array = array ("12è 14h", "12è 15h", "12è 16h", "12è 17h", "12è 18h", "12è 19h", "12è 20h", "12è 21h", "12è 15h", "12è 16h", "12è 17h", "12è 18h", "12è 19h", "12è 20h", "12è 21h");
Normalment, llegiu aquests valors des d’una consulta de base de dades o els carregueu des d’un fitxer de text.
A continuació, heu d’establir els paràmetres del vostre gràfic. És força senzill. Primer definiu els títols i, a continuació, fixeu l’alçada i l’amplada del gràfic.
$ chart_text = "El meu gràfic de prova juliol de 2018";
$ y_title = "Temp C Deg";
$ x_scale = 1000;
$ y_scale = 400;
A continuació, feu una trucada de funció de la següent manera.
draw_line_chart ($ data_array, $ date_array, $ chart_text, $ x_scale, $ y_scale, $ y_title);
He mostrat la sortida d’aquest programa d’exemple a la imatge adjunta. La funció de gràfics intenta escalar automàticament i evitar el desordre de l'eix y i els punts del descriptor de gràfics. Amb sort, us funciona. Això és tot el que necessites.
Pas 3: Conclusió
Espero que us sigui útil. És possible que utilitzeu un altre mètode que us funcioni, però aquí teniu algunes idees;
1) La majoria dels serveis de gràfics IOT de tercers funcionen com un servei en línia al qual es pot accedir normalment com a API.
2) Els usuaris d’IOT tenen una àmplia gamma de competències pel que fa al desplegament de la funcionalitat gràfica.
PROS de la meva solució
a) Pot funcionar fora de línia
b) Cost zero.
c) Petita petjada
CONTRES
a) No s'ha provat amb el mateix rigor que les grans cases de programari.
b) Funcionalitat limitada, és a dir, sense gràfics de barres, etc.
Aliment per al pensament!
Recomanat:
Feu parcel·les precioses a partir de dades Arduino en viu (i deseu les dades a Excel): 3 passos
Feu gràfics bonics a partir de dades Arduino en viu (i deseu les dades a Excel): a tots ens agrada jugar amb la nostra funció de loteria P … a l’IDE Arduino. Tot i que, si bé pot ser útil per a aplicacions bàsiques, les dades s’esborren com més s’afegeixen punts i no resulta especialment agradable als ulls. El traçador IDE Arduino no
Creeu els vostres propis discs de duel per utilitzar en un Battle Arena: 4 passos
Creeu els vostres propis discs de duel per utilitzar en un Battle Arena: sempre he estat mig fascinat pels discos de duel de la sèrie de dibuixos animats de Yugioh. Què guai seria convocar una criatura mitjançant un joc de cartes i fer-la ducar en una mena de camp de lluita hologràfica? Aquí vaig a repassar h
Creeu els vostres propis auriculars a partir de matèries primeres: 6 passos (amb imatges)
Creeu els vostres propis auriculars a partir de matèries primeres: aquí crearem uns auriculars personalitzats, a partir de la matèria primera versió amb disseny 3D i impressió 3D
FlowerCare i Nymea per rescatar les meves plantes: 5 passos
FlowerCare i Nymea per rescatar les meves plantes: embrutar-se les mans en connectar els sensors de cura de les plantes a la meva llar intel·ligent de codi obert existent. Una explicació detallada sobre el desenvolupament de connectors per a nymea
Creeu els vostres propis tons de trucada per a iPhone: 15 passos
Creeu els vostres propis tons de trucada per a l'iPhone: a continuació s'explica com podeu crear els vostres tons de trucada per a iPhone amb GarageBand i iTunes