8672ed0208
Prevents JavaDoc tooling issues because these tools check comments starting with `/**`. Signed-off-by: Wouter Born <github@maindrain.net> |
||
---|---|---|
.. | ||
src | ||
NOTICE | ||
README.md | ||
pom.xml |
README.md
Kaleidescape Binding
This binding now makes it possible to easily integrate almost all of the capabilities of the Kaleidescape control protocol into openHAB. Beyond just integrating playback transport controls, all meta-data provided via the control protocol is made available for display purposes and to use in rules. By using rules, it is possible to control other Things such as lighting, projector lens shift, screen masking, etc. based on events that occur during movie playback. A simulated remote control is available in BasicUI using the Buttongrid sitemap element described below. Finally, any other command that is supported by the control protocol can be sent to the component through rules. See Kaleidescape-System-Control-Protocol-Reference-Manual.pdf for a reference of available commands.
Supported Things
All movie player components including the original K-Player series, M Class Players, Cinema One, Alto, and Strato are supported. It is important to choose the correct thing type to ensure the available channels are correct for the component being used.
The supported thing types are:
player
Any KPlayer, M Class [M300, M500, M700] or Cinema One 1st Gen playercinemaone
Cinema One (2nd Gen)alto
strato
Includes Strato, Strato S, Strato C or Strato V
The binding supports either a TCP/IP connection or direct serial port connection (19200-8-N-1) to the Kaleidescape component.
Discovery
Auto-discovery is supported for Alto and Strato components if the device can be located on the local network using SDDP. Manually initiated discovery will locate all legacy Premiere line components if they are on the same IP subnet of the openHAB server. In the Inbox, select Search For Things and then choose the Kaleidescape Binding to initiate a discovery scan.
Thing Configuration
The thing has the following configuration parameters:
Parameter Label | Parameter ID | Description | Accepted values |
---|---|---|---|
Address | host | Host name or IP address of the Kaleidescape component | A host name or IP address |
Port | port | Communication port of the IP connection | 10000 (default - should not need to change) |
Serial Port | serialPort | Serial port for connecting directly a component | Serial port name (optional) |
Update Period | updatePeriod | Tells the component how often time status updates should be sent (see notes below) | 0 or 1 are the currently accepted values (default 0) |
Advanced Volume Control Enabled | volumeEnabled | Enable the volume and mute controls in the K iPad & phone apps; when enabled the volume and mute channels described below are active | Boolean (default false) |
Initial Volume Setting | initialVolume | Initial volume level set when the binding starts up | 0 to 75 (default 25) |
Basic Volume Control Enabled | volumeBasicEnabled | Enables stateless volume up/down and mute controls in the K apps; cannot be used when volumeEnabled is true (see rules example below) |
Boolean (default false) |
Load Highlighted Details | loadHighlightedDetails | When enabled the binding will automatically load the the metadata channels when the selected item in the UI (Movie or Album) changes | Boolean (default false) |
Load Album Details | loadAlbumDetails | When enabled the binding will automatically load the metadata channels for the currently playing Album | Boolean (default false) N/A for Alto and Strato |
Some notes:
-
The only caveat of note about this binding is the updatePeriod configuration parameter.
-
When set to the default of 0, the component only sends running time update messages sporadically (as an example: when the movie chapter changes) while content is playing.
-
In this case, the running time channels will also only sporadically update.
-
When updatePeriod is set to 1 (values greater than 1 are not yet supported by the control protocol), the component sends running time status update messages every second.
-
Be aware that this could cause performance impacts to your openHAB system.
-
On Linux, you may get an error stating the serial port cannot be opened when the Kaleidescape binding tries to load.
-
You can get around this by adding the
openhab
user to thedialout
group like this:usermod -a -G dialout openhab
. -
Also on Linux you may have issues with the USB if using two serial USB devices e.g. Kaleidescape and RFXcom.
-
See the general documentation about serial port configuration for more on symlinking the USB ports.
Channels
The following channels are available:
Channel ID | Item Type | Description |
---|---|---|
ui#power | Switch | Turn the zone On or Off (system standby) |
ui#volume | Dimmer | A virtual volume that tracks the volume control from the K app, use as a proxy to adjust a real volume item via follow or rules |
ui#mute | Switch | A virtual mute switch that tracks the mute status from the K app, use as a proxy to control a real mute item |
ui#control | Player | Control Movie Playback e.g. play/pause/next/previous/ffward/rewind |
ui#title_name | String | The title of the movie currently playing |
ui#play_mode | String | The current playback mode of the movie |
ui#play_speed | String | The speed of playback scanning |
ui#title_num | Number | The current movie title number that is playing |
ui#title_length | Number:Time | The total running time of the currently playing movie (seconds) |
ui#title_loc | Number:Time | The running time elapsed of the currently playing movie (seconds) |
ui#endtime | DateTime | The date/time when the currently playing movie will end (timestamp) |
ui#chapter_num | Number | The current chapter number of the movie that is playing |
ui#chapter_length | Number:Time | The total running time of the current chapter (seconds) |
ui#chapter_loc | Number:Time | The running time elapsed of the current chapter |
ui#movie_media_type | String | The type of media that is currently playing |
ui#movie_location | String | Identifies the location in the movie, ie: Main content, Intermission, or End Credits |
ui#aspect_ratio | String | Identifies the aspect ratio of the movie |
ui#video_mode | String | Raw output of video mode data from the component, format: 00:00:00 |
ui#video_mode_composite | String | Identifies the video mode currently active on the composite video output |
ui#video_mode_component | String | Identifies the video mode currently active on the component video output |
ui#video_mode_hdmi | String | Identifies the video mode currently active on the HDMI video output |
ui#video_color | String | Provides color information about the current video output (Strato Only) |
ui#video_color_eotf | String | Identifies the Electro-Optical Transfer Function standard of the current video output (Strato Only) |
ui#content_color | String | Provides color information about the currently playing content (Strato Only) |
ui#content_color_eotf | String | Identifies the Electro-Optical Transfer Function standard of the currently playing content (Strato Only) |
ui#scale_mode | String | Identifies whether the image from the player requires scaling |
ui#screen_mask | String | Provides aspect ratio and masking information for the current video image |
ui#screen_mask2 | String | Provides masking information based on aspect ratio and overscan area |
ui#cinemascape_mask | String | When in CinemaScape mode, provides information about the frame aspect ratio |
ui#cinemascape_mode | String | Identifies the CinemaScape mode currently active |
ui#ui_state | String | Provides information about which screen is visible in the Kaleidescape user interface |
ui#child_mode_state | String | Indicates if the onscreen display is displaying the child user interface |
ui#readiness_state | String | Indicates the system's current idle mode (Not available on Premiere system players) |
ui#highlighted_selection | String | Specifies the handle of the movie or album currently selected on the user interface |
ui#user_defined_event | String | Will contain custom event messages generated by scripts, sent from another component, or system events |
ui#user_input | String | Indicates if the user is being prompted for input, what type of input, and any currently entered characters |
ui#user_input_prompt | String | Indicates user input prompt info and properties currently shown on screen |
ui#sendcmd | String | Sends a raw command to the Kaleidescape player (WriteOnly) |
-- music channels (not available on Alto and Strato) -- | ||
music#control | Player | Control Music Playback e.g. play/pause/next/previous/ffward/rewind |
music#repeat | Switch | Controls repeat playback for music |
music#random | Switch | Controls random playback for music |
music#track | String | The name of the currently playing track |
music#artist | String | The name of the currently playing artist |
music#album | String | The name of the currently playing album |
music#title | String | The raw output from the MUSIC_TITLE api response for use in rules that require track, artist and album changes in one update |
music#play_mode | String | The current playback mode of the music |
music#play_speed | String | The speed of playback scanning |
music#track_length | Number:Time | The total running time of the current playing track (seconds) |
music#track_position | Number:Time | The running time elapsed of the current playing track (seconds) |
music#track_progress | Number | The percentage complete of the current playing track |
music#track_handle | String | The handle of the currently playing track |
music#album_handle | String | The handle of the currently playing album |
music#nowplay_handle | String | The handle of the current now playing list |
-- metadata display channels (music related channels not available on Alto and Strato) -- | ||
detail#type | String | Indicates if the currently selected item is a Movie or Album |
detail#title | String | The title of the selected movie |
detail#album_title | String | The title of the selected album |
detail#cover_art | Image | Cover art image of the currently selected item |
detail#cover_url | String | The url of the cover art |
detail#hires_cover_url | String | The url of the high resolution cover art |
detail#rating | String | The MPAA rating of the selected movie |
detail#year | String | The release year of the selected item |
detail#running_time | Number:Time | The total running time of the selected item (seconds) |
detail#actors | String | A list of actors appearing in the selected movie |
detail#artist | String | The artist of the selected album |
detail#directors | String | A list of directors of the selected movie |
detail#genres | String | A list of genres of the selected item |
detail#rating_reason | String | An explaination of why the selected movie received its rating |
detail#synopsis | String | A synopsis of the selected movie |
detail#review | String | A review of the selected album |
detail#color_description | String | Indicates if the selected movie is in Color, Black and White, etc. |
detail#country | String | The country that the selected movie originates from |
detail#aspect_ratio | String | The aspect ratio of the selected movie |
detail#disc_location | String | Indicates where the disc for the selected item is currently residing in the system (ie Vault, Tray, etc.) |
Full Example
kaleidescape.things:
kaleidescape:strato:myzone1 "Strato Theater Rm" [ host="192.168.1.10", updatePeriod=0, loadHighlightedDetails=true ]
kaleidescape:player:myzone2 "M500 Living Rm" [ host="192.168.1.11", updatePeriod=0, loadHighlightedDetails=true, loadAlbumDetails=true ]
kaleidescape:cinemaone:myzone3 "My Cinema One" [ host="192.168.1.12", updatePeriod=0, loadHighlightedDetails=true, loadAlbumDetails=true ]
kaleidescape.items:
// Virtual switch to send a command, see sitemap and rules below
Switch z1_GoMovieCovers "Go to Movie Covers"
// Movie Channels
Switch z1_Ui_Power "Power" { channel="kaleidescape:player:myzone1:ui#power" }
Dimmer z1_Ui_Volume "Volume" { channel="kaleidescape:player:myzone1:ui#volume" }
Switch z1_Ui_Mute "Mute" { channel="kaleidescape:player:myzone1:ui#mute" }
Player z1_Ui_Control "Control" { channel="kaleidescape:player:myzone1:ui#control" }
String z1_Ui_TitleName "Movie Title: [%s]" { channel="kaleidescape:player:myzone1:ui#title_name" }
String z1_Ui_PlayMode "Play Mode: [%s]" { channel="kaleidescape:player:myzone1:ui#play_mode" }
String z1_Ui_PlaySpeed "Play Speed: [%s]" { channel="kaleidescape:player:myzone1:ui#play_speed" }
Number z1_Ui_TitleNum "Title Number: [%s]" { channel="kaleidescape:player:myzone1:ui#title_num" }
Number:Time z1_Ui_TitleLength "Title Length: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:ui#title_length" }
Number:Time z1_Ui_TitleLoc "Title Location: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:ui#title_loc" }
DateTime z1_Ui_TitleEndTime "Title End Time: [%s]" { channel="kaleidescape:player:myzone1:ui#endtime" }
Number z1_Ui_ChapterNum "Chapter Number: [%s]" { channel="kaleidescape:player:myzone1:ui#chapter_num" }
Number:Time z1_Ui_ChapterLength "Chapter Length: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:ui#chapter_length" }
Number:Time z1_Ui_ChapterLoc "Chapter Location: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:ui#chapter_loc" }
String z1_Ui_MovieMediaType "Media Type: [%s]" { channel="kaleidescape:player:myzone1:ui#movie_media_type" }
String z1_Ui_MovieLocation "Movie Location: [%s]" { channel="kaleidescape:player:myzone1:ui#movie_location" }
String z1_Ui_AspectRatio "Aspect Ratio: [%s]" { channel="kaleidescape:player:myzone1:ui#aspect_ratio" }
String z1_Ui_VideoMode "Video Mode (raw): [%s]" { channel="kaleidescape:player:myzone1:ui#video_mode" }
String z1_Ui_VideoModeComposite "Video Mode (Composite): [%s]" { channel="kaleidescape:player:myzone1:ui#video_mode_composite" }
String z1_Ui_VideoModeComponent "Video Mode (Component): [%s]" { channel="kaleidescape:player:myzone1:ui#video_mode_component" }
String z1_Ui_VideoModeHdmi "Video Mode (HDMI): [%s]" { channel="kaleidescape:player:myzone1:ui#video_mode_hdmi" }
// Video Color and Content Color only available on the Strato
String z1_Ui_VideoColor "Video Color: [%s]" { channel="kaleidescape:player:myzone1:ui#video_color" }
String z1_Ui_VideoColorEotf "Video Color EOTF: [%s]" { channel="kaleidescape:player:myzone1:ui#video_color_eotf" }
String z1_Ui_ContentColor "Content Color: [%s]" { channel="kaleidescape:player:myzone1:ui#content_color" }
String z1_Ui_ContentColorEotf "Content Color EOTF: [%s]" { channel="kaleidescape:player:myzone1:ui#content_color_eotf" }
String z1_Ui_ScaleMode "Scale Mode: [%s]" { channel="kaleidescape:player:myzone1:ui#scale_mode" }
String z1_Ui_ScreenMask "Screen Mask: [%s]" { channel="kaleidescape:player:myzone1:ui#screen_mask" }
String z1_Ui_ScreenMask2 "Screen Mask 2: [%s]" { channel="kaleidescape:player:myzone1:ui#screen_mask2" }
String z1_Ui_CinemascapeMask "CinemaScape Mask: [%s]" { channel="kaleidescape:player:myzone1:ui#cinemascape_mask" }
String z1_Ui_CinemascapeMode "CinemaScape Mode: [%s]" { channel="kaleidescape:player:myzone1:ui#cinemascape_mode" }
String z1_Ui_UiState "UI State: [%s]" { channel="kaleidescape:player:myzone1:ui#ui_state" }
String z1_Ui_ChildModeState "Child Mode State: [%s]" { channel="kaleidescape:player:myzone1:ui#child_mode_state" }
String z1_Ui_ReadinessState "Readiness State: [%s]" { channel="kaleidescape:player:myzone1:ui#readiness_state" }
String z1_Ui_HighlightedSelection "Highlighted Selection: [%s]" { channel="kaleidescape:player:myzone1:ui#highlighted_selection" }
String z1_Ui_UserDefinedEvent "User Defined Event: [%s]" { channel="kaleidescape:player:myzone1:ui#user_defined_event" }
String z1_Ui_UserInput "User Input: [%s]" { channel="kaleidescape:player:myzone1:ui#user_input" }
String z1_Ui_UserInputPrompt "User Input Prompt[%s]" { channel="kaleidescape:player:myzone1:ui#user_input_prompt" }
String z1_Ui_Sendcmd "Send Command" { channel="kaleidescape:player:myzone1:ui#sendcmd" }
// Music Channels (not available on Alto or Strato)
Player z1_Music_Control "Music Control" { channel="kaleidescape:player:myzone1:music#control" }
Switch z1_Music_Repeat "Repeat" { channel="kaleidescape:player:myzone1:music#repeat" }
Switch z1_Music_Random "Random" { channel="kaleidescape:player:myzone1:music#random" }
String z1_Music_Track "Track: [%s]" { channel="kaleidescape:player:myzone1:music#track" }
String z1_Music_Artist "Artist: [%s]" { channel="kaleidescape:player:myzone1:music#artist" }
String z1_Music_Album "Album: [%s]" { channel="kaleidescape:player:myzone1:music#album" }
String z1_Music_PlayMode "Play Mode: [%s]" { channel="kaleidescape:player:myzone1:music#play_mode" }
String z1_Music_PlaySpeed "Play Speed: [%s]" { channel="kaleidescape:player:myzone1:music#play_speed" }
Number:Time z1_Music_TrackLength "Track Length: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:music#track_length" }
Number:Time z1_Music_TrackPosition "Track Position: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:music#track_position" }
Number z1_Music_TrackProgress "Track Progress: [%s %%]" { channel="kaleidescape:player:myzone1:music#track_progress" }
String z1_Music_Title "Music Title Raw: [%s]" { channel="kaleidescape:player:myzone1:music#title" }
String z1_Music_TrackHandle "Track Handle: [%s]" { channel="kaleidescape:player:myzone1:music#track_handle" }
String z1_Music_AlbumHandle "Album Handle: [%s]" { channel="kaleidescape:player:myzone1:music#album_handle" }
String z1_Music_NowplayHandle "Now Playing Handle: [%s]" { channel="kaleidescape:player:myzone1:music#nowplay_handle" }
// Metatdata Display Channels (Album Title, Artist & Review are not available on Alto or Strato)
String z1_Detail_Type "Metadata type: [%s]" { channel="kaleidescape:player:myzone1:detail#type" }
String z1_Detail_Title "Title: [%s]" { channel="kaleidescape:player:myzone1:detail#title" }
String z1_Detail_AlbumTitle "Album: [%s]" { channel="kaleidescape:player:myzone1:detail#album_title" }
Image z1_Detail_CoverArt { channel="kaleidescape:player:myzone1:detail#cover_art" }
String z1_Detail_CoverUrl "[%s]" { channel="kaleidescape:player:myzone1:detail#cover_url" }
String z1_Detail_HiresCoverUrl "[%s]" { channel="kaleidescape:player:myzone1:detail#hires_cover_url" }
String z1_Detail_Rating "Rating: [%s]" { channel="kaleidescape:player:myzone1:detail#rating" }
String z1_Detail_Year "Year: [%s]" { channel="kaleidescape:player:myzone1:detail#year" }
Number:Time z1_Detail_RunningTime "Running Time: [JS(ksecondsformat.js):%s]" { channel="kaleidescape:player:myzone1:detail#running_time" }
String z1_Detail_Actors "Actors: [%s]" { channel="kaleidescape:player:myzone1:detail#actors" }
String z1_Detail_Directors "Directors: [%s]" { channel="kaleidescape:player:myzone1:detail#directors" }
String z1_Detail_Artist "Artist: [%s]" { channel="kaleidescape:player:myzone1:detail#artist" }
String z1_Detail_Genres "Genres: [%s]" { channel="kaleidescape:player:myzone1:detail#genres" }
String z1_Detail_RatingReason "Rating Reason: [%s]" { channel="kaleidescape:player:myzone1:detail#rating_reason" }
String z1_Detail_Synopsis "Synopsis: [%s]" { channel="kaleidescape:player:myzone1:detail#synopsis" }
String z1_Detail_Review "Review: [%s]" { channel="kaleidescape:player:myzone1:detail#review" }
String z1_Detail_ColorDescription "Color Description: [%s]" { channel="kaleidescape:player:myzone1:detail#color_description" }
String z1_Detail_Country "Country: [%s]" { channel="kaleidescape:player:myzone1:detail#country" }
String z1_Detail_AspectRatio "Aspect Ratio: [%s]" { channel="kaleidescape:player:myzone1:detail#aspect_ratio" }
String z1_Detail_DiscLocation "Disc Location: [%s]" { channel="kaleidescape:player:myzone1:detail#disc_location" }
String z1_MovieSearch "Movie Search"
ksecondsformat.js:
(function(timestamp) {
var totalSeconds = Date.parse(timestamp) / 1000
if (isNaN(totalSeconds)) {
return '-';
} else {
hours = Math.floor(totalSeconds / 3600);
totalSeconds %= 3600;
minutes = Math.floor(totalSeconds / 60);
seconds = totalSeconds % 60;
if ( minutes < 10 ) {
minutes = '0' + minutes;
}
if ( seconds < 10 ) {
seconds = '0' + seconds;
}
return hours + ':' + minutes + ':' + seconds;
}
})(input)
kaleidescape.sitemap:
sitemap kaleidescape label="Kaleidescape" {
Frame label="Zone 1" {
Image item=z1_Detail_CoverArt
Text item=z1_Detail_Title visibility=[z1_Detail_Type=="movie"] icon="video"
Text item=z1_Detail_Artist visibility=[z1_Detail_Type=="album"] icon="microphone"
Text item=z1_Detail_AlbumTitle visibility=[z1_Detail_Type=="album"] icon="soundvolume-0"
Text item=z1_Detail_Rating visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Year visibility=[z1_Detail_Type=="movie", z1_Detail_Type=="album"] icon="none"
Text item=z1_Detail_RunningTime visibility=[z1_Detail_Type=="movie", z1_Detail_Type=="album"] icon="time"
Text item=z1_Detail_Actors visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Directors visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Genres visibility=[z1_Detail_Type=="movie", z1_Detail_Type=="album"] icon="none"
Text item=z1_Detail_RatingReason visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Synopsis visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Review visibility=[z1_Detail_Type=="album"] icon="none"
Text item=z1_Detail_ColorDescription visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_Country visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_AspectRatio visibility=[z1_Detail_Type=="movie"] icon="none"
Text item=z1_Detail_DiscLocation visibility=[z1_Detail_Type=="movie", z1_Detail_Type=="album"] icon="player"
Input item=z1_MovieSearch label="Movie Search" staticIcon=zoom inputHint="text"
Text label="Now Playing - Movie" icon="screen" {
Switch item=z1_Ui_Power
Slider item=z1_Ui_Volume
Switch item=z1_Ui_Mute
Default item=z1_Ui_Control
Switch item=z1_GoMovieCovers mappings=[ON="Movie Covers"]
Text item=z1_Ui_TitleName icon="video"
Text item=z1_Ui_PlayMode icon="player"
Text item=z1_Ui_PlaySpeed icon="player"
Text item=z1_Ui_TitleNum icon="video"
Text item=z1_Ui_TitleLength icon="time"
Text item=z1_Ui_TitleLoc icon="time"
Text item=z1_Ui_TitleEndTime icon="time"
Text item=z1_Ui_MovieMediaType icon="colorwheel"
Text item=z1_Ui_ChapterNum icon="video"
Text item=z1_Ui_ChapterLength icon="time"
Text item=z1_Ui_ChapterLoc icon="time"
Text item=z1_Ui_MovieLocation icon="video"
Text item=z1_Ui_AspectRatio icon="cinemascreen"
Text item=z1_Ui_VideoMode icon="screen"
Text item=z1_Ui_VideoModeComposite icon="screen"
Text item=z1_Ui_VideoModeComponent icon="screen"
Text item=z1_Ui_VideoModeHdmi icon="screen"
Text item=z1_Ui_VideoColor icon="screen"
Text item=z1_Ui_VideoColorEotf icon="screen"
Text item=z1_Ui_ContentColor icon="screen"
Text item=z1_Ui_ContentColorEotf icon="screen"
Text item=z1_Ui_ScaleMode icon="screen"
Text item=z1_Ui_ScreenMask icon="screen"
Text item=z1_Ui_ScreenMask2 icon="screen"
Text item=z1_Ui_CinemascapeMask icon="screen"
Text item=z1_Ui_CinemascapeMode icon="screen"
Text item=z1_Ui_UiState icon="player"
Text item=z1_Ui_ChildModeState icon="player"
Text item=z1_Ui_ReadinessState icon="switch"
Text item=z1_Ui_HighlightedSelection icon="zoom"
Text item=z1_Ui_UserDefinedEvent icon="zoom"
Text item=z1_Ui_UserInput icon="zoom"
Text item=z1_Ui_UserInputPrompt icon="zoom"
}
Text label="Now Playing - Music" icon="soundvolume-0" {
Switch item=z1_Ui_Power
Slider item=z1_Ui_Volume
Switch item=z1_Ui_Mute
Default item=z1_Music_Control
Switch item=z1_Music_Repeat
Switch item=z1_Music_Random
Text item=z1_Music_Track icon="soundvolume-0"
Text item=z1_Music_Artist icon="microphone"
Text item=z1_Music_Album icon="soundvolume-0"
Text item=z1_Music_PlayMode icon="player"
Text item=z1_Music_PlaySpeed icon="player"
Text item=z1_Music_TrackLength icon="time"
Text item=z1_Music_TrackPosition icon="time"
Text item=z1_Music_TrackProgress icon="time"
Text item=z1_Music_Title icon="zoom"
Text item=z1_Music_TrackHandle icon="zoom"
Text item=z1_Music_AlbumHandle icon="zoom"
Text item=z1_Music_NowplayHandle icon="zoom"
}
Buttongrid label="Kaleidescape Remote" staticIcon=material:tv_remote item=z1_Ui_Sendcmd buttons=[1:1:DETAILS="Info", 1:2:STOP="Stop"=f7:stop, 1:3:PAUSE="Pause"=f7:pause, 2:1:PREVIOUS="Previous"=f7:backward_end_alt, 2:2:PLAY="Play"=f7:play, 2:3:NEXT="Next"=f7:forward_end_alt, 3:1:SCAN_REVERSE="Reverse"=f7:backward, 3:2:KALEIDESCAPE_MENU_TOGGLE="Menu", 3:3:SCAN_FORWARD="Forward"=f7:forward, 4:1:GO_MOVIES="Movies"=f7:film, 4:3:GO_MUSIC="Music"=f7:music_note_2, 4:2:UP="Up"=f7:arrowtriangle_up, 6:2:DOWN="Down"=f7:arrowtriangle_down, 5:1:LEFT="Left"=f7:arrowtriangle_left, 5:3:RIGHT="Right"=f7:arrowtriangle_right, 5:2:SELECT="OK", 7:1:DISC_MENU="Disc Menu", 7:2:INTERMISSION_TOGGLE="Intermission", 7:3:PAGE_UP="Page Up", 8:1:SHUFFLE_COVER_ART="Shuffle", 8:2:GO_NOW_PLAYING="Now Playing", 8:3:PAGE_DOWN="Page Down", 9:1:"KEYBOARD_CHARACTER:1"="1", 9:2:"KEYBOARD_CHARACTER:2"="2", 9:3:"KEYBOARD_CHARACTER:3"="3", 10:1:"KEYBOARD_CHARACTER:4"="4", 10:2:"KEYBOARD_CHARACTER:5"="5", 10:3:"KEYBOARD_CHARACTER:6"="6", 11:1:"KEYBOARD_CHARACTER:7"="7", 11:2:"KEYBOARD_CHARACTER:8"="8", 11:3:"KEYBOARD_CHARACTER:9"="9", 12:1:CANCEL="Cancel", 12:2:"KEYBOARD_CHARACTER:0"="0", 12:3:SELECT="Enter", 13:1:RED="Red", 13:2:GREEN="Green", 13:3:BLUE="Blue", 14:2:YELLOW="Yellow"]
}
}
kaleidescape.rules:
var int lightPercent
// send command to go to movie covers when button pressed
rule "Go to Movie Covers"
when
Item z1_GoMovieCovers received command
then
z1_Ui_Sendcmd.sendCommand("GO_MOVIE_COVERS")
end
// send command to play a script
rule "Play Script - Great Vistas"
when
Item z1_PlayScript received command
then
z1_Ui_Sendcmd.sendCommand("PLAY_SCRIPT:Great Vistas")
end
// handle volume events from K apps or IR remote
// the events can be used to send a command to another item that controls volume
rule "Handle volume events"
when
Item z1_Ui_UserDefinedEvent received update
then
var volEvt = newState.toString()
// When `volumeBasicEnabled` is true for the thing, VOLUME_UP, VOLUME_DOWN and TOGGLE_MUTE are received from the iPad and phone apps
// VOLUME_UP_PRESS/RELEASE, VOLUME_DOWN_PRESS/RELEASE, TOGGLE_MUTE events will always be received from the IR remote
// *RELEASE events are not used in this example
if (volEvt == "VOLUME_UP" || volEvt == "VOLUME_UP_PRESS") {
logInfo("k rules", "Volumne Up received")
}
if (volEvt == "VOLUME_DOWN" || volEvt == "VOLUME_DOWN_PRESS") {
logInfo("k rules", "Volumne Down received")
}
if (volEvt == "TOGGLE_MUTE") {
logInfo("k rules", "Mute Toggle received")
}
end
// handle a control system command sent from a kaleidescape script
// the command string is specified in a "Send command to control system" script step
rule "Handle script commands"
when
Item z1_Ui_UserDefinedEvent received update
then
if (z1_Ui_UserDefinedEvent.state.toString == "DO_THE_NEEDFUL") {
logInfo("k rules", "handing the NEEDFUL script command...")
}
end
rule "Bring up Lights when movie is over"
when
Item z1_Ui_MovieLocation changed from "Main content" to "End Credits"
then
// fade the lights up slowly while the credits are rolling
lightPercent = 0
while (lightPercent < 100) {
lightPercent = lightPercent + 5
logInfo("k rules", "lights at " + lightPercent.toString + " percent")
// myLightItem.sendCommand(lightPercent)
Thread::sleep(5000)
}
end
rule "Bring up Lights at 20 percent during intermission"
when
Item z1_Ui_MovieLocation changed from "Main content" to "Intermission"
then
// myLightItem.sendCommand(20)
logInfo("k rules", "intermission started")
end
rule "Turn lights back off when intermission over"
when
Item z1_Ui_MovieLocation changed from "Intermission" to "Main content"
then
// myLightItem.sendCommand(OFF)
logInfo("k rules", "intermission over")
end
rule "Movie Search"
when
Item z1_MovieSearch received update
then
if (newState != NULL && newState.toString.length > 0) {
z1_Ui_Sendcmd.sendCommand("GO_MOVIE_LIST")
Thread::sleep(1000)
z1_Ui_Sendcmd.sendCommand("FILTER_LIST")
Thread::sleep(300)
var i = 0
var srch = newState.toString.toUpperCase
logInfo("k rules","Searching for: " + srch)
while (i < (srch.length)) {
z1_Ui_Sendcmd.sendCommand("KEYBOARD_CHARACTER:" + srch.charAt(i).toString)
Thread::sleep(100)
i++
}
}
end
// The following are no longer required since the thing configuration will enable automatic loading of metatdata.
// However the examples are still valid for advanced use cases where retrieving metadata from an arbitrary content handle is desired.
rule "Load selected item Metadata"
when
Item z1_Ui_HighlightedSelection changed
then
z1_Ui_Sendcmd.sendCommand("GET_CONTENT_DETAILS:" + z1_Ui_HighlightedSelection.state.toString + ":")
end
rule "Load Metadata for currently playing album"
when
Item z1_Music_AlbumHandle changed
then
z1_Ui_Sendcmd.sendCommand("GET_CONTENT_DETAILS:" + z1_Music_AlbumHandle.state.toString + ":")
end