[nuvo] Add favorites selection channel and fix a few bugs (#8631)
* Fix issue with All Mute and extra source options * Add channel to select preset favorite Signed-off-by: Michael Lobstein <michael.lobstein@gmail.com>pull/8635/head
parent
003c3af985
commit
4c6d63df38
|
@ -70,6 +70,7 @@ The following channels are available:
|
||||||
| zoneN#source (where N= 1-20) | Number | Select the source input for a zone (1-6) |
|
| zoneN#source (where N= 1-20) | Number | Select the source input for a zone (1-6) |
|
||||||
| zoneN#volume (where N= 1-20) | Dimmer | Control the volume for a zone (0-100%) [translates to 0-79] |
|
| zoneN#volume (where N= 1-20) | Dimmer | Control the volume for a zone (0-100%) [translates to 0-79] |
|
||||||
| zoneN#mute (where N= 1-20) | Switch | Mute or unmute a zone |
|
| zoneN#mute (where N= 1-20) | Switch | Mute or unmute a zone |
|
||||||
|
| zoneN#favorite (where N= 1-20) | Number | Select a preset Favorite for a zone (1-12) |
|
||||||
| zoneN#control (where N= 1-20) | Player | Simulate pressing the transport control buttons on the keypad e.g. play/pause/next/previous |
|
| zoneN#control (where N= 1-20) | Player | Simulate pressing the transport control buttons on the keypad e.g. play/pause/next/previous |
|
||||||
| zoneN#treble (where N= 1-20) | Number | Adjust the treble control for a zone (-18 to 18 [in increments of 2]) -18=none, 0=flat, 18=full |
|
| zoneN#treble (where N= 1-20) | Number | Adjust the treble control for a zone (-18 to 18 [in increments of 2]) -18=none, 0=flat, 18=full |
|
||||||
| zoneN#bass (where N= 1-20) | Number | Adjust the bass control for a zone (-18 to 18 [in increments of 2]) -18=none, 0=flat, 18=full |
|
| zoneN#bass (where N= 1-20) | Number | Adjust the bass control for a zone (-18 to 18 [in increments of 2]) -18=none, 0=flat, 18=full |
|
||||||
|
@ -113,6 +114,7 @@ Switch nuvo_z1_power "Power" { channel="nuvo:amplifier:myamp:zone1#power" }
|
||||||
Number nuvo_z1_source "Source Input [%s]" { channel="nuvo:amplifier:myamp:zone1#source" }
|
Number nuvo_z1_source "Source Input [%s]" { channel="nuvo:amplifier:myamp:zone1#source" }
|
||||||
Dimmer nuvo_z1_volume "Volume [%d %%]" { channel="nuvo:amplifier:myamp:zone1#volume" }
|
Dimmer nuvo_z1_volume "Volume [%d %%]" { channel="nuvo:amplifier:myamp:zone1#volume" }
|
||||||
Switch nuvo_z1_mute "Mute" { channel="nuvo:amplifier:myamp:zone1#mute" }
|
Switch nuvo_z1_mute "Mute" { channel="nuvo:amplifier:myamp:zone1#mute" }
|
||||||
|
Number nuvo_z1_favorite "Favorite" { channel="nuvo:amplifier:myamp:zone1#favorite" }
|
||||||
Player nuvo_z1_control "Control" { channel="nuvo:amplifier:myamp:zone1#control" }
|
Player nuvo_z1_control "Control" { channel="nuvo:amplifier:myamp:zone1#control" }
|
||||||
Number nuvo_z1_treble "Treble Adjustment [%s]" { channel="nuvo:amplifier:myamp:zone1#treble" }
|
Number nuvo_z1_treble "Treble Adjustment [%s]" { channel="nuvo:amplifier:myamp:zone1#treble" }
|
||||||
Number nuvo_z1_bass "Bass Adjustment [%s]" { channel="nuvo:amplifier:myamp:zone1#bass" }
|
Number nuvo_z1_bass "Bass Adjustment [%s]" { channel="nuvo:amplifier:myamp:zone1#bass" }
|
||||||
|
@ -197,6 +199,8 @@ sitemap nuvo label="Audio Control" {
|
||||||
//Volume can be a Setpoint also
|
//Volume can be a Setpoint also
|
||||||
Slider item=nuvo_z1_volume minValue=0 maxValue=100 step=1 visibility=[nuvo_z1_power==ON] icon="soundvolume"
|
Slider item=nuvo_z1_volume minValue=0 maxValue=100 step=1 visibility=[nuvo_z1_power==ON] icon="soundvolume"
|
||||||
Switch item=nuvo_z1_mute visibility=[nuvo_z1_power==ON] icon="soundvolume_mute"
|
Switch item=nuvo_z1_mute visibility=[nuvo_z1_power==ON] icon="soundvolume_mute"
|
||||||
|
// mappings is optional to override the default dropdown item labels
|
||||||
|
Selection item=nuvo_z1_favorite visibility=[nuvo_z1_power==ON] icon="player" //mappings=[1="WNYC", 2="BBC One", 2="My Playlist"]
|
||||||
Default item=nuvo_z1_control visibility=[nuvo_z1_power==ON]
|
Default item=nuvo_z1_control visibility=[nuvo_z1_power==ON]
|
||||||
|
|
||||||
Text item=nuvo_s1_display_line1 visibility=[nuvo_z1_source=="1"] icon="zoom"
|
Text item=nuvo_s1_display_line1 visibility=[nuvo_z1_source=="1"] icon="zoom"
|
||||||
|
@ -253,13 +257,15 @@ sitemap nuvo label="Audio Control" {
|
||||||
Text item=nuvo_s6_track_position visibility=[nuvo_z1_source=="6"]
|
Text item=nuvo_s6_track_position visibility=[nuvo_z1_source=="6"]
|
||||||
Text item=nuvo_s6_button_press visibility=[nuvo_z1_source=="6"] icon="none"
|
Text item=nuvo_s6_button_press visibility=[nuvo_z1_source=="6"] icon="none"
|
||||||
|
|
||||||
Setpoint item=nuvo_z1_treble label="Treble Adjustment [%d]" minValue=-18 maxValue=18 step=2 visibility=[nuvo_z1_power==ON]
|
Text label="Advanced" icon="settings" visibility=[nuvo_z1_power==ON] {
|
||||||
Setpoint item=nuvo_z1_bass label="Bass Adjustment [%d]" minValue=-18 maxValue=18 step=2 visibility=[nuvo_z1_power==ON]
|
Setpoint item=nuvo_z1_treble label="Treble Adjustment [%d]" minValue=-18 maxValue=18 step=2
|
||||||
Setpoint item=nuvo_z1_balance label="Balance Adjustment [%d]" minValue=-18 maxValue=18 step=2 visibility=[nuvo_z1_power==ON]
|
Setpoint item=nuvo_z1_bass label="Bass Adjustment [%d]" minValue=-18 maxValue=18 step=2
|
||||||
Switch item=nuvo_z1_loudness visibility=[nuvo_z1_power==ON]
|
Setpoint item=nuvo_z1_balance label="Balance Adjustment [%d]" minValue=-18 maxValue=18 step=2
|
||||||
Switch item=nuvo_z1_dnd visibility=[nuvo_z1_power==ON]
|
Switch item=nuvo_z1_loudness
|
||||||
Text item=nuvo_z1_lock label="Zone Locked: [%s]" icon="lock"
|
Switch item=nuvo_z1_dnd
|
||||||
Switch item=nuvo_z1_party visibility=[nuvo_z1_power==ON]
|
Switch item=nuvo_z1_party
|
||||||
|
}
|
||||||
|
Text item=nuvo_z1_lock label="Zone Locked: [%s]" icon="lock" visibility=[nuvo_z1_lock=="1"]
|
||||||
}
|
}
|
||||||
|
|
||||||
//repeat for zones 2-20 (substitute z1)
|
//repeat for zones 2-20 (substitute z1)
|
||||||
|
@ -294,9 +300,6 @@ then
|
||||||
// Send a message to Zone 11
|
// Send a message to Zone 11
|
||||||
//actions.sendNuvoCommand("Z11MSG\"Hello World\",0,0")
|
//actions.sendNuvoCommand("Z11MSG\"Hello World\",0,0")
|
||||||
|
|
||||||
// Select a Favorite (1-12) for Zone 2
|
|
||||||
//actions.sendNuvoCommand("Z2FAV1")
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
// In the below examples, a method for maintaing Metadata information
|
// In the below examples, a method for maintaing Metadata information
|
||||||
|
|
|
@ -39,6 +39,7 @@ public class NuvoBindingConstants {
|
||||||
// zone
|
// zone
|
||||||
public static final String CHANNEL_TYPE_POWER = "power";
|
public static final String CHANNEL_TYPE_POWER = "power";
|
||||||
public static final String CHANNEL_TYPE_SOURCE = "source";
|
public static final String CHANNEL_TYPE_SOURCE = "source";
|
||||||
|
public static final String CHANNEL_TYPE_FAVORITE = "favorite";
|
||||||
public static final String CHANNEL_TYPE_VOLUME = "volume";
|
public static final String CHANNEL_TYPE_VOLUME = "volume";
|
||||||
public static final String CHANNEL_TYPE_MUTE = "mute";
|
public static final String CHANNEL_TYPE_MUTE = "mute";
|
||||||
public static final String CHANNEL_TYPE_CONTROL = "control";
|
public static final String CHANNEL_TYPE_CONTROL = "control";
|
||||||
|
|
|
@ -40,6 +40,7 @@ public enum NuvoCommand {
|
||||||
ON("ON"),
|
ON("ON"),
|
||||||
OFF("OFF"),
|
OFF("OFF"),
|
||||||
SOURCE("SRC"),
|
SOURCE("SRC"),
|
||||||
|
FAVORITE("FAV"),
|
||||||
VOLUME("VOL"),
|
VOLUME("VOL"),
|
||||||
MUTE_ON("MUTEON"),
|
MUTE_ON("MUTEON"),
|
||||||
MUTE_OFF("MUTEOFF"),
|
MUTE_OFF("MUTEOFF"),
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.TreeMap;
|
||||||
import java.util.concurrent.ScheduledFuture;
|
import java.util.concurrent.ScheduledFuture;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
|
@ -98,6 +99,7 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
|
|
||||||
private static final int MAX_ZONES = 20;
|
private static final int MAX_ZONES = 20;
|
||||||
private static final int MAX_SRC = 6;
|
private static final int MAX_SRC = 6;
|
||||||
|
private static final int MAX_FAV = 12;
|
||||||
private static final int MIN_VOLUME = 0;
|
private static final int MIN_VOLUME = 0;
|
||||||
private static final int MAX_VOLUME = 79;
|
private static final int MAX_VOLUME = 79;
|
||||||
private static final int MIN_EQ = -18;
|
private static final int MIN_EQ = -18;
|
||||||
|
@ -129,8 +131,8 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
|
|
||||||
Set<Integer> activeZones = new HashSet<>(1);
|
Set<Integer> activeZones = new HashSet<>(1);
|
||||||
|
|
||||||
// A state option list for the source labels
|
// A tree map that maps the source ids to source labels
|
||||||
List<StateOption> sourceLabels = new ArrayList<>();
|
TreeMap<String, String> sourceLabels = new TreeMap<String, String>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
|
@ -274,6 +276,15 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CHANNEL_TYPE_FAVORITE:
|
||||||
|
if (command instanceof DecimalType) {
|
||||||
|
int value = ((DecimalType) command).intValue();
|
||||||
|
if (value >= 1 && value <= MAX_FAV) {
|
||||||
|
logger.debug("Got favorite command {} zone {}", value, target);
|
||||||
|
connector.sendCommand(target, NuvoCommand.FAVORITE, String.valueOf(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
case CHANNEL_TYPE_VOLUME:
|
case CHANNEL_TYPE_VOLUME:
|
||||||
if (command instanceof PercentType) {
|
if (command instanceof PercentType) {
|
||||||
int value = (MAX_VOLUME
|
int value = (MAX_VOLUME
|
||||||
|
@ -373,14 +384,13 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
break;
|
break;
|
||||||
case CHANNEL_TYPE_ALLMUTE:
|
case CHANNEL_TYPE_ALLMUTE:
|
||||||
if (command instanceof OnOffType) {
|
if (command instanceof OnOffType) {
|
||||||
connector.sendCommand(target,
|
connector.sendCommand(
|
||||||
command == OnOffType.ON ? NuvoCommand.ALLMUTE_ON : NuvoCommand.ALLMUTE_OFF);
|
command == OnOffType.ON ? NuvoCommand.ALLMUTE_ON : NuvoCommand.ALLMUTE_OFF);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CHANNEL_TYPE_PAGE:
|
case CHANNEL_TYPE_PAGE:
|
||||||
if (command instanceof OnOffType) {
|
if (command instanceof OnOffType) {
|
||||||
connector.sendCommand(target,
|
connector.sendCommand(command == OnOffType.ON ? NuvoCommand.PAGE_ON : NuvoCommand.PAGE_OFF);
|
||||||
command == OnOffType.ON ? NuvoCommand.PAGE_ON : NuvoCommand.PAGE_OFF);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -484,10 +494,10 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
} else {
|
} else {
|
||||||
logger.debug("no match on message: {}", updateData);
|
logger.debug("no match on message: {}", updateData);
|
||||||
}
|
}
|
||||||
} else if (updateData.contains(NAME_QUOTE) && sourceLabels.size() <= MAX_SRC) {
|
} else if (updateData.contains(NAME_QUOTE)) {
|
||||||
// example: NAME"Ipod"
|
// example: NAME"Ipod"
|
||||||
String name = updateData.split("\"")[1];
|
String name = updateData.split("\"")[1];
|
||||||
sourceLabels.add(new StateOption(key, name));
|
sourceLabels.put(key, name);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case TYPE_ZONE_UPDATE:
|
case TYPE_ZONE_UPDATE:
|
||||||
|
@ -594,11 +604,16 @@ public class NuvoHandler extends BaseThingHandler implements NuvoMessageEventLis
|
||||||
if (prevUpdateTime == lastEventReceived) {
|
if (prevUpdateTime == lastEventReceived) {
|
||||||
error = "Controller not responding to status requests";
|
error = "Controller not responding to status requests";
|
||||||
} else {
|
} else {
|
||||||
|
List<StateOption> sourceStateOptions = new ArrayList<>();
|
||||||
|
sourceLabels.keySet().forEach(key -> {
|
||||||
|
sourceStateOptions.add(new StateOption(key, sourceLabels.get(key)));
|
||||||
|
});
|
||||||
|
|
||||||
// Put the source labels on all active zones
|
// Put the source labels on all active zones
|
||||||
activeZones.forEach(zoneNum -> {
|
activeZones.forEach(zoneNum -> {
|
||||||
stateDescriptionProvider.setStateOptions(new ChannelUID(getThing().getUID(),
|
stateDescriptionProvider.setStateOptions(new ChannelUID(getThing().getUID(),
|
||||||
ZONE.toLowerCase() + zoneNum + CHANNEL_DELIMIT + CHANNEL_TYPE_SOURCE),
|
ZONE.toLowerCase() + zoneNum + CHANNEL_DELIMIT + CHANNEL_TYPE_SOURCE),
|
||||||
sourceLabels);
|
sourceStateOptions);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} catch (NuvoException e) {
|
} catch (NuvoException e) {
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
<!-- Nuvo Whole House Amplifier Thing -->
|
<!-- Nuvo Whole House Amplifier Thing -->
|
||||||
<thing-type id="amplifier">
|
<thing-type id="amplifier">
|
||||||
<label>Whole House Amplifier</label>
|
<label>Nuvo Whole House Amplifier</label>
|
||||||
<description>
|
<description>
|
||||||
A Multi-zone Whole House Amplifier System
|
A Multi-zone Whole House Amplifier System
|
||||||
</description>
|
</description>
|
||||||
|
@ -96,27 +96,27 @@
|
||||||
<label>Zone 20</label>
|
<label>Zone 20</label>
|
||||||
<description>The Controls for Zone 20</description>
|
<description>The Controls for Zone 20</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source1" typeId="source">
|
<channel-group id="source1" typeId="source_info">
|
||||||
<label>Source 1</label>
|
<label>Source 1</label>
|
||||||
<description>The Display Information for Source 1</description>
|
<description>The Display Information for Source 1</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source2" typeId="source">
|
<channel-group id="source2" typeId="source_info">
|
||||||
<label>Source 2</label>
|
<label>Source 2</label>
|
||||||
<description>The Display Information for Source 2</description>
|
<description>The Display Information for Source 2</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source3" typeId="source">
|
<channel-group id="source3" typeId="source_info">
|
||||||
<label>Source 3</label>
|
<label>Source 3</label>
|
||||||
<description>The Display Information for Source 3</description>
|
<description>The Display Information for Source 3</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source4" typeId="source">
|
<channel-group id="source4" typeId="source_info">
|
||||||
<label>Source 4</label>
|
<label>Source 4</label>
|
||||||
<description>The Display Information for Source 4</description>
|
<description>The Display Information for Source 4</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source5" typeId="source">
|
<channel-group id="source5" typeId="source_info">
|
||||||
<label>Source 5</label>
|
<label>Source 5</label>
|
||||||
<description>The Display Information for Source 5</description>
|
<description>The Display Information for Source 5</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
<channel-group id="source6" typeId="source">
|
<channel-group id="source6" typeId="source_info">
|
||||||
<label>Source 6</label>
|
<label>Source 6</label>
|
||||||
<description>The Display Information for Source 6</description>
|
<description>The Display Information for Source 6</description>
|
||||||
</channel-group>
|
</channel-group>
|
||||||
|
@ -169,6 +169,7 @@
|
||||||
<channels>
|
<channels>
|
||||||
<channel id="power" typeId="system.power"/>
|
<channel id="power" typeId="system.power"/>
|
||||||
<channel id="source" typeId="source"/>
|
<channel id="source" typeId="source"/>
|
||||||
|
<channel id="favorite" typeId="favorite"/>
|
||||||
<channel id="volume" typeId="system.volume"/>
|
<channel id="volume" typeId="system.volume"/>
|
||||||
<channel id="mute" typeId="system.mute"/>
|
<channel id="mute" typeId="system.mute"/>
|
||||||
<channel id="control" typeId="control"/>
|
<channel id="control" typeId="control"/>
|
||||||
|
@ -182,7 +183,7 @@
|
||||||
</channels>
|
</channels>
|
||||||
</channel-group-type>
|
</channel-group-type>
|
||||||
|
|
||||||
<channel-group-type id="source">
|
<channel-group-type id="source_info">
|
||||||
<label>Source Info</label>
|
<label>Source Info</label>
|
||||||
<description>The Display Information for the Source</description>
|
<description>The Display Information for the Source</description>
|
||||||
<channels>
|
<channels>
|
||||||
|
@ -215,6 +216,28 @@
|
||||||
<description>Select the Source Input for the Zone</description>
|
<description>Select the Source Input for the Zone</description>
|
||||||
</channel-type>
|
</channel-type>
|
||||||
|
|
||||||
|
<channel-type id="favorite">
|
||||||
|
<item-type>Number</item-type>
|
||||||
|
<label>Favorite</label>
|
||||||
|
<description>Select a Preset Favorite for the Zone</description>
|
||||||
|
<state>
|
||||||
|
<options>
|
||||||
|
<option value="1">Favorite 1</option>
|
||||||
|
<option value="2">Favorite 2</option>
|
||||||
|
<option value="3">Favorite 3</option>
|
||||||
|
<option value="4">Favorite 4</option>
|
||||||
|
<option value="5">Favorite 5</option>
|
||||||
|
<option value="6">Favorite 6</option>
|
||||||
|
<option value="7">Favorite 7</option>
|
||||||
|
<option value="8">Favorite 8</option>
|
||||||
|
<option value="9">Favorite 9</option>
|
||||||
|
<option value="10">Favorite 10</option>
|
||||||
|
<option value="11">Favorite 11</option>
|
||||||
|
<option value="12">Favorite 12</option>
|
||||||
|
</options>
|
||||||
|
</state>
|
||||||
|
</channel-type>
|
||||||
|
|
||||||
<channel-type id="control">
|
<channel-type id="control">
|
||||||
<item-type>Player</item-type>
|
<item-type>Player</item-type>
|
||||||
<label>Control</label>
|
<label>Control</label>
|
||||||
|
|
Loading…
Reference in New Issue