Aller au contenu

couillerot

Membres confirmés
  • Compteur de contenus

    1 505
  • Inscription

  • Dernière visite

  • Jours gagnés

    69

Tout ce qui a été posté par couillerot

  1. Nouvelle MAJ - version 1.2 il désormais possible de récupérer les données de précipitations du jour soit via un capteur de pluie, soit en passant par WeatherBit. Stef
  2. Difficile de répondre... Nativement, le QA récupère la prévision de J+1 de Weatherbit et l'affiche dans "Précipitations ce jour" > "prévues : ... mm" (en guise d'information). Après je pourrais très bien récupérer les précipitations du jour J via Weatrherbit, c'est tout à fait possible mais la solution ne me paraissait peu pertinente. Après, je pourrais modifier le code pour donner le choix... pourquoi pas ? - soit les données Weatherbit : précipitations du joiur - soit les données d'un pluviomètre Stef
  3. tu peux mettre ce que tu veux, la variable se mettra à jour par la suite automatiquement Stef
  4. sorry, en effet il faut ajouter une variable "prevision" dans le tableau. Stef
  5. * version 1.1 - prise en compte de 2 cas particuliers (si J-2 > Consigne + 4 jours suivant sont à 0 mm et J+2 > Consigne + 4 jours précédent sont à 0) - affichage jour J de la prévision annoncée précédemment à titre de comparaison / information Stef
  6. c'est fait QA mis à jour le 03.06.2021 Stef
  7. je ne le conseille pas car WeatherBit fournit des données de précipitations en mm/h et non en cumul sur 24h comme le pluvio Netatmo. Stef
  8. merci CatTrack il est vrai que je n'avais pas considéré ce cas de figure Stef
  9. merci Dragoniacs je vais tâcher de l'essayer également avec le mien Stef
  10. Il ne s'agit pas à proprement parlé d'un QA sur l'arrosage automatique mais simplement du déclencheur, à l'aide d'une variable globale "Arrosage" > OUI ou NON (récupérable donc dans une scène ou un autre QA pour lancer l'arrosage). Ce QA fonctionne de la sorte : - il récupère les prévisions de précipitations J+1 et J+2 (via le site WeatherBit) - il met à jour régulièrement le cumul des précipitations du jour via un pluviomètre (type "capteur de pluie") ou soit les données de précipitations du jour via Weatherbit (indication de la source dans le QA) - il stock les données de précipitations à J-1 et J-2 - il compare la consigne de déclenchement et les précipitations passées, actuelles et prévues pour conseiller un arrosage, ou pas. si vous avez des conseils pour optimiser le code (surement) ou même des choses à améliorer (certainement), n'hésitez pas ! Installation : - Créer une variable globale globable énumérée : "Arrosage" > valeurs : "OUI" / "NON" - Dans le tableau des variables : renseignez la key_id WeatherBit (en s'inscrivant gratuitement sur weatherbit.io) et - indiquez l'id de votre pluviomètre (précipitations 24h) > "id_pluviometre" ou l'id de n'importe quel autre module existant pour obtenir les données de Weatherbit. function QuickApp:onInit() self:updateProperty("deviceIcon", 1044) -- mettre ici l'id de votre icon self:loop() end function QuickApp:loop() lat = api.get("/settings/location").latitude lati = tostring(string.format("%.2f", lat)) lon = api.get("/settings/location").longitude long = tostring(string.format("%.2f", lon)) key_id = self:getVariable("key_id") local http = net.HTTPClient() http:request("https://api.weatherbit.io/v2.0/forecast/daily?lat="..lati.."&lon="..long.."&days=5&lang=fr&key="..key_id, { options = { method = 'GET' }, success = function(response) if response.status == 200 then if response.data and response.data ~= "" then local jsonTable = json.decode(response.data) precipday1 = jsonTable.data[2].precip precipday2 = jsonTable.data[3].precip precipday0 = jsonTable.data[1].precip id_pluie = self:getVariable("id_pluviometre") precip1 = self:getVariable("precip_jour_1") precip2 = self:getVariable("precip_jour_2") Consigne_mm, _ = self:getVariable("Consigne") Consigne_mm = tonumber(Consigne_mm) if tostring(id_pluie) > tostring("0") and fibaro.getType(tonumber(id_pluie)) == tostring("com.fibaro.rainSensor") then pluie = fibaro.getValue(tonumber(id_pluie), "value") source = fibaro.getName(tonumber(id_pluie)) else pluie = precipday0 source = tostring("WeatherBit") end name = fibaro.getName(tonumber(id_pluie)) arrosage = string.format("%.2f", precipday1 + precipday2 + pluie + precip1 + precip2) arrosage, _= tonumber(arrosage) arrosage_jardin = fibaro.getGlobalVariable("Arrosage") self:setVariable("pluie", pluie) ---------------------------------------- ---------- ARROSAGE OUI / NON ---------- ---------------------------------------- if tonumber(arrosage) > tonumber(Consigne_mm) then fibaro.setGlobalVariable("Arrosage", "NON") else if (tonumber(precip2) > tonumber(Consigne_mm)) and (tonumber(precipday2 + precipday1 + pluie + precip1) == 0) then fibaro.setGlobalVariable("Arrosage", "OUI") else if (tonumber(precipday2) > tonumber(Consigne_mm)) and (tonumber(precipday1 + pluie + precip1 + precip2) == 0) then fibaro.setGlobalVariable("Arrosage", "OUI") else fibaro.setGlobalVariable("Arrosage", "OUI") end end end ------------------------------------------------------------------------------ --------------------------- CONSTRUCTION DES LABELS -------------------------- ------------------------------------------------------------------------------ Arro = fibaro.getGlobalVariable("Arrosage") self:updateProperty("log", ""..arrosage.." mm") self:updateView("labeldate", "text", "INFOS ARROSAGE DU "..os.date("%d.%m.%Y\r\rdonnées mises à jour à %Hh%M")) self:updateView("labelconsigne", "text", "\nConsigne de report : + "..tostring(Consigne_mm).." mm de pluie / 5 jours") self:updateView("labelprecip", "text", "\rPrécipitations J-2 : "..string.format("%.1f", precip2).." mm\r\rPrécipitations J-1 : "..string.format("%.1f", precip1).." mm\r\rPrécipitations ce jour : " ..string.format("%.1f", pluie).." mm (source : "..source..")\r\rPrécipitations prévues J+1 : "..string.format("%.1f", precipday1).." mm\r\rPrécipitations prévues J+2 : "..string.format("%.1f", precipday2).." mm") self:updateView("labelconseil", "text", "Arrosage conseillé : "..Arro) else self:debug("Error : empty response data") end else self:debug("Error : status=" .. tostring(response.status)) end end, error = function(err) self:debug("Error : " .. err) end }) self:stockprecipitations() fibaro.setTimeout(1000 * 60 * 3, function() self:loop() end) end function QuickApp:uiMoinsOnR() local Consigne_mm, _ = self:getVariable("Consigne") Consigne_mm = tonumber(Consigne_mm) - 1 self:setVariable("Consigne", tostring(Consigne_mm)) self:loop() end function QuickApp:uiPlusOnR() local Consigne_mm, _ = self:getVariable("Consigne") Consigne_mm = tonumber(Consigne_mm) + 1 self:setVariable("Consigne", tostring(Consigne_mm)) self:loop() end function QuickApp:stockprecipitations() local Heure = tonumber(os.date("%H", os.time())) local Minute = tonumber(os.date("%M", os.time())) ----------------------------------------------------------------- ---------- MISE A JOUR DES VARIABLES POUR L'HISTORIQUE ---------- ----------------------------------------------------------------- if (Heure == tonumber("23") and Minute > tonumber("45")) and (Heure == tonumber("23") and Minute < tonumber("50")) then actus = self:getVariable("precip_jour_1") self:setVariable("precip_jour_2", tostring(actus)) end if (Heure == tonumber("23") and Minute > tonumber("50")) and (Heure == tonumber("23") and Minute < tonumber("55")) then actu = self:getVariable("pluie") self:setVariable("precip_jour_1", tostring(actu)) end fibaro.setTimeout(1000 * 60 * 2, function() self:stockprecipitations() end) end version 1.2 - choix du type de source de données de précipitations (capteur de pluie ou WeatherBit) version 1.3 (20.06.2021) - correction d'un bug historique précipitations - affichage dans le log du total des précipitations sur 5 jours. Programmateur.fqa bonne installation ! Stef
  11. le pluvio netatmo aura en effet toute sa place dans le QA ! Stef
  12. couillerot

    réglage jardin

    idem, inexploitable ce panneau arrosage Stef
  13. je vais faire un QA spécial Arrosage qui servira de déclencheur pour un arrosage auto ; c'est dans les tuyaux car je vais en avoir besoin cet été par exemple : - historique des précipitations sur 2 jours (quantifiées par un pluviomètre netatmo) -> J-1 et J-2 - précipitations du jour (via pluviomètre Netatmo) -> jour J (jour arrosage : OUI ou NON) - prévisions des précipitations sur les 2 jours suivant -> J+1 et J+2 Stef NB : après tu peux très bien utilisé les QA "météo" et "prévisions Météo" pour l'arrosage auto via le passage aux variables globales (besoin de faire quelques lignes de code) Stef
  14. couillerot

    réglage jardin

    A priori, il faut : - aller dans dispositifs / autre - ajouter un appareil - dans la rubrique Climat, choisir "arroseurs" - ... Stef
  15. v1.2 - Récupération auto des coordonnées de latitude et longitude de votre localité. - Vérification que les id des modules de température et/ou Humidité appartiennent bien aux types appropriés ; si ce n'est pas le cas ce seront les données WeatherBit qui seront remontées. Stef
  16. couillerot

    questions de newbie !

    c'est exactement ce que je cherchais ! merci encore pour ton aide précieuse Stef
  17. v1.1 mise à jour effectuée - pour la température et l'humidité, ce sont soient les données de Weatherbit soient les valeurs de vos propres modules. - changement de l'icon selon les conditions météo. - indication de la source de la temp et de l'humidité ("nom de la pièce" ou WeatherBit) Stef -> peut être encore amélioré si capteur de pluie présent.
  18. couillerot

    questions de newbie !

    existe t-il un moyen (surement d'ailleurs) pour récupérer une série de variable ? pour expliquer grossièrement mon propos : for i = 1, 11 do variable[i] = tonumber(self:getVariable("variable"[i])) end Stef
  19. une mise à jour prochaine permettra le changement de l'icon selon les conditions météo ainsi que le choix de la source de la température et d'humidité (module perso par exemple / idem que Weather Provider sur HC2). Pour la vitesse du vent, je n'ai pas d'anémomètre donc je ne pourrais pas tester... Stef
  20. Ce QA récupère les données météo issues du site WeatherBit.io Du fait que ce QA est du type weather provider, vous pouvez le substituer à la source météo par défaut de la box : YR Weather (panneau General / Principal / Capteurs Principaux / source de la météo) La mise à jour des données se fait toutes les 5 minutes. Au niveau de la température et de l'humidité, vous pouvez dorénavant soit récupérer les données de WeatherBit, soit issues de vos propres modules. Dans le cas ou vous souhaitez obtenir les valeurs (température ou/et humidité) via vos propres modules, il suffit de renseigner dans le tableau des variables l'id de votre (vos) module(s) de température et/ou humidité ("temp_id" / "humidity_id"). Si vous renseignez la valeur "0" ce seront les données de WeatherBit qui seront récoltées. Installation Il vous faut d’abord obtenir une « clé » (key) que vous obtiendrez en vous inscrivant gratuitement sur le site Weatherbit.io Renseignez alors le key_id dans le panneau des variables. Pour l’installation des icons, il suffit de suivre l’ordre pré établi (de id_icon1 à id_icon11) selon la représentation ci-dessous : Pour récupérer l’id d’un icon : après avoir téléversé l’icon, vous faites un clic droit dessus et sélectionner « Ouvrir l’image dans un nouvel onglet ». Dans l’onglet, il devrait s’afficher une phrase du style : « User(id_icon).png Bien noter pour chaque icon son id correspondant pour pouvoir le renseigner par la suite dans le tableau des variables… ----------------------------------------------------------------------------------- ----------------------------------------------------------------------------------- -------------------- QA WEATHERBIT / com.fibaro.weather --------------------------- --------------- Stephane Couillerot 2021 pour domotique-fibaro.fr ----------------- ----------------------------------------------------------------------------------- ----------------------------------------------------------------------------------- ------- indiquez dans le panneau des variables votre latitude / longitude --------- -----------et votre key id qui vous est attribuéz en vous inscrivant -------------- ---------------------gratuitement sur le site WeatherBit.io ----------------------- ----------------------------------------------------------------------------------- ----------------------------------------------------------------------------------- ------ function QuickApp:onInit() __TAG = "QA_"..plugin.mainDeviceId.."INFOS METEO WEATHERBIT" self:loop() end -- function QuickApp:loop() lat = api.get("/settings/location").latitude lati = tostring(lat) lon = api.get("/settings/location").longitude long = tostring(lon) key_id = self:getVariable("key_id") Var_Heure = os.date("%d.%m.%Y à %H:%M") lev = api.get("/settings/info").sunriseHour lever = string.gsub(lev, ":", "h") couch = api.get("/settings/info").sunsetHour coucher = string.gsub(couch, ":", "h") local http = net.HTTPClient() http:request("https://api.weatherbit.io/v2.0/current?lat="..lati.."&lon="..long.."&lang=fr&key="..key_id, { options = { method = 'GET' }, success = function(response) if response.status == 200 then if response.data and response.data ~= "" then local jsonTable = json.decode(response.data) gfx = jsonTable.data[1].weather.code aujourdhui = tostring(os.date("%w", os.time())) dat = jsonTable.data[1].ob_time codeweather = jsonTable.data[1].weather.code jour = string.sub(dat, 9, 10) mois = string.sub(dat, 6, 7) city = jsonTable.data[1].city_name citycode = jsonTable.data[1].country_code codeicon = tonumber(gfx) ----------------------------------------------------------------------------- -------------------- MISE A JOUR ICON COM.FIBARO.WEATHER -------------------- ----------------------------------------------------------------------------- if codeweather >= tonumber("300") and codeweather <= tonumber("522") then condition = "rain" end if codeweather >= tonumber("800") and codeweather <= tonumber("801") then condition = "clear" end if codeweather == tonumber("900") then condition = "unknown" end if codeweather >= tonumber("600") and codeweather <= tonumber("623") then condition = "snow" end if codeweather >= tonumber("200") and codeweather <= tonumber("233") then condition = "storm" end if codeweather >= tonumber("802") and codeweather < tonumber("803") then condition = "cloudy" end if codeweather >= tonumber("803") and codeweather <= tonumber("804") then condition = "Partly cloudy" end if codeweather >= tonumber("700") and codeweather <= tonumber("751") then condition = "fog" end ----------------------------------------------------------------------------- ---------------------------- MISE A JOUR ICON QA ---------------------------- ----------------------------------------------------------------------------- id_icon1 = tonumber(self:getVariable("id_icon1")) id_icon2 = tonumber(self:getVariable("id_icon2")) id_icon3 = tonumber(self:getVariable("id_icon3")) id_icon4 = tonumber(self:getVariable("id_icon4")) id_icon5 = tonumber(self:getVariable("id_icon5")) id_icon6 = tonumber(self:getVariable("id_icon6")) id_icon7 = tonumber(self:getVariable("id_icon7")) id_icon8 = tonumber(self:getVariable("id_icon8")) id_icon9 = tonumber(self:getVariable("id_icon9")) id_icon10 = tonumber(self:getVariable("id_icon10")) id_icon11 = tonumber(self:getVariable("id_icon11")) if codeicon == tonumber("610") then self:updateProperty("deviceIcon", id_icon1) end if codeicon >= tonumber("803") and codeicon <= tonumber("804") then self:updateProperty("deviceIcon", id_icon2) end if codeicon >= tonumber("700") and codeicon <= tonumber("751") then self:updateProperty("deviceIcon", id_icon3) end if codeicon >= tonumber("500") and codeicon <= tonumber("522") then self:updateProperty("deviceIcon", id_icon4) end if codeicon >= tonumber("601") and codeicon <= tonumber("623") then self:updateProperty("deviceIcon", id_icon5) end if codeicon == tonumber("600") then self:updateProperty("deviceIcon", id_icon6) end if codeicon == tonumber("800") then self:updateProperty("deviceIcon", id_icon7) end if codeicon >= tonumber("801") and codeicon <= tonumber("802") then self:updateProperty("deviceIcon", id_icon8) end if codeicon >= tonumber("300") and codeicon <= tonumber("302") then self:updateProperty("deviceIcon", id_icon9) end if codeicon >= tonumber("230") and codeicon <= tonumber("233") then self:updateProperty("deviceIcon", id_icon10) end if codeicon >= tonumber("200") and codeicon <= tonumber("202") then self:updateProperty("deviceIcon", id_icon11) end ------------------------------------------------------------------------------ -------------------------- CONSTRUCTION DES TABLES --------------------------- ------------------------------------------------------------------------------ week = {["0"] = "DIMANCHE", ["1"] = "LUNDI", ["2"] = "MARDI", ["3"] = "MERCREDI", ["4"] = "JEUDI", ["5"] = "VENDREDI", ["6"] = "SAMEDI"} month = {["01"] = "JANVIER", ["02"] = "FEVRIER", ["03"] = "MARS", ["04"] = "AVRIL", ["05"] = "MAI", ["06"] = "JUIN", ["07"] = "JUILLET", ["08"] = "AOUT", ["09"] = "SEPTEMBRE", ["10"] = "OCTOBRE", ["11"] = "NOVEMBRE", ["12"] = "DECEMBRE"} ------------------------------------------ ----- RECUPERATION DES DONNEES METEO ----- ------------------------------------------ ---- Récupération des 2 varaibles température / Humidity ---- tempid = self:getVariable("temp_id") humid = self:getVariable("humidity_id") fibartemp = fibaro.getType(tonumber(tempid)) fibarhumid = fibaro.getType(tonumber(humid)) ---- Température ---- if tostring(tempid) > tostring("0") and fibartemp == tostring("com.fibaro.temperatureSensor") then temp = fibaro.getValue(tonumber(tempid), "value") roomnametemp = fibaro.getRoomNameByDeviceID(tonumber(tempid)) else temp = jsonTable.data[1].app_temp roomnametemp = tostring("WeatherBit") end ---- Humidité ---- if tostring(humid) > tostring("0") and fibarhumid == tostring("com.fibaro.humiditySensor") then humidite = fibaro.getValue(tonumber(humid), "value") roomnamehum = fibaro.getRoomNameByDeviceID(tonumber(humid)) else humidite = jsonTable.data[1].rh roomnamehum = tostring("WeatherBit") end ---- Vent ---- win = jsonTable.data[1].wind_spd winder = tonumber(win) * 3.6 windspeed = string.format("%.1f", tostring(winder)) ---- Divers ---- descript = jsonTable.data[1].weather.description snow = jsonTable.data[1].snow winddir = jsonTable.data[1].wind_cdir uv = jsonTable.data[1].uv pression = jsonTable.data[1].pres rosee = jsonTable.data[1].dewpt ---- Mise à jour dse variables pluie pour historique ---- pluie = fibaro.getValue(911, "value") precip = fibaro.getValue(909, "value") self:setVariable("pluie", pluie) local conditionCodes = { unknown = 3200, clear = 32, rain = 40, snow = 38, storm = 666, cloudy = 30, fog = 20, } local conditionCode = conditionCodes[condition] if conditionCode then self:updateProperty("ConditionCode", conditionCode) self:updateProperty("WeatherCondition", condition) self:updateProperty("Temperature", tonumber(temp)) self:updateProperty("Wind", tonumber(windspeed)) self:updateProperty("Humidity", tonumber(humidite)) end self:debug(aujourdhui) ------------------------------------------------------------------------------ --------------------------- CONSTRUCTION DES LABELS -------------------------- ------------------------------------------------------------------------------ self:updateProperty("log", ""..temp.. " °c") self:updateView("labelCity", "text", "INFOS METEO DU "..week[tostring(aujourdhui)].." "..jour.. " "..month[mois].." "..os.date("%Y")) self:updateView("label1", "text", descript.."\r\rTempérature : "..temp.. "°c\rHumidité : "..string.format("%.0f", humidite).." %\rPluie : "..string.format("%.1f", precip).." mm/h\rNeige : "..string.format("%.1f", snow).." mm/h\rCumul pluie 24h : "..string.format("%.1f", pluie).."mm\rVent : "..windspeed.." km/h ("..winddir..")\rIndex UV (0-11+) : "..string.format("%.0f", uv).."\rPression atmosphérique : "..string.format("%.0f", pression).." mb\rPoint de rosée : "..rosee.." °c\rLever du soleil : "..lever.."\rCoucher du soleil : "..coucher.."\r\rSource Température : "..roomnametemp.. "\rSource Humidité : "..roomnamehum) self:updateView("labelMAJ", "text", "Station de "..city.." ("..citycode..") | MAJ le "..Var_Heure) else self:debug("Error : empty response data") end else self:debug("Error : status=" .. tostring(response.status)) end end, error = function(err) self:debug("Error : " .. err) end }) self:debug("Boucle METEO") fibaro.setTimeout(1000 * 60 * 30, function() -- MAJ 30 minutes self:loop() end) end Version 1.1 - pour la température et l'humidité, ce sont soient les données de Weatherbit soient les valeurs de vos propres modules. - changement de l'icon selon les conditions météo. - indication de la source de la temp et de l'humidité ("nom de la pièce" ou WeatherBit) Version 1.2 - QA Reconnu comme weather provider - récupération auto des coordonnées latitude et longitude - Vérification que les id des modules de température et/ou Humidité appartiennent aux types appropriés WeatherBit.fqa Bonne installation ! Stef
  21. Ce QA récupère les données de prévisions météo sur 5 jours du site WeatherBit. Mise a jour du QA toutes les 2 heures. Installation Il vous faut d’abord obtenir une « clé » (key) que vous obtiendrez en vous inscrivant gratuitement sur le site Weatherbit.io renseignez alors la variables key_id dans le panneau. Pour l’installation des icons, il suffit de suivre l’ordre pré établi (de id_icon1 à id_icon11) selon la représentation ci-dessous : Pour récupérer l’id d’un icon : après avoir téléversé l’icon, vous faites un clic droit dessus et sélectionner « Ouvrir l’image dans un nouvel onglet ». Dans l’onglet, il devrait s’afficher une phrase du style : « User(id_icon).png Bien noter pour chaque icon son id correspondant pour pouvoir le renseigner par la suite dans le tableau des variables… Bonne installation ! Version 1.2 - Récupération auto des coordonnées de latitude et longitude de la box pour déterminer votre localité. Previsions_Meteo.fqa
  22. couillerot

    questions de newbie !

    il me semble (comme la HC2) que c'est sur l'appli mobile que les balises HTML ne fonctionnent pas. j'ai laissé tomber d'inclure le QA prévisions météo type Weather : pas assez pertinent car le QA ne se met à jour que toutes les 24h... (auparavant WeatherBit permettait une maj toute les 3 heures sur 5 jours). je peaufine le QA pour qu'il soit accessible et paramétrable facilement au plus grand nombre. Stef
×
×
  • Créer...