Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org: 4 stappe
Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org: 4 stappe
Anonim
Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org
Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org
Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org
Teken data aan en teken 'n grafiek aanlyn met behulp van NodeMCU, MySQL, PHP en Chartjs.org

Hierdie instruksie beskryf hoe ons die Node MCU -bord kan gebruik om data van verskeie sensors te versamel, om hierdie data na 'n PHP -lêer te stuur wat die data dan byvoeg tot 'n MySQL -databasis. Die data kan dan aanlyn as 'n grafiek beskou word met behulp van chart.js.

'N Basiese kennis van PHP en MySQL is nodig vir hierdie projek, en u benodig toegang tot webhosting met hierdie opstel om u eie grafieke te kan maak en te sien. Ek neem ook aan dat u basiese kennis het van die gebruik van die Node MCU -bord en om sketse daarna op te laai. (Ek gebruik die Arduino IDE hiervoor)

Stap 1: Bou die kring

Bou die kring
Bou die kring
Bou die kring
Bou die kring
Bou die kring
Bou die kring

Aangesien die Node MCU slegs een analoog pen het, gebruik ons multiplexing om data van verskeie sensors te kan lees. ('N Aantal instruksies behandel hierdie konsep in meer besonderhede, so ek sal hier nie op ingaan nie). In hierdie voorbeeld het ek twee sensors (vir lig en temperatuur) gebruik, maar u kan dit verander na wat u wil en indien nodig meer sensors byvoeg. Ek gebruik 'n ligsensitiewe weerstand, 'n termistor, twee gelykstellende diodes, 'n weerstand van 330 ohm en 'n 10K -weerstand en 'n paar springdrade. Die aangehegte Fritzing -diagram toon hoe dit alles op die broodbord verbind is.

Stap 2: Wysig en laai die skets op na node MCU

Gebruik hierdie aangehegte.ino -lêer. U moet dit met u eie naam en wagwoord van u WiFi -netwerk wysig sodat die Node MCU met u eie netwerk kan koppel.

Onderaan hierdie skets staan die reël 'vertraging (60000);' gee 'n minuut vertraging tussen sensorlesings, maar dit kan aangepas word om aan u eie behoeftes te voldoen. Ek beveel egter aan dat u ten minste 10 sekondes laat om elke keer verbinding met die 'updater.php' -lêer te maak.

U sal ook die pad moet wysig na die plek waar u die twee.php -lêers en die twee javascript -lêers wat benodig word, sal huisves. U kan dit in die volgende stap aflaai.

Stap 3: Databasis en weblêers

Skep u MySql -databasis. Skep 'n tabel genaamd 'temp_light' (u kan dit verander, maar u moet die twee php -lêers wysig om die veranderinge wat u aanbring) weer te gee. Gee die tabel vier velde. 'N Primêre veld vir outomatiese toename. 'N Heelgetalveld genaamd' temp ', 'n heelgetalveld genaamd' lig 'en 'n veld' datum_tyd ', wat 'n tydstempel en standaardwaarde' CURRENT_TIMESTAMP 'sal wees

Laai nou die aangehegte.zip -lêer af en pak dit uit. Dit gee u twee php -lêers en 'n gids genaamd 'scripts' wat bevat. JS -lêers wat ek van chartjs.org gekry het. Die twee.js -lêers hoef nie geredigeer te word nie en die 'scripts' -lêergids moet op dieselfde plek as u twee php -lêers gehuisves word. die twee php -lêers moet albei met u eie databse naam, wagwoord en gasheer -I. P. adres.

In die index.php -lêer sien u reël 50: $ adjust_temp = ($ temp*0.0623);

Hierdie berekening is om die temperatuurmeting te omskep in so naby as wat ek grade Celsius kan kry, en ek het dit deur proef en fout bereik, en dit sal byna seker moet verander word om by u eie temperatuursensor te pas.

Beheer nou beide php -lêers en die gids 'scripts' wat die twee.js -lêers bevat, saam in dieselfde gids. Blaai na die gids en u moet u eie grafiek sien met die data wat vanaf u Node MCU -bord gestuur is.

Stap 4: Die voltooide resultaat

Ek het hierdie projek oorspronklik ongeveer twee jaar gelede gemaak, maar ek kon nog nooit 'n instruksie daarvoor skryf nie. U kan die grafiek wat deur my toets geskep is, hier sien:

Die groot piek in die grafiek is waar die son deur die venster na die twee sensors skyn en die stadige afname weer was toe die son stadig uit die oog val.