diff --git a/PV_Visu/module.html b/PV_Visu/module.html index 3b5090a..3e5c039 100644 --- a/PV_Visu/module.html +++ b/PV_Visu/module.html @@ -14,7 +14,6 @@ - Hallo
@@ -38,14 +37,14 @@ } function handleMessage(msg) { try { - var data = (typeof msg === 'string') ? JSON.parse(msg) : msg; - Apply(data); - } catch(e) { - console.error('PV_Visu handleMessage error:', e, msg); + var d = (typeof msg === 'string') ? JSON.parse(msg) : msg; + Apply(d); + } catch (e) { + console.error('PV_Visu handleMessage error', e, msg); } } - // Bind to HTML-SDK + // Register HTML-SDK handler if (typeof registerMessageHandler === 'function') { registerMessageHandler(handleMessage); } - + \ No newline at end of file diff --git a/PV_Visu/module.php b/PV_Visu/module.php index 768fcae..30682c3 100644 --- a/PV_Visu/module.php +++ b/PV_Visu/module.php @@ -2,7 +2,6 @@ declare(strict_types=1); - class PV_Visu extends IPSModule { public function Create() @@ -14,13 +13,36 @@ class PV_Visu extends IPSModule $this->RegisterPropertyInteger('VarFeedIn', 0); $this->RegisterPropertyInteger('VarGrid', 0); // HTML-SDK Tile aktivieren - $this->SetVisualizationType(1); + $this->SetVisualizationType(3); } - public function ApplyChanges(): void + + + public function ApplyChanges(): void { parent::ApplyChanges(); - $this->GetVisualizationTile(); + // Auf Änderungen der Zähler-Variablen reagieren + foreach (['VarProduction', 'VarConsumption', 'VarFeedIn', 'VarGrid'] as $prop) { + $vid = $this->ReadPropertyInteger($prop); + if ($vid > 0) { + // Register event for variable update + $this->RegisterMessage($vid, VM_UPDATE); + } + } + } + + public function MessageSink(int $TimeStamp, int $SenderID, int $Message, $Data): void + { + if ($Message === VM_UPDATE) { + // bei jeder Aktualisierung einer Zählervariable neu senden + $this->UpdateData(); + } + }(int $TimeStamp, int $SenderID, int $Message, $Data): void + { + if ($Message === VM_UPDATE) { + // bei jeder Aktualisierung einer Zählervariable neu senden + $this->UpdateData(); + } } /** @@ -28,38 +50,9 @@ class PV_Visu extends IPSModule */ public function GetVisualizationTile(): string { - $start = strtotime('today 00:00'); - $end = time(); - - $prod = $this->GetDailyTotal($this->ReadPropertyInteger('VarProduction'), $start, $end); - $cons = $this->GetDailyTotal($this->ReadPropertyInteger('VarConsumption'), $start, $end); - $feed = $this->GetDailyTotal($this->ReadPropertyInteger('VarFeedIn'), $start, $end); - $grid = $this->GetDailyTotal($this->ReadPropertyInteger('VarGrid'), $start, $end); - - // Prozent-Quoten - $prodCons = $prod > 0 ? ($cons / $prod) * 100 : 0; - $prodFeed = $prod > 0 ? ($feed / $prod) * 100 : 0; - $consPV = $cons > 0 ? min($prod, $cons) / $cons * 100 : 0; - $consGrid = $cons > 0 ? ($grid / $cons) * 100 : 0; - - $data = [ - 'prodCons' => round($prodCons, 1), - 'prodFeed' => round($prodFeed, 1), - 'consPV' => round($consPV, 1), - 'consGrid' => round($consGrid, 1), - 'value' => [ - 'prod' => round($prod, 2), - 'cons' => round($cons, 2), - 'feed' => round($feed, 2), - 'grid' => round($grid, 2), - ], - ]; - - // Daten als JSON-String übergeben - $json = json_encode($data); - $this->UpdateVisualizationValue($json); - - // HTML-Template laden und zurückgeben + // Initial senden + $this->UpdateData(); + // HTML laden $htmlPath = __DIR__ . '/module.html'; if (!file_exists($htmlPath)) { $this->LogMessage("module.html nicht gefunden in $htmlPath", KL_ERROR); @@ -69,9 +62,9 @@ class PV_Visu extends IPSModule } /** - * Callback vom HTML: sendet frische Daten + * Callback vom HTML: frische Daten senden */ - public function RequestAction($Ident, $Value): void + public function RequestAction(string $Ident, $Value): void { if ($Ident === 'update') { $this->UpdateData(); @@ -81,21 +74,21 @@ class PV_Visu extends IPSModule } /** - * Aktualisiert Daten und sendet an Tile + * Berechnet Tagesdaten und schickt sie an die Visualisierung */ public function UpdateData(): void { $start = strtotime('today 00:00'); $end = time(); - $prod = $this->GetDailyTotal($this->ReadPropertyInteger('VarProduction'), $start, $end); - $cons = $this->GetDailyTotal($this->ReadPropertyInteger('VarConsumption'), $start, $end); - $feed = $this->GetDailyTotal($this->ReadPropertyInteger('VarFeedIn'), $start, $end); - $grid = $this->GetDailyTotal($this->ReadPropertyInteger('VarGrid'), $start, $end); + $prod = $this->GetDailyTotal($this->ReadPropertyInteger('VarProduction'), $start, $end); + $cons = $this->GetDailyTotal($this->ReadPropertyInteger('VarConsumption'), $start, $end); + $feed = $this->GetDailyTotal($this->ReadPropertyInteger('VarFeedIn'), $start, $end); + $grid = $this->GetDailyTotal($this->ReadPropertyInteger('VarGrid'), $start, $end); $prodCons = $prod > 0 ? ($cons / $prod) * 100 : 0; $prodFeed = $prod > 0 ? ($feed / $prod) * 100 : 0; - $consPV = $cons > 0 ? min($prod, $cons) / $cons * 100 : 0; + $consPV = $cons > 0 ? (min($prod, $cons) / $cons) * 100 : 0; $consGrid = $cons > 0 ? ($grid / $cons) * 100 : 0; $data = [ @@ -111,12 +104,12 @@ class PV_Visu extends IPSModule ], ]; - $json = json_encode($data); - $this->UpdateVisualizationValue($json); + // Als JSON-String senden + $this->UpdateVisualizationValue(json_encode($data)); } /** - * Holt Tages-Aggregat aus dem IPS-Archiv + * Holt aggregierte Tageswerte (Summe) aus dem Archiv */ private function GetDailyTotal(int $varID, int $start, int $end): float { @@ -128,6 +121,11 @@ class PV_Visu extends IPSModule return 0.0; } $values = AC_GetAggregatedValues($archives[0], $varID, 1, $start, $end, 1); - return empty($values) ? 0.0 : (float) $values[0]['Avg']; + if (empty($values)) { + return 0.0; + } + // Für Zähler den Summenwert nutzen + return (float)$values[0]['Sum']; } -} \ No newline at end of file +} +?> \ No newline at end of file