mirror of
https://github.com/PepperDash/Essentials.git
synced 2026-02-16 13:15:03 +00:00
Merge pull request #137 from PepperDash/feature/Add_DM-RMC-4K-Z-100-C
resolves #135 - Add new controller class for DM-RMC-4K-Z-100-C
This commit is contained in:
@@ -0,0 +1,79 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using Crestron.SimplSharp;
|
||||||
|
using Crestron.SimplSharpPro;
|
||||||
|
using Crestron.SimplSharpPro.DeviceSupport;
|
||||||
|
using Crestron.SimplSharpPro.DM;
|
||||||
|
using Crestron.SimplSharpPro.DM.Endpoints;
|
||||||
|
using Crestron.SimplSharpPro.DM.Endpoints.Receivers;
|
||||||
|
|
||||||
|
using PepperDash.Essentials.Core;
|
||||||
|
using PepperDash.Essentials.Core.Bridges;
|
||||||
|
|
||||||
|
namespace PepperDash.Essentials.DM
|
||||||
|
{
|
||||||
|
public class DmRmc4kZ100CController : DmRmcX100CController
|
||||||
|
{
|
||||||
|
private readonly DmRmc4kz100C _rmc;
|
||||||
|
|
||||||
|
public DmRmc4kZ100CController(string key, string name, DmRmc4kz100C rmc)
|
||||||
|
: base(key, name, rmc)
|
||||||
|
{
|
||||||
|
_rmc = rmc;
|
||||||
|
|
||||||
|
/* removed this logic because it's done in the base constructor and doesn't need to be duplicated here
|
||||||
|
DmIn = new RoutingInputPort(DmPortName.DmIn, eRoutingSignalType.Audio | eRoutingSignalType.Video,
|
||||||
|
eRoutingPortConnectionType.DmCat, 0, this);
|
||||||
|
HdmiOut = new RoutingOutputPort(DmPortName.HdmiOut, eRoutingSignalType.Audio | eRoutingSignalType.Video,
|
||||||
|
eRoutingPortConnectionType.Hdmi, null, this) {Port = _rmc};
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Set Ports for CEC
|
||||||
|
|
||||||
|
//TODO: We need to look at this class inheritance design...not so sure these properties need to be virtual and/or abstract.
|
||||||
|
EdidManufacturerFeedback = new StringFeedback(() => _rmc.HdmiOutput.ConnectedDevice.Manufacturer.StringValue);
|
||||||
|
EdidNameFeedback = new StringFeedback(() => _rmc.HdmiOutput.ConnectedDevice.Name.StringValue);
|
||||||
|
EdidPreferredTimingFeedback = new StringFeedback(() => _rmc.HdmiOutput.ConnectedDevice.PreferredTiming.StringValue);
|
||||||
|
EdidSerialNumberFeedback = new StringFeedback(() => _rmc.HdmiOutput.ConnectedDevice.SerialNumber.StringValue);
|
||||||
|
|
||||||
|
_rmc.HdmiOutput.OutputStreamChange += HdmiOutput_OutputStreamChange;
|
||||||
|
_rmc.HdmiOutput.ConnectedDevice.DeviceInformationChange += ConnectedDevice_DeviceInformationChange;
|
||||||
|
}
|
||||||
|
|
||||||
|
void HdmiOutput_OutputStreamChange(EndpointOutputStream outputStream, EndpointOutputStreamEventArgs args)
|
||||||
|
{
|
||||||
|
if (args.EventId == EndpointOutputStreamEventIds.HorizontalResolutionFeedbackEventId || args.EventId == EndpointOutputStreamEventIds.VerticalResolutionFeedbackEventId ||
|
||||||
|
args.EventId == EndpointOutputStreamEventIds.FramesPerSecondFeedbackEventId)
|
||||||
|
{
|
||||||
|
VideoOutputResolutionFeedback.FireUpdate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConnectedDevice_DeviceInformationChange(ConnectedDeviceInformation connectedDevice, ConnectedDeviceEventArgs args)
|
||||||
|
{
|
||||||
|
if (args.EventId == ConnectedDeviceEventIds.ManufacturerEventId)
|
||||||
|
{
|
||||||
|
EdidManufacturerFeedback.FireUpdate();
|
||||||
|
}
|
||||||
|
else if (args.EventId == ConnectedDeviceEventIds.NameEventId)
|
||||||
|
{
|
||||||
|
EdidNameFeedback.FireUpdate();
|
||||||
|
}
|
||||||
|
else if (args.EventId == ConnectedDeviceEventIds.PreferredTimingEventId)
|
||||||
|
{
|
||||||
|
EdidPreferredTimingFeedback.FireUpdate();
|
||||||
|
}
|
||||||
|
else if (args.EventId == ConnectedDeviceEventIds.SerialNumberEventId)
|
||||||
|
{
|
||||||
|
EdidSerialNumberFeedback.FireUpdate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void LinkToApi(BasicTriList trilist, uint joinStart, string joinMapKey, EiscApiAdvanced bridge)
|
||||||
|
{
|
||||||
|
LinkDmRmcToApi(this, trilist, joinStart, joinMapKey, bridge);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,7 +26,7 @@ namespace PepperDash.Essentials.DM
|
|||||||
public virtual StringFeedback EdidPreferredTimingFeedback { get; protected set; }
|
public virtual StringFeedback EdidPreferredTimingFeedback { get; protected set; }
|
||||||
public virtual StringFeedback EdidSerialNumberFeedback { get; protected set; }
|
public virtual StringFeedback EdidSerialNumberFeedback { get; protected set; }
|
||||||
|
|
||||||
public DmRmcControllerBase(string key, string name, EndpointReceiverBase device)
|
protected DmRmcControllerBase(string key, string name, EndpointReceiverBase device)
|
||||||
: base(key, name, device)
|
: base(key, name, device)
|
||||||
{
|
{
|
||||||
// if wired to a chassis, skip registration step in base class
|
// if wired to a chassis, skip registration step in base class
|
||||||
@@ -157,7 +157,7 @@ namespace PepperDash.Essentials.DM
|
|||||||
if (typeName.StartsWith("dmrmc4k100c"))
|
if (typeName.StartsWith("dmrmc4k100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4k100C(ipid, Global.ControlSystem));
|
return new DmRmcX100CController(key, name, new DmRmc4k100C(ipid, Global.ControlSystem));
|
||||||
if (typeName.StartsWith("dmrmc4kz100c"))
|
if (typeName.StartsWith("dmrmc4kz100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4kz100C(ipid, Global.ControlSystem));
|
return new DmRmc4kZ100CController(key, name, new DmRmc4kz100C(ipid, Global.ControlSystem));
|
||||||
if (typeName.StartsWith("dmrmc150s"))
|
if (typeName.StartsWith("dmrmc150s"))
|
||||||
return new DmRmc150SController(key, name, new DmRmc150S(ipid, Global.ControlSystem));
|
return new DmRmc150SController(key, name, new DmRmc150S(ipid, Global.ControlSystem));
|
||||||
if (typeName.StartsWith("dmrmc200c"))
|
if (typeName.StartsWith("dmrmc200c"))
|
||||||
@@ -232,7 +232,7 @@ namespace PepperDash.Essentials.DM
|
|||||||
if (typeName.StartsWith("dmrmc4k100c"))
|
if (typeName.StartsWith("dmrmc4k100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4k100C(chassis.Outputs[num]));
|
return new DmRmcX100CController(key, name, new DmRmc4k100C(chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc4kz100c"))
|
if (typeName.StartsWith("dmrmc4kz100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4kz100C(chassis.Outputs[num]));
|
return new DmRmc4kZ100CController(key, name, new DmRmc4kz100C(chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc150s"))
|
if (typeName.StartsWith("dmrmc150s"))
|
||||||
return new DmRmc150SController(key, name, new DmRmc150S(chassis.Outputs[num]));
|
return new DmRmc150SController(key, name, new DmRmc150S(chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc200c"))
|
if (typeName.StartsWith("dmrmc200c"))
|
||||||
@@ -267,7 +267,7 @@ namespace PepperDash.Essentials.DM
|
|||||||
if (typeName.StartsWith("dmrmc4k100c"))
|
if (typeName.StartsWith("dmrmc4k100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4k100C(ipid, chassis.Outputs[num]));
|
return new DmRmcX100CController(key, name, new DmRmc4k100C(ipid, chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc4kz100c"))
|
if (typeName.StartsWith("dmrmc4kz100c"))
|
||||||
return new DmRmcX100CController(key, name, new DmRmc4kz100C(ipid, chassis.Outputs[num]));
|
return new DmRmc4kZ100CController(key, name, new DmRmc4kz100C(ipid, chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc150s"))
|
if (typeName.StartsWith("dmrmc150s"))
|
||||||
return new DmRmc150SController(key, name, new DmRmc150S(ipid, chassis.Outputs[num]));
|
return new DmRmc150SController(key, name, new DmRmc150S(ipid, chassis.Outputs[num]));
|
||||||
if (typeName.StartsWith("dmrmc200c"))
|
if (typeName.StartsWith("dmrmc200c"))
|
||||||
@@ -307,7 +307,7 @@ namespace PepperDash.Essentials.DM
|
|||||||
{
|
{
|
||||||
TypeNames = new List<string>() { "hdbasetrx", "dmrmc4k100c1g", "dmrmc100c", "dmrmc100s", "dmrmc4k100c", "dmrmc150s",
|
TypeNames = new List<string>() { "hdbasetrx", "dmrmc4k100c1g", "dmrmc100c", "dmrmc100s", "dmrmc4k100c", "dmrmc150s",
|
||||||
"dmrmc200c", "dmrmc200s", "dmrmc200s2", "dmrmcscalerc", "dmrmcscalers", "dmrmcscalers2", "dmrmc4kscalerc", "dmrmc4kscalercdsp",
|
"dmrmc200c", "dmrmc200s", "dmrmc200s2", "dmrmcscalerc", "dmrmcscalers", "dmrmcscalers2", "dmrmc4kscalerc", "dmrmc4kscalercdsp",
|
||||||
"dmrmc4kzscalerc" };
|
"dmrmc4kz100c", "dmrmckzscalerc" };
|
||||||
}
|
}
|
||||||
|
|
||||||
public override EssentialsDevice BuildDevice(DeviceConfig dc)
|
public override EssentialsDevice BuildDevice(DeviceConfig dc)
|
||||||
|
|||||||
@@ -21,10 +21,10 @@ namespace PepperDash.Essentials.DM
|
|||||||
public class DmRmcX100CController : DmRmcControllerBase, IRoutingInputsOutputs,
|
public class DmRmcX100CController : DmRmcControllerBase, IRoutingInputsOutputs,
|
||||||
IIROutputPorts, IComPorts, ICec
|
IIROutputPorts, IComPorts, ICec
|
||||||
{
|
{
|
||||||
public DmRmc100C Rmc { get; private set; }
|
public DmRmc100C Rmc { get; protected set; }
|
||||||
|
|
||||||
public RoutingInputPort DmIn { get; private set; }
|
public RoutingInputPort DmIn { get; protected set; }
|
||||||
public RoutingOutputPort HdmiOut { get; private set; }
|
public RoutingOutputPort HdmiOut { get; protected set; }
|
||||||
|
|
||||||
public RoutingPortCollection<RoutingInputPort> InputPorts
|
public RoutingPortCollection<RoutingInputPort> InputPorts
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -100,6 +100,7 @@
|
|||||||
<Compile Include="Chassis\DmpsInternalVirtualDmTxController.cs" />
|
<Compile Include="Chassis\DmpsInternalVirtualDmTxController.cs" />
|
||||||
<Compile Include="Chassis\DmpsRoutingController.cs" />
|
<Compile Include="Chassis\DmpsRoutingController.cs" />
|
||||||
<Compile Include="Chassis\HdMdNxM4kEController.cs" />
|
<Compile Include="Chassis\HdMdNxM4kEController.cs" />
|
||||||
|
<Compile Include="Endpoints\Receivers\DmRmc4kZ100CController.cs" />
|
||||||
<Compile Include="Endpoints\Receivers\DmRmc4kZScalerCController.cs" />
|
<Compile Include="Endpoints\Receivers\DmRmc4kZScalerCController.cs" />
|
||||||
<Compile Include="Endpoints\Transmitters\TxInterfaces.cs" />
|
<Compile Include="Endpoints\Transmitters\TxInterfaces.cs" />
|
||||||
<Compile Include="IDmSwitch.cs" />
|
<Compile Include="IDmSwitch.cs" />
|
||||||
|
|||||||
Reference in New Issue
Block a user