YAF: Unterschied zwischen den Versionen

Aus FHEMWiki
Zeile 86: Zeile 86:


= Konfiguration =
= Konfiguration =
YAF wird durch die folgende Definition aktivert:
define yaf YAF
Die weitere Konfiguration kann komplett über das YAF Interface erfolgen, außer das Setzen des Hintergrundbildes.
Der Pfad zum Hintergrundbild muss im Attribut <code>backgrounds</code> definiert werden.
attr yaf backgrounds 1,1,1,/path/to/image;;2,1,1,/path/to/another/image.jpg
attr yaf refresh_interval 10
attr yaf views 1,Haus;;2,Test


= Widgets =
= Widgets =

Version vom 7. September 2013, 19:25 Uhr

Projekt YAF

YAF entstand als Projektarbeit von Daniel Weisensee und Markus Mangei an der Hochschule Karlsruhe Technik und Wirtschaft.

Es steht für “Yet Another Floorplan” und soll eine Alternative zum bisher vorhandenen Floorplan bieten. YAF basiert auf ClientSeite aus den JavaScript Frameworks JQuery und JQuery UI, serverseitig werden die CPAN Module XML::LibXML (bindet libxml2 an Perl an) und JSON::XS verwendet, um die Konfiguration zu persisitieren und um Daten zwischen der Oberfläche und dem Server austauschen zu können.

Durch die Erweiterbarkeit von Widgets soll YAF flexibel gehalten werden. Mit Hilfe dieser Schnittstelle können problemlos Widgets von verschiedenen Entwicklern veröffentlicht werden, ohne dass sich diese über gewünschte Änderungen am YAF Code mit der Community abstimmen müssen. Es soll ähnlich dem Prinzip der Widgets unter Android oder Windows funktionieren. Widgets sollen speziell für FHEM Plugins geschrieben werden, um somit möglichst komfortable Oberflächen bieten zu können.


  • Das Projekt ist freie Software unter der GNU General Public License und befindet sich auf dem offiziellen FHEM SourceForge.net Repository:

https://sourceforge.net/p/fhem/code/HEAD/tree/trunk/fhem/contrib/YAF/

  • Im FHEM Forum gibt es einen Thread mit dem Titel “Yet Another Floorplan YAF”:

http://forum.fhem.de/index.php?t=msg&th=12629&start=0&rid=0

Installation

Installation mit FHEM Update

update thirdparty http://svn.code.sf.net/p/fhem/code/trunk/fhem/contrib/YAF/ yaf

Voraussetzungen

XML::LibXML auf einer Synology

In der aktuellen Version nutzt YAF die FHEM Konfiguration, LibXML ist nicht mehr notwendig. JSON::XS ist notwendig.

YAF benötigt (neben anderen Modulen, siehe HOWTO im SVN), das PERL Modul XML::LibXML.

Dies kann einen fast zur Verzweiflung bringen, da das Modul weder mit CPAN noch manuell kompilieren möchte. Das Problem ist, das "perl Makefile.PL" sich weigert, den Makefile zu erstellen. Die wenig elegante, aber funktionierende Lösung ist, den entsprechenden Code aus der Datei Makefile.PL zu entfernen:


print "Checking for ability to link against xml2...";
#if ( _libxml_check_lib('xml2') ) {
#    print "yes\n";
#}
#else {
#    print "no\n";
#    print "Checking for ability to link against libxml2...";
#    if ( _libxml_check_lib('libxml2')) {
#        print "yes\n";
#    }
#    else {
#        print STDERR <<"DEATH";
#libxml2, zlib, and/or the Math library (-lm) have not been found.
#Try setting LIBS and INC values on the command line
#Or get libxml2 from
#  http://xmlsoft.org/
#If you install via RPMs, make sure you also install the -devel
#RPMs, as this is where the headers (.h files) are.
#
#Also, you may try to run perl Makefile.PL with the DEBUG=1 parameter
#to see the exact reason why the detection of libxml2 installation
#failed or why Makefile.PL was not able to compile a test program.
#DEATH
#        exit 0; # 0 recommended by http://cpantest.grango.org (Notes for CPAN Authors)
#    }
#}

# -------------------------------------------------------------------------- #
# _NOW_ write the Makefile

danach:

perl Makefile.PL
make
make install

Konfiguration

YAF wird durch die folgende Definition aktivert:

define yaf YAF

Die weitere Konfiguration kann komplett über das YAF Interface erfolgen, außer das Setzen des Hintergrundbildes. Der Pfad zum Hintergrundbild muss im Attribut backgrounds definiert werden.

attr yaf backgrounds 1,1,1,/path/to/image;;2,1,1,/path/to/another/image.jpg
attr yaf refresh_interval 10
attr yaf views 1,Haus;;2,Test

Widgets

fhttk

fs20st

fs20easylamp

generic

fht80