Cuprins:
2025 Autor: John Day | [email protected]. Modificat ultima dată: 2025-01-13 06:58
Acesta este un manual pe care a trebuit să-l scriu pentru școală. Nu este complet și nu sunt sigur dacă îl puteți folosi. Cunoștințele mele despre API sunt minimul. Am vrut să realizăm o oglindă interactivă cu lumini pe spate care să reacționeze la vreme, lumină din exterior etc.
M-am uitat la modul în care aș putea programa o lampă Philips Hue cu un Arduino. În acest sens, vă explic toți pașii și cât de departe am ajuns. Nu am reușit să programez Hue cu Arduino, dar cred că este un început bun.
Am avut nevoie de acest lucru: o lampă Arduino a nuanță un cont de dezvoltator Philips Hue
Surse: https://www.developers.meethue.com/documentation/g…https://github.com/bsalinas/ArduinoHuehttps://arduino-esp8266.readthedocs.io/en/latest/e…https:// www.makeuseof.com/tag/control-philips-hue-…
Pasul 1: Începeți
Înainte de a putea accesa documentația API, va trebui să vă înregistrați ca dezvoltator. Este gratuit, dar trebuie să acceptați termenii și condițiile. Puteți face unul aici>
Pasul 2: aplicația Hue
Descărcați aplicația oficială Philips Hue. Conectați-vă telefonul la rețeaua pe care doriți să o conecteze Hue Bridge.
Pasul 3: Conectați Podul
Conectați-vă bridge-ul la rețeaua dvs. și funcționează corect. Testați dacă aplicația smartphone poate controla luminile din aceeași rețea. Trebuie să fie pe aceeași rețea Wi-Fi.
Pasul 4: adresa IP
Apoi, trebuie să descoperiți adresa IP a podului din rețeaua dvs. Apăsați linkul pentru a vă conecta la podul din aplicație și încercați să controlați luminile.
Pasul 5:
Dacă totul funcționează, accesați meniul de setări din aplicație. Deci mergeți la „Podul meu”, accesați „Setări rețea”. Opriți comutatorul DHCP și vedeți adresa IP a podului. Rețineți adresa IP, apoi reporniți DHCP.
Pasul 6: Depanare Hue
Când ați notat acest lucru, trebuie să depanați Hue. Aveți nevoie de adresa IP pentru acest pas. Trebuie să vizitați următorul site.
/debug/clip.html
Interfața va arăta astfel în imagine. Aceasta este baza întregului trafic web și a interfeței RESTful Hue.
Am primit aceste informații despre interfața Restful a site-ului Philips Hue.
URL: aceasta este de fapt adresa locală a unei anumite resurse (lucru) din sistemul de nuanțe. Ar putea fi lumină, un grup de lumini sau multe alte lucruri. Acesta este obiectul pe care îl veți interacționa în cadrul acestei comenzi.
Un corp: aceasta este partea mesajului care descrie ce vrei să schimbi și cum. Aici introduceți, în format JSON, numele și valoarea resurselor pe care doriți să le modificați / adăugați.
O metodă: aici aveți de ales dintre cele 4 metode HTTP pe care apelul Hue le poate folosi.
OBȚINE: aceasta este comanda pentru a prelua toate informațiile despre resursa adresată
PUT: aceasta este comanda de modificare a unei resurse adresate
POST: aceasta este comanda pentru a crea o nouă resursă în interiorul resursei adresate
ȘTERGERE: aceasta este comanda pentru a șterge resursa adresată Răspuns: În această zonă, veți vedea răspunsul la comanda dvs. De asemenea, în format JSON.
Pasul 7: Să începem
Acum avem nevoie de un nume de utilizator generat aleatoriu, creat de pod pentru dvs. Veți obține unul completând acest lucru.
Introduceți adresa URL:
/ api /
Puneți în CORP:
și apăsați GET
Această comandă spune practic „vă rugăm să creați o resursă nouă în / api” (unde stau numele de utilizator) cu următoarele proprietăți. La început, veți primi o eroare și asta pentru că este pasul de securitate al Philips Hue. Prin apăsarea butonului, ei dovedesc că aveți acces fizic la pod.
Pasul 8:
Acum apăsați butonul de pe pod și faceți clic din nou pe POST.
Acum veți obține un nume de utilizator creat de pod pentru dvs.
Pasul 9: Să facem ceva cu luminile
Copiați numele de utilizator și puneți-l în rândul următor.
Puneți acest lucru în adresa URL
/ api / / lights
Apăsați GET
Ar trebui să primiți un răspuns JSON cu toate luminile din sistemul dvs. și numele acestora.
Pasul 10:
Am împrumutat niște Hue Lights de la școală, cel pe care îl folosesc este cel cu id 3. Vreau informații specifice despre această lumină.
Puneți acest lucru lângă adresa URL pe care o aveați deja:
/ api / / lights / 3
Apăsați GET
Acum primiți toate informațiile despre Led 3 (dacă aveți un alt număr ca 1, veți vedea informații despre acesta).
Pasul 11: Să controlăm lumina
Vedeți în „stare” că ledul meu este „pornit”. Vrem să controlăm lumina în „stare”.
Puneți acest lucru lângă adresa URL pe care o aveați deja: https:// / api / / lights / 3 / state
Puneți următoarea linie în CORP
Apăsați PUT
Acum lumina ta se va stinge! Schimbați valoarea din corp în adevărată și lumina se va aprinde din nou.
Pasul 12:
Acum totul funcționează. Vreau să fac asta cu Arduino. M-am uitat la link-ul dat de Philips Hue pentru a schimba culoarea luminii. Dar ai nevoie de Python pentru asta, nu am lucrat niciodată cu Python, așa că am căutat altceva.
Dacă doriți să vă uitați la acest cod, am link-ul Github aici:
github.com/bsalinas/ArduinoHue
Pasul 13:
Am căutat cum aș putea obține informații de pe acest site pentru dezvoltatori pe arduino. De cele mai multe ori nu înțelegeam limba. Dar am găsit un cod pe un site de la James Bruce.
Acesta este linkul către site.
www.makeuseof.com/tag/control-philips-hue-lights-arduino-and-motion-sensor/
Pasul 14:
Mai întâi am văzut că folosea un cablu Ethernet. Am avut doar un bec Hue și Bridge un Arduino și o mică înțelegere a codului. Mi-a luat ceva timp să-i înțeleg codul, dar încă nu-l înțeleg cu adevărat.
Am adăugat mai întâi această bibliotecă pentru internet.
#include
Aceasta este pentru rețeaua dvs. (trebuie să fie la fel ca becul Hue)
const char * ssid = ""; // pune aici rețeaua WiFi SSIDconst char * password = ""; // pune aici parola rețelei WiFi
Acestea sunt ID-ul podului dvs. și numele de utilizator pe care vi l-a dat podul. (Nu știu unde reprezintă 80, dar când am făcut unele cercetări am văzut că a fost folosit pentru rețele).
// Constantele de nuanță const char hueHubIP = ""; // Hue hub IP const char hueUsername = ""; // Hue nume de utilizator const int hueHubPort = 80;
// Variabile de nuanță bool hueOn; // on / off int hueBri; // luminozitate valoare lungă nuanță; // hue value String hueCmd; // Comanda Hue
tampon lung nesemnat = 0; // tampon pentru stocarea datelor primite nesemnate lung addr;
Pasul 15:
Pentru configurarea nulă, am făcut cel mai mult pentru conexiunea la internet. În acest cod, Arduino caută dacă se poate conecta la rețea.
void setup () {Serial.begin (9600);
Serial.println ();
Serial.printf ("Conectarea la% s", ssid);
WiFi.begin (ssid, parolă);
while (WiFi.status ()! = WL_CONNECTED) {
întârziere (500);
Serial.print ("."); }
Serial.println („conectat”); }
Pasul 16:
În bucla lui James, am văzut că avea o declarație If and else. Dar asta a fost pentru cablul ethernet, așa că am încercat să las asta. De asemenea, am încercat uneori să-l reglez, dar nu știam încă cu multe date. Unele lucruri din cod le-am înțeles, în șir sunt datele care sunt date luminii Hue.
bucla nulă () {
// O serie de patru exemple de comenzi, care culoare estompează două lumini între roșu și roz. Citiți în documentația Hue API // pentru mai multe detalii despre comenzile exacte care trebuie utilizate, dar rețineți că ghilimele trebuie evitate.
String command = "{" on / ": true, \" hue / ": 50100, \" sat / ": 255, \" bri / ": 255, \" transitiontime / ":" + String (random (15, 25)) + "}"; setHue (1, comandă);
command = "{" on / ": true, \" hue / ": 65280, \" sat / ": 255, \" bri / ": 255, \" transitiontime / ":" + String (random (15, 25)) + "}"; setHue (2, comandă);
command = "{" hue / ": 65280, \" sat / ": 255, \" bri / ": 255, \" transitiontime / ":" + String (random (15, 25)) + "}"; setHue (1, comandă);
command = "{" hue / ": 50100, \" sat / ": 255, \" bri / ": 255, \" transitiontime / ":" + String (random (15, 25)) + "}"; setHue (2, comandă);
}
Pasul 17:
Următorul cod a fost un boolean, dar în Arduino trebuie să scrieți Bool. La început, am primit multe erori din cauza cuvântului client. Așa că am căutat-o și am văzut că un anumit cod folosea linia „client WifiClient;”. Așa că l-am obișnuit și a funcționat.
În declarația if vedeți adesea client.print. Dacă vă uitați în cod, veți vedea că adresa URL pe care ați introdus-o anterior este împărțită în bucăți. Acum introduceți propriul cod. A trebuit să-mi aleg a treia lumină LED.
/ * setHue () este funcția noastră principală de comandă, care trebuie să fie transmisă un număr ușor și un șir de comandă * formatat corespunzător în format JSON (practic o matrice în stil Javascript de variabile * și valori. Apoi face o solicitare simplă HTTP PUT către Podul la adresa IP specificată la început. * /
bool setHue (int lightNum, comanda String) {
Client WiFiClient;
if (client.connect (hueHubIP, hueHubPort)) {
while (client.connected ()) {
client.print ("PUT / api /"); client.print (hueUsername); client.print ("/ lights /"); client.print (lightNum); // hueLight zero based, add 1 client.println ("3 / state"); // aici am schimbat numele nuanței și stateclient.print ("Gazdă:"); client.println (hueHubIP); client.print („Lungime conținut:”); client.println (command.length ()); client.println ("Content-Type: text / plain; charset = UTF-8"); client.println (); // linie necompletată înaintea corpului client.println (comandă); // Comanda Hue
} client.stop (); întoarce-te adevărat; // comanda executată}
altfel returnează fals; // comanda a eșuat}
Pasul 18:
La al doilea Boolean, am făcut același lucru cu schimbarea unor cuvinte. L-am încărcat pentru a vedea dacă a funcționat.
/ * O funcție de ajutor în cazul în care logica dvs. depinde de starea curentă a luminii. * Aceasta setează un număr de variabile globale pe care le puteți verifica pentru a afla dacă o lumină este sau nu în prezent * și nuanța etc. Nu este necesar doar pentru a trimite comenzi * /
bool getHue (int lightNum) {
Client WiFiClient;
if (client.connect (hueHubIP, hueHubPort)) {
client.print ("GET / api /"); client.print (hueUsername); client.print ("/ lights /"); client.print (lightNum); client.println ("3 / state"); client.print ("Gazdă:"); client.println (hueHubIP); client.println ("Tipul conținutului: aplicație / json"); client.println ("păstrați-vii"); client.println ();
while (client.connected ()) {if (client.available ()) {client.findUntil ("\" on / ":", "\ 0"); hueOn = (client.readStringUntil (',') == "adevărat"); // dacă lumina este aprinsă, setați variabila la adevărat client.findUntil ("\" bri / ":", "\ 0"); hueBri = client.readStringUntil (',').toInt (); // setați variabila la valoarea de luminozitate client.findUntil ("\" nuanță / ":", "\ 0"); hueHue = client.readStringUntil (',').toInt (); // setați variabila la nuanță de valoare; // încă nu captează alte atribute ușoare}} client.stop (); întoarce-te adevărat; // capture on, bri, hue} else return false; // eroare la citire, bri, nuanță}
Pasul 19:
Cred că aș putea face o legătură cu Philips Hue. Primesc informații, dar totuși trebuie folosite.
Din păcate, acest lucru depășește ceea ce pot codifica. Dacă știți răspunsul sau dacă există erori reale care trebuie corectate, mi-ar plăcea să-l aud.:-)