| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557 |
- ##############################################
- # $Id: 95_remotecontrol.pm 10724 2016-02-04 18:17:33Z ulimaass $
- # 95_remotecontrol
- #
- ################################################################
- #
- # Copyright notice
- #
- # (c) 2013 Copyright: Ulrich Maass
- #
- # This file is part of fhem.
- #
- # Fhem is free software: you can redistribute it and/or modify
- # it under the terms of the GNU General Public License as published by
- # the Free Software Foundation, either version 2 of the License, or
- # (at your option) any later version.
- #
- # Fhem is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with fhem. If not, see <http://www.gnu.org/licenses/>.
- #
- # Disclaimer: The Author takes no responsibility whatsoever
- # for damages potentially done by this program.
- #
- ################################################################################
- #
- # Implementation:
- # 1 - set WEB rereadicons
- # 2 - define rc1 remotecontrol (defines fresh remotecontrol, has no keys defined yet)
- # 3a- get rc1 layout (display list of available "keybiard"-layouts)
- # 3 - set rc1 layout samsung (assigns standard-key-layout for e.g. samsungTV)
- # 4 - set rc1 makeweblink (creates a weblink weblink_rc1)
- # 4a- for testing: attr rc1 room TestRemote , attr weblink_rc1 room TestRemote
- # 5 - set rc1 makenotify <executingDevice> (creates a notify of the form: define notify_rc1 notify rc1 set <executingDevice> $EVENT)
- #
- # Published June 23, 2013
- # bugfix "use strict" upon foreign makenotify - June 24, 2013
- # converted to UNIX-LF - June 25, 2013
- # fixed minor html-bug - June 26, 2013
- # added css-tags rc_body and rc_button - June 27, 2013
- # deleted leading \n at beginning of html-code - June 30, 2013
- # fhemweb-detailscreen of remotecontrol now displays a preview, added htmlNoTable for RC_attr2html(), added RC_summaryFn incl attr rc_devStateIcon
- package main;
- use strict;
- use warnings;
- #########################
- # Forward declaration
- sub RC_Define();
- sub RC_Set($@);
- sub RC_Get($@);
- sub RC_Attr(@);
- sub RC_array2attr($@);
- sub RC_attr2html($@);
- sub RC_layout_delete($);
- sub RC_layout_samsung();
- sub RC_layout_itunes();
- sub RC_detailFn($$$$);
- sub RC_webCmdFn($$$);
- sub RC_summaryFn($$$$);
- #####################################
- # Initialize module
- sub
- remotecontrol_Initialize($)
- {
- my ($hash) = @_;
- $hash->{GetFn} = "RC_Get";
- $hash->{SetFn} = "RC_Set";
- $hash->{AttrFn} = "RC_Attr";
- $hash->{DefFn} = "RC_Define";
- $hash->{AttrList} = "rc_iconpath rc_iconprefix loglevel:0,1,2,3,4,5,6 rc_devStateIcon:0,1 ".
- "row00 row01 row02 row03 row04 row05 row06 row07 row08 row09 ".
- "row10 row11 row12 row13 row14 row15 row16 row17 row18 row19";
- $hash->{FW_detailFn} = "RC_detailFn"; # displays rc preview in fhemweb detail-screen
- $hash->{FW_summaryFn} = "RC_summaryFn"; # displays rc instead of status icon in fhemweb room-view
- $data{webCmdFn}{remotecontrol} = "RC_webCmdFn"; # displays rc instead of device-commands on the calling device
- $data{RC_layout}{samsung} = "RC_layout_samsung";
- $data{RC_layout}{itunes} = "RC_layout_itunes";
-
- # $data{RC_layout}{enigma} = "RC_layout_enigma";
- # $data{RC_makenotify}{enigma} = "RC_makenotify_enigma";
- }
- #####################################
- # Initialize every new instance
- sub
- RC_Define()
- {
- my ($hash, $def) = @_;
- $hash->{STATE} = "initialized";
- $hash->{".htmlCode"} = "";
- return undef;
- }
- #####################################
- # Ensure htmlcode is created from scratch after an attribute value has been changed
- sub
- RC_Attr(@)
- {
- my @a = @_;
- my $hash = $defs{$a[1]};
- $hash->{".htmlCode"} = "";
- return;
- }
- #####################################
- # Digest set-commands
- sub
- RC_Set($@)
- {
- my ($hash, @a) = @_;
- my $nam = $a[0];
- my $cmd = (defined($a[1]) ? $a[1] : ""); #command
- my $par = (defined($a[2]) ? $a[2] : ""); #parameter
-
- ## set layout
- if ($cmd eq "layout") {
- if ($par eq "delete") {
- RC_layout_delete($nam);
- $hash->{".htmlCode"} = "";
- } else { # layout
- my $layoutlist = "";
- my @rows;
- foreach my $fn (sort keys %{$data{RC_layout}}) {
- $layoutlist .= $fn."\n";
- next if ($fn ne $par);
- no strict "refs";
- @rows = &{$data{RC_layout}{$fn}}($fn);
- use strict "refs";
- }
- if ($#rows > 0) {
- RC_layout_delete($nam);
- RC_array2attr($nam, @rows);
- $hash->{".htmlCode"} = "";
- } else {
- return "Missing or invalid parameter \"$par\" for set ... layout. Use one of\n".
- "delete\n".$layoutlist;
- }
- }
- ## set makeweblink
- } elsif ($cmd eq "makeweblink") {
- my $wname = $a[2] ? $a[2] : "weblink_".$nam;
- fhem("define $wname weblink htmlCode {fhem(\"get $hash->{NAME} htmlcode\", 1)}");
- Log 2, "[remotecontrol] Weblink created: $wname";
- return "Weblink created: $wname";
- ## set makenotify
- } elsif ($cmd eq "makenotify") {
- if ($a[2]) {
- my $ndev = $a[2];
- my $fn = $defs{$ndev}{TYPE} ? $defs{$ndev}{TYPE} : undef;
- if (defined($fn) && defined($data{RC_makenotify}{$fn})) { #foreign makenotify
- no strict "refs";
- my $msg = &{$data{RC_makenotify}{$fn}}($nam,$ndev);
- use strict "refs";
- return $msg;
- } else {
- my $nname="notify_$nam";
- fhem("define $nname notify $nam set $ndev ".'$EVENT',1);
- Log 2, "[remotecontrol] Notify created: $nname";
- return "Notify created: $nname";
- }
- } else {
- return "set $nam makenotify <executingdevice>:\n name of executing device missing.";
- }
- ## set ?
- } elsif ($cmd eq "?") {
- my $ret = "Unknown argument $cmd choose one of makeweblink makenotify state .remotecontrol:remotecontrol layout:";
- foreach my $fn (sort keys %{$data{RC_layout}}) {
- $ret .= $fn . ",";
- }
- $ret =~ s/[:,]$//;
- return $ret;
- ## set state <command>
- } else {
- Log GetLogLevel($nam,4), "[remotecontrol] set $nam $cmd $par";
- readingsSingleUpdate($hash,"state",$cmd,1) if (!$par);
- }
- }
- #####################################
- # Digest get-commands
- sub
- RC_Get($@)
- {
- my ($hash, @a) = @_;
- my $arg = (defined($a[1]) ? $a[1] : ""); #command
- my $name = $hash->{NAME};
- ## get htmlcode
- if($arg eq "htmlcode") {
- $hash->{".htmlCode"} = RC_attr2html($name) if ($hash->{".htmlCode"} eq "");
- return $hash->{".htmlCode"};
- ## get layout
- } elsif ($arg eq "layout") {
- my $layoutlist = "Available predefined layouts are:\n";
- foreach my $fn (sort keys %{$data{RC_layout}}) {
- $layoutlist .= $fn."\n";
- }
- return $layoutlist;
- ## get -> error
- } else {
- return "Unknown argument $arg choose one of: htmlcode layout";
- }
- }
- #####################################
- # Convert all rowXX-attribute-values into htmlcode
- sub
- RC_attr2html($@) {
- my ($name,$htmlNoTable) = @_;
- my $iconpath = AttrVal("$name","rc_iconpath","icons/remotecontrol");
- my $iconprefix = AttrVal("$name","rc_iconprefix","");
- my $rc_html;
- my $row;
- $rc_html = "<div class=\"remotecontrol\">";
- # $rc_html = "<div class=\"remotecontrol\" id=\"$name\">"; # provokes update by longpoll
- $rc_html.= '<table class="rc_body">' if (!$htmlNoTable);
- foreach my $rownr (0..19) {
- $rownr = sprintf("%2.2d",$rownr);
- $row = AttrVal("$name","row$rownr",undef);
- next if (!$row);
- $rc_html .= "<tr>\n" if (!$htmlNoTable);
- my @btn = split (",",$row);
- foreach my $btnnr (0..$#btn) {
- $rc_html .= '<td class="rc_button">';# if (!$htmlNoTable);
- if ($btn[$btnnr] ne "") {
- my $cmd;
- my $img;
- if ($btn[$btnnr] =~ /(.*?):(.*)/) { # button has format <command>:<image>
- $cmd = $1;
- $img = $2;
- } else { # button has format <command> or is empty
- $cmd = $btn[$btnnr];
- $img = $btn[$btnnr];
- }
- if ($img =~ m/\.svg/) { # convert svg-images
- $img = FW_makeImage($img, $cmd, "rc-button");
- } else {
- $img = "<img src=\"$FW_ME/$iconpath/$iconprefix$img\">";
- }
- if ($cmd || $cmd eq "0") {
- $cmd = "cmd.$name=set $name $cmd";
- $rc_html .= "<a onClick=\"FW_cmd('$FW_ME$FW_subdir?XHR=1&$cmd')\">$img</a>";
- } else {
- $rc_html .= $img;
- }
- }
- $rc_html .= "</td>";# if (!$htmlNoTable);
- $rc_html .= "\n";
- }
- $rc_html .= "</tr>\n" if (!$htmlNoTable);
- }
- $rc_html .= "</table>" if (!$htmlNoTable);
- $rc_html .= "</div>";
- return $rc_html;
- }
- #####################################
- # Delete all rowXX-attributes
- sub
- RC_layout_delete($) {
- my $name = shift;
- foreach my $rownr (0..19) {
- $rownr = sprintf("%2.2d",$rownr);
- fhem("deleteattr $name row$rownr",1);
- }
- }
- #####################################
- # Convert array-values into rowXX-attribute-values
- sub
- RC_array2attr($@)
- {
- my ($name, @row) = @_;
- my $ret;
- foreach my $rownr (0..21) {
- next if (!$row[$rownr]);
- $rownr = sprintf("%2.2d",$rownr);
- if ($row[$rownr] =~ m/^attr (.*?)\s(.*)/) {
- $ret = fhem("attr $name $1 $2");
- } else {
- $ret = fhem("attr $name row$rownr $row[$rownr]") if ($row[$rownr]);
- }
- }
- }
- ##################
- #remotecontrol-specific fhemweb detail-screen
- sub
- RC_detailFn($$$$) {
- my ($FW_wname, $d, $room, $pageHash) = @_; # pageHash is set for summaryFn.
- my $hash = $defs{$d};
- $hash->{".htmlCode"} = RC_attr2html($d) if ($hash->{".htmlCode"} eq "");
- return $hash->{".htmlCode"};
- }
- ##################
- #remotecontrol-specific webCmdFn to be used
- # calling module needs to provide ".remotecontrol:remotecontrol" in its return to 'set <device> ?'
- sub
- RC_webCmdFn($$$) {
- my ($FW_wname, $d, $FW_room, $cmd, $values) = @_;
- return undef if($values !~ m/remotecontrol/);
- my @args = split("[ \t]+", $cmd);
- return RC_attr2html($args[1],1) if ($args[1]);
- return undef;
- }
- ##################
- #remotecontrol-specific summaryFn to be used
- # displays the remote on the remote-device itself in FHEMWEB room-overview
- sub
- RC_summaryFn($$$$) {
- my ($FW_wname, $d, $room, $pageHash) = @_; # pageHash is set for summaryFn.
- my $hash = $defs{$d};
- my $name = $hash->{NAME};
- return undef if (AttrVal($name,"rc_devStateIcon",1) != 1);
- return RC_attr2html($name);
- }
- #####################################
- # Default-layout for samsung
- sub
- RC_layout_samsung() {
- my $ret;
- my @row;
- $row[0]="POWEROFF,TV,HDMI";
- $row[1]=":blank,:blank,:blank";
- $row[2]="1,2,3";
- $row[3]="4,5,6";
- $row[4]="7,8,9";
- $row[5]=":blank,0,PRECH";
- $row[6]=":blank,:blank,:blank";
- $row[7]="VOLUP:UP,MUTE,CHUP";
- $row[8]=":VOL,:blank,:PROG";
- $row[9]="VOLDOWN:DOWN,CH_LIST,CHDOWN";
- $row[10]="MENU,:blank,GUIDE";
- $row[11]=":blank,:blank,:blank";
- $row[12]="TOOLS,UP,INFO";
- $row[13]="LEFT,ENTER,RIGHT";
- $row[14]="RETURN,DOWN,EXIT";
- $row[15]="attr rc_iconpath icons/remotecontrol";
- $row[16]="attr rc_iconprefix black_btn_";
- # unused available commands
- # AD PICTURE_SIZE SOURCE
- # CONTENTS W_LINK
- # RSS MTS SRS CAPTION TOPMENU SLEEP ESAVING
- # PLAY PAUSE REWIND FF REC STOP
- # PIP_ONOFF ASPECT
- return @row;
- }
- #####################################
- # Default-layout for itunes
- sub
- RC_layout_itunes() {
- my $ret;
- my @row;
- $row[0]="play:PLAY,pause:PAUSE,prev:REWIND,next:FF,quieter:VOLDOWN,louder:VOLUP";
- $row[1]="attr rc_iconpath icons/remotecontrol";
- $row[2]="attr rc_iconprefix black_btn_";
- # unused available commands
- return @row;
- }
- 1;
- =pod
- =begin html
- <a name="remotecontrol"></a>
- <h3>remotecontrol</h3>
- <ul>
- Displays a graphical remote control. Buttons (=icons) can be chosen and arranged. Predefined layouts are available for e.g. Samsung-TV or iTunes.
- Any buttonclick can be forwarded to the actual fhem-device. For further explanation, please check the <a href="http://www.fhemwiki.de/wiki/Remotecontrol">Wiki-Entry</a>.<br>
- <a name="remotecontroldefine"></a><br>
- <b>Define</b>
- <ul>
- <code>define <rc-name> remotecontrol</code><br><br>
- Typical steps to implement a remotecontrol:<br>
- <table>
- <tr><td><code>define rc1 remotecontrol</code></td><td><code># defines a "blank" remotecontrol</code></td></tr>
- <tr><td><code>get rc1 layout</code></td><td><code># displays all available predefined layouts</code></td></tr>
- <tr><td><code>set rc1 layout samsung</code></td><td><code># assigns keys for a SamsungTV</code></td></tr>
- <tr><td><code>set rc1 makenotify myTV</code></td><td><code># creates notify_rc1 which forwards every buttonclick to myTV for execution</code></td></tr>
- <tr><td><b>Note:</b> keys can be changed at any time, it is not necessary to redefine the weblink</td></tr>
- <tr><td><code>attr rc1 row15 VOLUP,VOLDOWN</code></td></tr>
- </table>
- </ul>
- <a name="remotecontrolset"></a><br>
- <b>Set</b>
- <ul>
- <li><code>set <rc-name> layout [delete|<layoutname>]</code><br>
- <code>layout delete</code> deletes all rowXX-attributes<br>
- <code>layout <layoutname></code> assigns a predefined layout to rowXX-attributes</li>
- <li><code>set <rc-name> makeweblink [<name>]</code><br>
- creates a weblink to display the graphical remotecontrol. Default-name is weblink_<rc-name> .</li>
- <li><code>set <rc-name> makenotify <executingDevice></code><br>
- creates a notify to trigger <executingDevice> every time a button has been pressed. name is notify_<rc-name> .</li>
- </ul>
-
- <a name="remotecontrolget"></a><br>
- <b>Get</b>
- <ul>
- <code>get <rc-name> [htmlcode|layout]</code><br>
- <li><code>htmlcode</code> displays htmlcode for the remotecontrol on fhem-page</li>
- <li><code>layout</code> shows which predefined layouts ae available</li>
- </ul>
-
- <a name="remotecontrolattr"></a><br>
- <b>Attributes</b>
- <ul>
- <li><a href="#loglevel">loglevel</a></li>
- <li><a name="rc_iconpath">rc_iconpath</a><br>
- path for icons, default is "icons" . The attribute-value will be used for all icon-files except .svg .</li>
- <li><a name="rc_iconprefix">rc_iconprefix</a><br>
- prefix for icon-files, default is "" . The attribute-value will be used for all icon-files except .svg .</li>
- <li>Note: Icon-names (button-image-file-names) will be composed as <code>fhem/<rc_iconpath>/<rc_iconprefix><command|image></code><br>
- For .svg -icons, the access sequence is according to the FHEMWEB-attribute iconPath, default is openautomation:fhemSVG:default .</li>
- <li><a name="rc_devStateIcon">rc_devStateIcon</a><br>
- In FHEMWEB-room-overview, displays the button-layout on the rc-device itself. Default is 1, set to 0 is the remotecontrol-device should not display its buttons in FHEMWEB roomview.</li>
- <br>
- <li><a href="#rowXX">rowXX</a><br>
- <code>attr <rc-name> rowXX <command>[:<image>][,<command>[:<image>]][,...]</code><br>
- Comma-separated list of buttons/images per row. Any number of buttons can be placed in one row. For each button, use</li>
- <ul>
- <li><code><command></code> is the command that will trigger the event after a buttonclick. Case sensitive.</li>
- <li><code><image></code> is the filename of the image</li><br>
- <li>Per button for the remotecontrol, use</li>
- <li><code><command></code> where an icon with the name <rc_iconprefix><command> is displayed<br>
- Example:<br>
- <code>attr rc1 rc_iconprefix black_btn_ # used for ALL icons on remotecontrol rc1</code><br>
- <code>attr rc1 row00 VOLUP </code><br>
- icon is <code>black_btn_VOLUP</code>, a buttonclick creates the event <code>VOLUP</code>
- </li>
- or
- <li><code><command>:<image></code> where an icon with the name <code><rc_iconprefix><image></code> is displayed<br>
- Example: <br>
- <code>row00=LOUDER:VOLUP</code><br>
- icon is <code>black_btn_VOLUP</code>, a buttonclick creates the event <code>LOUDER</code>
- <br>
- Examples:<br>
- <code>attr rc1 row00 1,2,3,TV,HDMI</code><br>
- <code>attr rc2 row00 play:PLAY,pause:PAUSE,louder:VOLUP,quieter:VOLDOWN</code><br>
- </li>
- <li><b>Hint:</b> use :blank for a blank space, use e.g. :blank,:blank,:blank for a blank row</li>
- </ul>
- </ul>
- </ul>
- =end html
- =begin html_DE
- <a name="remotecontrol"></a>
- <h3>remotecontrol</h3>
- <ul>
- Erzeugt eine graphische Fernbedienung. Buttons (=icons) können frei ausgewählt und angeordnet werden. Vordefinierte layouts sind verfügbar für z.B. Samsung-TV und iTunes.
- Jeder "Knopfdruck" kann an das entsprechende fhem-Gerät weitergegeben werden.<br>
- Weitere Erklaerungen finden sich im <a href="http://www.fhemwiki.de/wiki/Remotecontrol">Wiki-Eintrag</a>.<br>
- <a name="remotecontroldefine"></a><br>
- <b>Define</b>
- <ul>
- <code>define <rc-name> remotecontrol</code><br><br>
- Typische Schritte zur Einrichtung:<br>
- <table>
- <tr><td><code>define rc1 remotecontrol</code></td><td><code># erzeugt eine "leere" remotecontrol</code></td></tr>
- <tr><td><code>get rc1 layout</code></td><td><code># zeigt alle vorhandenen vordefinierten layouts an</code></td></tr>
- <tr><td><code>set rc1 layout samsung</code></td><td><code># laedt das layout für SamsungTV</code></td></tr>
- <tr><td><code>set rc1 makenotify myTV</code></td><td><code># erzeugt notify_rc1, das jeden Tastendruck an myTV weitergibt</code></td></tr>
- <tr><td><b>Hinweis:</b>die Tastenbelegung kann jederzeit geaendert werden, ohne dass der weblink erneut erzeugt werden muss.</td></tr>
- <tr><td><code>attr rc1 row15 VOLUP,VOLDOWN</code></td></tr>
- </table>
- </ul>
- <a name="remotecontrolset"></a><br>
- <b>Set</b>
- <ul>
- <li><code>set <rc-name> layout [delete|<layoutname>]</code><br>
- <code>layout delete</code> loescht alle rowXX-Attribute<br>
- <code>layout <layoutname></code> laedt das vordefinierte layout in die rowXX-Attribute</li>
- <li><code>set <rc-name> makeweblink [<name>]</code><br>
- erzeugt einen weblink zur Anzeige der remotecontrol in FHEMWEB oder FLOORPLAN. Default-Name ist weblink_<rc-name> .</li>
- <li><code>set rc1 makenotify mySamsungTV</code><br>
- erzeugt <code>notify_rc1</code> das jeden Tastendruck an mySamsungTV zur Ausfuehrung weitergibt</li>
- </ul>
-
- <a name="remotecontrolattr"></a><br>
- <b>Attribute</b>
- <ul>
- <li><a href="#loglevel">loglevel</a></li>
- <li><a name="rc_iconpath">rc_iconpath</a><br>
- Pfad für icons, default ist "icons" . Der Attribut-Wert wird für alle icon-Dateien verwendet ausser .svg .</li>
- <li><a name="rc_iconprefix">rc_iconprefix</a><br>
- Prefix für icon-Dateien, default ist "" . Der Attribut-Wert wird für alle icon-Dateien verwendet ausser .svg .</li>
- <li>Note: Icon-Namen (Tasten-Bild-Datei-Namen) werden zusammengesetzt als fhem/<rc_iconpath>/<rc_iconprefix><command|image><br>
- Fuer .svg -icons ist die Zugriffsfolge gemaess dem FHEMWEB-Attribut iconPath, default ist openautomation:fhemSVG:default .
- </li>
- <li><a name="rc_devStateIcon">rc_devStateIcon</a><br>
- Zeigt das button-layout auf dem remotecontrol-device selbst in der FHEMWEB-Raumansicht an. Default ist 1, durch setzen auf 0 erscheint in der FHEMWEB-Raumansciht nicht das layout, sondern nur der Status "Initialized".</li>
- <br>
- <li><a href="#rowXX">rowXX</a><br>
- <code>attr <rc-name> rowXX <command>[:<image>]</code><br>
- Komma-separarierte Liste von Tasten/Icons je Tastaturzeile. Eine Tastaturzeile kann beliebig viele Tasten enthalten.</li><br>
- <li><command> ist der event, der bei Tastendruck ausgelöst wird. Gross/Kleinschreibung beachten.</li>
- <li><image> ist der Dateiname des als Taste angezeigten icons</li>
- <li>Verwenden Sie je Taste</li>
- <li><command> wobei als Taste/icon <code><rc_iconprefix><command></code> angezeigt wird<br>
- Beispiel:<br>
- <code>attr rc1 rc_iconprefix black_btn_ # gilt für alle Tasten/icons</code><br>
- <code>attr rc1 row00 VOLUP</code><br>
- -> icon ist <code>black_btn_VOLUP</code>, ein Tastendruck erzeugt den event <code>VOLUP</code>
- </li><br>
- oder
- <li><command>:<image> wobei als Taste/icon <rc_iconprefix><image> angezeigt wird.<br>
- Beispiel:<br>
- <code>attr rc1 row00 LOUDER:VOLUP</code><br>
- icon ist black_btn_VOLUP, ein Tastendruck erzeugt den event LOUDER<br>
- Beispiele:
- <code>attr rc1 row00 1,2,3,TV,HDMI</code><br>
- <code>attr rc2 row00 play:PLAY,pause:PAUSE,louder:VOLUP,quieter:VOLDOWN</code><br>
- </li>
- <li><b>Hinweis:</b> verwenden Sie :blank für eine 'leere Taste', oder z.B. :blank,:blank,:blank für eine Abstands-Leerzeile.</li>
- </ul>
- </ul>
- =end html_DE
- =cut
|