Hi!
Eine deutsche Anleitung dafuer habe ich gerade nicht - nur die
englische.
Deepl macht jedoch einen recht gut verstaendlichen Text daraus:
Oliver
Erstellung von Bannern und Stickern (ab v0.10)
Als zusätzlicher Weiterleitungstyp (FWD_TYPE) wurde in v0.10 der Typ BANNER eingeführt. Mit diesem Typ können Bilder (PNG/JPG/GIF) erstellt werden, in die Wetterdaten (Werte) aus dem FOSHKplugin eingebettet werden können:
- banner-green.png (83.88 KiB) 489 mal betrachtet
Die erzeugten Bilder können im Dateisystem gespeichert oder per FTP oder http/POST an einen entfernten Server gesendet werden. Dort können sie von überall aus abgerufen, in eigene Webseiten integriert oder als Fußzeile in beliebigen Forenbeiträgen verwendet werden (sofern erlaubt).
Wenn man also seine Wetterdaten auf der eigenen Homepage anzeigen möchte, muss man nicht den komplizierten Weg gehen, die Daten an den Webserver zu schicken und sie von einem serverspezifischen Einleseskript verarbeiten zu lassen.
Man definiert einfach ein Bild auf der Homepage, das ohne weitere Programmierkenntnisse automatisch ausgetauscht wird - und zwar mit den jeweils aktuellen Daten der Wetterstation. Für die verschiedenen CMS sind keine weiteren Anpassungen notwendig; Joomla, Wordpress, Typo3 etc. zeigen einfach ein Bild an, das sich selbst aktualisiert.
Diese Bilder können ein bestehendes Bild, aber auch eine definierbare Farbe als Hintergrund haben. Diese Farbe kann auch transparent sein, so dass nur der Text des Bildes sichtbar ist und der ursprüngliche Hintergrund erhalten bleibt. Mit der Option rounded_corners = True können Sie in den Bildformaten PNG und GIF abgerundete Ecken erzeugen - unabhängig davon, ob der Hintergrund ein Bild oder eine Farbe ist. Der Radius der Abrundung kann mit der entsprechenden Zahl anstelle von True angegeben werden. Im Standard (True) wird der Wert 10 genommen, was einem kleinen Radius und damit einer kleinen Abrundung entspricht.
Es können beliebige Bildobjekte (z.B. Logos) innerhalb des Banners positioniert werden.
Diese Logos können auch gezielt in Abhängigkeit von bestimmten Werten ausgegeben werden. Damit eröffnen sich interessante Möglichkeiten für "dynamische" Banner.
Ein Beispiel:
Es gibt den FOSHKplugin-internen Schlüssel wnowlvl, der die aktuelle Wetterlage anhand des Luftdrucks ausgibt. Über die Qualität dieser Aussage brauchen wir nicht zu diskutieren - aber sie liefert hier ein schönes visuelles Beispiel.
Laut Definition werden - je nach Wetterlage - die folgenden Codes ausgegeben:
wnowlvl = 0 –> stormy, rain
wnowlvl = 1 –> rainy
wnowlvl = 2 –> changeable
wnowlvl = 3 –> sunny
wnowlvl = 4 –> dry, thunderstorm
In der Logokonfiguration der Bannerdefinition können Sie nun festlegen, dass für jeden einzelnen Status ein anderes Logo verwendet wird:
Code: Alles auswählen
logo_1 = 10,100,storm.png,@wnowlvl = 0
logo_2 = 10,100,rain.png,@wnowlvl = 1
logo_3 = 10,100,change.png,@wnowlvl = 2
logo_4 = 10,100,sun.png,@wnowlvl = 3
logo_5 = 10,100,tstorm.png,@wnowlvl = 4
Es werden also je nach Daten unterschiedliche Bilder (definiert in der 3. Spalte) angezeigt!
In der 4. Spalte der Logozeilen wird festgelegt, ob das Logo im Banner angezeigt wird. Fehlt diese Spalte oder ist sie leer, wird das Logo in den Banner integriert.
Ansonsten prüft das FOSHKplugin den Inhalt der 4. Spalte auf Gültigkeit. Die abzufragenden Felder sind mit einem "@" gekennzeichnet. Sie können auch ein Feld mit einem anderen Feld vergleichen, zum Beispiel @temp1f ⇐ @tempf.
Zulässige Operatoren sind: [<,⇐,==,>,>=,<>,!=]
Nur wenn die Prüfung erfolgreich ist, wird das Logo in das Banner aufgenommen.
Diese Abfragen können verwendet werden, um ein bestimmtes Logo in den Sonderfällen eines leeren Wertes oder eines nicht existierenden Schlüssels anzuzeigen:
Code: Alles auswählen
logo_6 = 10,100,emptyvalue.png,@wnowlvl = # empty value
logo_7 = 10,100,dontexist.png,@wnowlvl = null # key does not exist
Mit den Optionen pre_count und dec_count kann für jeden Zeilentyp die Länge des (dynamischen) Ausgabestrings (pre_count) und die Anzahl der Nachkommastellen (inkl. Rundung) festgelegt werden. Dies führt zu einer besseren Positionierung der Ausgabewerte, falls dies erforderlich sein sollte.
Alle FOSHKplugin-internen Werte können zur Einbindung in das Bild verwendet werden - so können Werte mit metrischen oder imperialen Einheiten (auch gleichzeitig) ausgegeben werden.
Der Zugriff auf FOSHKplugin-interne Statuswerte sowie Min/Max-Werte ist ebenfalls möglich. Zusätzlich zu den unter http://ipaddress:port/FOSHKplugin/keyhelp angezeigten Schlüsseln können auch folgende Schlüssel für Banner & Sticker verarbeitet werden:
prgname –> Programmname (FOSHKplugin)
prgver –> Programmversion (v0.10)
winddir_text –> Windrichtung als String - etwa "N", "NNE", "NE", "ENE", "E", "ESE", "SE", "SSE", "S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW" oder die jeweiligen deutschen Bezeichnungen
pchange1in –> Luftdruckänderung der letzten Stunde in inHg (pchange1 zeigt den Wert in hPa)
pchange3in –> Luftdruckänderung der letzten 3 Stunden in inHg (pchange3 zeigt den Wert in hPa)
lightningmi –> Entfernung in Meilen des letzten Blitzes (instead of km)
Sonderzeichen wie z. B. deutsche Umlaute können verwendet werden - sofern die verwendete Schriftart sie unterstützt. Ein Sonderzeichen ist jedoch das Komma ",". Da dieses innerhalb der Konfiguration zur Trennung der einzelnen Felder verwendet wird, muss es als String mit einem Backslash escaped werden: "," wird so zu "\,".
Beispiele hierfür finden Sie auf der eigens dafür eingerichteten Banner-Demoseite:
https://foshkplugin.phantasoft.de/banner.
Die Einbettung der Werte basiert auf einer Positionierung von Zeilen pro y-Koordinate, die einzelne Spalten enthalten, die pro x-Koordinate positioniert werden können. Die Anzahl der Zeilen (pro Typ) und Spalten ist auf 100 begrenzt.
Für jedes Bild können 10 (!) verschiedene Schriftarten mit unterschiedlicher Schriftart, Größe und Farbe verwendet werden: Header, Line, Footer, Special und Custom, Custom1..5. Die Namen sind nur ein Unterscheidungsmerkmal, der Inhalt wird durch die Definition geprägt.
Überschneidungen von Schriftarten sind problemlos möglich, da jede Zeile durch x,y-Koordinaten im Bereich des Hintergrundes positioniert wird.
Die Verfügbarkeit von Schriftarten hängt von vielen Faktoren ab: Linux-Distribution, installierte Software, manuell installierte Schriftarten.
Der Befehl:
sollte alle im System vorhandenen Schriftarten anzeigen. Diese Dateinamen sollten dann auch als Schriftartennamen verwendbar sein. Bei Bedarf können jedoch zusätzliche Schriften (auch die Microsoft-Schriften) installiert werden. Ein paar Hinweise zur Installation der Schriften finden Sie weiter unten. Wird die definierte Schriftart nicht gefunden, wird auf die DejaVuSansMono.ttf zurückgegriffen.
Die zu verwendende Schriftgröße hängt in erster Linie von der Größe des Bildes ab, in das Sie Ihren Text integrieren wollen. Eine sehr große Schrift erfordert natürlich auch ein sehr großes Bild. Bei Bannern oder Stickern sind die Bilder eher klein und erfordern dann natürlich eine kleinere Schriftgröße. Es wäre aber kein Problem, Bilder der eigenen Webcam mit den Daten der eigenen Wetterstation einzufügen.
Bei der Farbdefinition für Schriften und auch Hintergründe können die meisten Farbnamen wie schwarz, rot, gelb, grün, ... aber auch Farbangaben in html-Notation konfiguriert werden. Bei der Angabe der html-Notation muss jedoch anstelle des Zeichens "#" das "$" eingegeben werden.
Es gibt eine vordefinierte Variable $datetime, die in einem definierbaren Format (Python-like: "%d.%m.%Y %H:%M:%S" oder "%y/%m/%d %I:%M %p") die lokale Zeit der Bilderstellung in das Bild "einstempelt". Die Ausgabesprache der Monate und Wochentage kann über locale_format = de_DE.UTF-8 auf Deutsch oder über locale_format = en_US.UTF-8 in der Bannerkonfigurationsdatei auf US-Englisch (oder ein anderes installiertes Gebietsschema) eingestellt werden. Die im Linux-System installierten Sprachpakete, die hier eingetragen werden können, lassen sich mit dem Befehl
In der FOSHKplugin-Konfigurationsdatei foshkplugin.conf soll eine übliche Weiterleitung mit einer eindeutigen Nummer vom Typ "BANNER" (FWD_TYPE = BANNER) angelegt werden.
Die eigentliche Bannerkonfigurationsdatei wird als FWD_OPTION mit bannerconfig=configname.conf angegeben. Diese Trennung in FOSHKplugin-Konfigurationsdatei und Bannerdefinition hat den Vorteil, dass das Banner auch zur Laufzeit von FOSHKplugin angepasst werden kann. Gerade bei der Entwicklung eines Banners sind meist mehrere Versuche notwendig, um die Bannerkomponenten perfekt zu positionieren oder die "richtige" Schriftart auszuwählen.
Dies kann geschehen, ohne dass FOSHKplugin jedes Mal neu gestartet werden muss.
Beachten Sie, dass FWD_URL den Zielort enthält, an dem die generierte Bilddatei via http/POST oder FTP gespeichert werden soll - der eigentliche Dateiname wird in der Bannerkonfiguration festgelegt. Die für den Upload benötigten Zugangsdaten werden mit FWD_SID und FWD_PWD definiert.
Auch wenn die Ausgabedatei für den Upload vorgesehen ist - es wird immer (!) zuerst eine lokale Datei erstellt, die mit image_name in der Bannerkonfiguration angegeben wird.
Bitte beachten Sie auch, dass ohne Angabe eines bestimmten FWD_INTERVAL bei JEDER Eingabe von Daten der Wetterstation ein entsprechendes Banner erzeugt wird. Wenn die Wetterstation z.B. im 16-Sekunden-Takt sendet, wird alle 16 Sekunden (!) ein neues Bannerbild generiert und - falls konfiguriert - an das Upload-Ziel hochgeladen. Dies kann erheblichen Datenverkehr verursachen!
Sie sollten ein gutes Gleichgewicht zwischen der Aktualität der Banner-Bilder und dem Datenverkehr finden. 60 Sekunden (FWD_INTERVAL = 60) sollten ausreichend sein. Aber auch 5 Minuten (d.h. 300 Sekunden - FWD_INTERVAL = 300) können durchaus noch als aktuell bezeichnet werden.
Eine Weiterleitung würde zum Beispiel so in foshkplugin.conf aussehen:
Code: Alles auswählen
[Forward-19]
FWD_ENABLE = True # you may disable the forward instead of deleting
FWD_CMT = Banner-Test Simple # comment field - for your info
FWD_OPTION = bannerconfig=banner-simple.conf # file with banner definition: bannerconfig=/path/to/configfile
FWD_URL = ftps://my.domain.tld/httpdocs/img/ # you may specify a local path, a ftp or http address
FWD_INTERVAL = 60 # in seconds - if not specified a banner image will be created/sent on every weather station interval
FWD_IGNORE = # not really usefull in the BANNER context
FWD_TYPE = BANNER # use BANNER for creating banners/stickers
FWD_SID = ftpuser # user name for ftp/http access
FWD_PWD = ftppasswd # password for uploading via ftp/http
FWD_EXEC = # a script to be started before image creation - e.g. to add custom key=value entries
Und die Bannerdefinition in banner-simple.conf sieht dann wie folgt aus:
Code: Alles auswählen
[Banner]
# this is just a demo banner definition to see the syntax and possibilities
# there are 10 definable fonts: header, line, special, footer, custom, custom1, custom2, custom3, custom4 and custom5
# each font definition contains information on font, colour, size, decimal places (dec_count) and string length (pre_count)
# you may specify up to 100 lines (n) per font definition, where y=Y-coordinate, X-coordinate for name, name, position for value, value and unit
# each line may contain up to 100 coloumns containing the position of the text, the text itself as well as the position of the value, the value and the unit
# fontdefinition_n = y,key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
image_name = banner-simple.png # file name of output image - may be gif, png, jpg, ... and may contain a path
image_width = 300 # only valid if no image is selected as background
image_height = 100 # only valid if no image is selected as background
image_background = white # may be transparent, any color, http color code (with $ instead of #) or a filename of an image file
dtime_format = "%y/%m/%d %I:%M %p" # use "%d.%m.%Y %H:%M:%S" for european 24h display - Python like - see https://www.w3schools.com/python/python_datetime.asp
locale_format = "de_DE.utf8" # use en_US.utf8 for English terms in dates
rounded_corners = True # rounded corners; available for png/gif only, you may specify the radius by n instead of True (default: 10)
border_width = 0 # width of the border in pixels
border_color = black # may be any color name or http colorcode (with $ instead of #)
#logo_1 = y,x,name
logo_1 = 10,250,foshkplugin.png # define logo file name and position - y,y,name - up to 100 logos possible
header_font_name = verdana.ttf # if the specified font is not available the standard font DejaVuSansMono.ttf will be used
header_font_color = blue # may be any color name or the http color code (use $ instead of #)
header_font_size = 8 # size in pixel
#header_1 = y,key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
header_1 = 0,10,$datetime,,,,,,,, # header_0..99 - 100 possible lines with header definition; $datetime uses the current local time
header_pre_count = # length of the output value - padded with spaces if necessary
header_dec_count = # default of decimal places - will be rounded
header_dtime_format = # uses the format defined here for time/date outputs of this font (see dtime_format in the global assignment).
line_font_name = verdanab.ttf
line_font_color = black
line_font_size = 14
#line_1 = y,key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
line_1 = 15,10,Temperatur:,140,tempc, °C,,,,,,,,,,
line_2 = 35,10,Luftfeuchte:,140,humidity, %,,,,,,,,,,
line_3 = 55,10,Luftdruck:,140,baromrelhpa, hPa,,,,,,,,,,
footer_font_name = verdana.ttf
footer_font_color = black
footer_font_size = 16
#footer_1 = y, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
footer_1 = 80,10,Hohen Neuendorf\, Germany,,,,,,,,
special_font_name = verdana.ttf
special_font_color = black
special_font_size = 16
#special_1 = y, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
#special_1 = 80,10,Hohen Neuendorf\, Germany,,,,,,,,
custom_font_name = verdana.ttf
custom_font_color = black
custom_font_size = 16
#custom_1 = y,key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni, key_pos,key,val_pos,value,uni
Zu Testzwecken und als Übersicht gibt es eine http-Übersichtsseite, die unter http://ipaddress:port/FOSHKplugin/banner zu erreichen ist. Dort werden alle Bilder angezeigt, die von bestehenden conf-Dateien (mit [Banner]-Stanza) erzeugt werden.
Jedes der angezeigten Bilder enthält einen Link auf das eigentliche Bild. Es gibt zwei verschiedene Links - image und config. image zeigt einfach das Bild an, das im angegebenen Intervall (FWD_INTERVAL) erzeugt wurde; config erzeugt bei jedem Aufruf ein neues Bild und zeigt es an - es wird aber nicht außerhalb des üblichen Intervalls per ftp/http an das Ziel gesendet.
Für die Erstellung und Optimierung von Bannern empfiehlt es sich, die Webseite mit dem zu erstellenden Banner und einem Refresh (&refresh=2 an die URL anhängen) im Hintergrund zu starten und die eigentliche conf-Datei im Vordergrund zu bearbeiten - so sieht man die vorgenommenen Änderungen sofort und kann die einzelnen Elemente sehr einfach positionieren.
Bei transparenten Bannern oder auch um die Wirkung der Farbgebung zu beurteilen, kann die Hintergrundfarbe der Webseite durch Hinzufügen von &background=grey (oder eines beliebigen html-Farbcodes - wobei das "#"-Zeichen durch "$" ersetzt werden muss) zur URL geändert werden.
Auch wenn es Probleme mit falschen Zuordnungen, fehlenden Logos oder Schriftarten gibt, versucht FOSHKplugin immer, das passende Bild zu erzeugen. Bei falschen oder fehlerhaften Komponenten wird eine Warnung im snd-foshkplugin.log ausgegeben.
Häufige Probleme sind fehlende Schriftarten, Logos oder Hintergründe, die eingebettet werden sollen. Auch die falsche Angabe von Farben für Hintergrund und Schrift kann aufgrund der geänderten Syntax ($ statt #) oder Tippfehler in der Farbdefinition zu Warnungen oder nicht erwarteten Ergebnissen führen.
Mit den Hinweisen in der Logdatei und dieser Beschreibung sollten diese Probleme jedoch schnell zu lösen sein.
Problemlösung:
Wenn trotz Angabe des gewünschten Gebietsschemas (locale_format) die Wochentage oder Monate nicht in der erwarteten Sprache angezeigt werden, muss dieses Gebietsschema zunächst installiert werden. Auf Debian-basierten Systemen geschieht dies durch Ankreuzen der entsprechenden Locale nach dem Aufruf von
Zusätzliche Hinweise:
Kompatibilität der Schriften:
https://www.linux-magazine.com/Online/B ... tary-fonts
Microsoft-Schriftarten:
https://translate.google.com/website?sl ... ts-ubuntu/
freie DejaVu-Schriftarten:
https://translate.google.com/website?sl ... github.io/
freie Logos:
Kostenlose (gemeinfreie) Logos zur Integration in Ihre eigenen Banner finden Sie
hier. Diese Bilder können in jeder Auflösung und Farbe heruntergeladen werden.
Google hat auch eine umfangreiche Sammlung von
Schriftarten und
Symbolen, die kostenlos verwendet werden können.
Frei verwendbare Hintergrundbilder für Banner finden Sie u.a. bei
Pexels oder
Unsplash.
Weitere freie Icons finden sich hier:
https://github.com/roe-dl/weathericons
https://www.dwd.de/DE/wetter/warnungen_ ... _node.html
https://erikflowers.github.io/weather-icons/
Sie sollten sich jedoch immer vergewissern, dass die verwendeten Schriftarten, Icons, Logos und Hintergründe legal verwendet werden können. Ich übernehme keine Haftung!