no message
This commit is contained in:
111
Belevo_Pv_Visu_1/module.php
Normal file
111
Belevo_Pv_Visu_1/module.php
Normal file
@@ -0,0 +1,111 @@
|
||||
<?php
|
||||
|
||||
class Belevo_Pv_Visu_1 extends IPSModule
|
||||
{
|
||||
public function Create()
|
||||
{
|
||||
parent::Create();
|
||||
// Properties für die vier Zähler-Variablen
|
||||
$this->RegisterPropertyInteger('VarProduction', 0);
|
||||
$this->RegisterPropertyInteger('VarConsumption', 0);
|
||||
$this->RegisterPropertyInteger('VarFeedIn', 0);
|
||||
$this->RegisterPropertyInteger('VarGrid', 0);
|
||||
// HTML-SDK aktivieren
|
||||
$this->SetVisualizationType(3);
|
||||
}
|
||||
|
||||
/**
|
||||
* Wird aufgerufen, wenn IPS das statische form.json nicht findet
|
||||
* (hier leer, denn wir nutzen form.json im Root)
|
||||
*/
|
||||
// public function GetConfigurationForm(): string
|
||||
// {
|
||||
// return '';
|
||||
// }
|
||||
|
||||
/**
|
||||
* Liefert das HTML-Template für die WebFront-Tile
|
||||
*/
|
||||
public function GetVisualizationTile(int $InstanceID): string
|
||||
{
|
||||
$file = __DIR__ . '/module.html';
|
||||
if (!file_exists($file)) {
|
||||
$this->LogMessage("module.html nicht gefunden in $file", KL_ERROR);
|
||||
return '';
|
||||
}
|
||||
return $this->Translate(file_get_contents($file));
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback aus dem HTML: Daten neu berechnen und senden
|
||||
*/
|
||||
public function RequestAction(string $Ident, $Value): void
|
||||
{
|
||||
if ($Ident === 'update') {
|
||||
$this->UpdateData();
|
||||
} else {
|
||||
throw new Exception("Unknown Ident");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Tägliche Summen holen, Quoten berechnen und ans Frontend senden
|
||||
*/
|
||||
protected function UpdateData(): void
|
||||
{
|
||||
$start = strtotime('today 00:00');
|
||||
$end = time();
|
||||
|
||||
$prodID = $this->ReadPropertyInteger('VarProduction');
|
||||
$consID = $this->ReadPropertyInteger('VarConsumption');
|
||||
$feedID = $this->ReadPropertyInteger('VarFeedIn');
|
||||
$gridID = $this->ReadPropertyInteger('VarGrid');
|
||||
|
||||
$prod = $this->GetDailyTotal($prodID, $start, $end);
|
||||
$cons = $this->GetDailyTotal($consID, $start, $end);
|
||||
$feed = $this->GetDailyTotal($feedID, $start, $end);
|
||||
$grid = $this->GetDailyTotal($gridID, $start, $end);
|
||||
|
||||
// Quoten in Prozent
|
||||
$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)
|
||||
]
|
||||
];
|
||||
|
||||
$this->UpdateVisualizationValue($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Aggregierte Tageswerte aus dem Archiv
|
||||
*/
|
||||
private function GetDailyTotal(int $varID, int $start, int $end): float
|
||||
{
|
||||
if ($varID <= 0) {
|
||||
return 0.0;
|
||||
}
|
||||
// Erstes Archivmodul finden
|
||||
$archives = IPS_GetInstanceListByModuleID('{43192F11-5B02-4B5D-9B53-8B4DBD4769E9}');
|
||||
if (empty($archives)) {
|
||||
return 0.0;
|
||||
}
|
||||
$archiveID = $archives[0];
|
||||
$values = AC_GetAggregatedValues($archiveID, $varID, 1, $start, $end, 1);
|
||||
if (empty($values)) {
|
||||
return 0.0;
|
||||
}
|
||||
return (float)$values[0]['Avg'];
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user