mirror of
https://github.com/PepperDash/Essentials.git
synced 2026-02-11 10:45:00 +00:00
Progress on comm bridge
This commit is contained in:
@@ -9,81 +9,74 @@ using PepperDash.Core;
|
||||
using PepperDash.Essentials.Core;
|
||||
using PepperDash.Essentials.DM;
|
||||
|
||||
namespace PepperDash.Essentials.Bridges.TEST
|
||||
namespace PepperDash.Essentials.Bridges
|
||||
{
|
||||
public static class IBasicCommunicationExtensions
|
||||
{
|
||||
public static void LinkToApi(this GenericComm comm, BasicTriList trilist, uint joinStart)
|
||||
{
|
||||
// this is a permanent event handler. This cannot be -= from event
|
||||
comm.CommPort.TextReceived += (s, a) => trilist.SetString(joinStart, a.Text);
|
||||
trilist.SetStringSigAction(joinStart, new Action<string>(s => comm.CommPort.SendText(s)));
|
||||
trilist.SetStringSigAction(joinStart + 1, new Action<string>(s => comm.SetPortConfig(s)));
|
||||
|
||||
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
public static class DmChassisControllerApiExtensions
|
||||
{
|
||||
public static void LinkToApi(this PepperDash.Essentials.DM.DmChassisController chassis,
|
||||
BasicTriList trilist, Dictionary<string,uint> map, uint joinstart)
|
||||
{
|
||||
uint joinOffset = joinstart - 1;
|
||||
var sComm = comm.CommPort as ISocketStatus;
|
||||
if (sComm != null)
|
||||
{
|
||||
sComm.ConnectionChange += (s, a) =>
|
||||
{
|
||||
trilist.SetUshort(joinStart, (ushort)(a.Client.ClientStatus));
|
||||
trilist.SetBool(joinStart, a.Client.ClientStatus ==
|
||||
Crestron.SimplSharp.CrestronSockets.SocketStatus.SOCKET_STATUS_CONNECTED);
|
||||
};
|
||||
|
||||
uint videoSelectOffset = 0 + joinOffset;
|
||||
uint audioSelectOffset = 40 + joinOffset;
|
||||
trilist.SetBoolSigAction(joinStart, new Action<bool>(b =>
|
||||
{
|
||||
if (b)
|
||||
{
|
||||
sComm.Connect();
|
||||
}
|
||||
else
|
||||
{
|
||||
sComm.Disconnect();
|
||||
}
|
||||
}));
|
||||
}
|
||||
}
|
||||
}
|
||||
///// <summary>
|
||||
/////
|
||||
///// </summary>
|
||||
//public static class DmChassisControllerApiExtensions
|
||||
//{
|
||||
// public static void LinkToApi(this PepperDash.Essentials.DM.DmChassisController chassis,
|
||||
// BasicTriList trilist, Dictionary<string,uint> map, uint joinstart)
|
||||
// {
|
||||
// uint joinOffset = joinstart - 1;
|
||||
|
||||
// uint videoSelectOffset = 0 + joinOffset;
|
||||
// uint audioSelectOffset = 40 + joinOffset;
|
||||
|
||||
|
||||
// loop chassis number of inupts
|
||||
for (uint i = 1; i <= chassis.Chassis.NumberOfOutputs; i++)
|
||||
{
|
||||
trilist.SetUShortSigAction(videoSelectOffset + i, new Action<ushort>(u => chassis.ExecuteSwitch(u, i, eRoutingSignalType.Video)));
|
||||
trilist.SetUShortSigAction(audioSelectOffset + i, new Action<ushort>(u => chassis.ExecuteSwitch(u, i, eRoutingSignalType.Audio)));
|
||||
}
|
||||
// // loop chassis number of inupts
|
||||
// for (uint i = 1; i <= chassis.Chassis.NumberOfOutputs; i++)
|
||||
// {
|
||||
// trilist.SetUShortSigAction(videoSelectOffset + i, new Action<ushort>(u => chassis.ExecuteSwitch(u, i, eRoutingSignalType.Video)));
|
||||
// trilist.SetUShortSigAction(audioSelectOffset + i, new Action<ushort>(u => chassis.ExecuteSwitch(u, i, eRoutingSignalType.Audio)));
|
||||
// }
|
||||
|
||||
// wire up output change detection (try to add feedbacks or something to DMChassisController??
|
||||
// // wire up output change detection (try to add feedbacks or something to DMChassisController??
|
||||
|
||||
// names?
|
||||
// // names?
|
||||
|
||||
// HDCP?
|
||||
// // HDCP?
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
// }
|
||||
//}
|
||||
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// For trilists to com sockets only
|
||||
/// </summary>
|
||||
public static class IBasicCommunicationApiExtensions
|
||||
{
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
/// <param name="comm"></param>
|
||||
/// <param name="trilist"></param>
|
||||
/// <param name="joinStart"></param>
|
||||
public static void LinkToApi(this IBasicCommunication comm, BasicTriList trilist, uint joinStart)
|
||||
{
|
||||
// this is a permanent event handler. This cannot be -= from event
|
||||
comm.TextReceived += (s, a) => trilist.SetString(joinStart, a.Text);
|
||||
trilist.SetStringSigAction(joinStart, new Action<string>(s => comm.SendText(s)));
|
||||
|
||||
var sComm = comm as ISocketStatus;
|
||||
if (sComm != null)
|
||||
{
|
||||
sComm.ConnectionChange += (s, a) =>
|
||||
{
|
||||
trilist.SetUshort(joinStart, (ushort)(a.Client.ClientStatus));
|
||||
trilist.SetBool(joinStart, a.Client.ClientStatus ==
|
||||
Crestron.SimplSharp.CrestronSockets.SocketStatus.SOCKET_STATUS_CONNECTED);
|
||||
};
|
||||
|
||||
trilist.SetBoolSigAction(joinStart, new Action<bool>(b =>
|
||||
{
|
||||
if (b)
|
||||
{
|
||||
sComm.Connect();
|
||||
}
|
||||
else
|
||||
{
|
||||
sComm.Disconnect();
|
||||
}
|
||||
}));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user