The Huddly SDK is a library for interacting with Huddly devices. This repo contains documentation and common examples for interacting with the Huddly SDK.
The Huddly Sdk has two ways of discovering and identifying devices, IP and USB. Which one is appropriate depends on the device. When setting up the Sdk, you need to specify which of these protocols to use: You can use both, or just one of them.
We recommend using dependency injection through the Huddly.Sdk.Extensions
package for creating an ISdk
instance.
services
.AddHuddlySdk(
configure =>
{
configure.UseUsbDeviceMonitor();
configure.UseIpDeviceMonitor();
}
);
Alternatively, if you don't wish to use dependency injection
IDeviceMonitor usbMonitor = Huddly.Sdk.Monitor.UsbAutoProxyClientDeviceMonitor();
IDeviceMonitor ipMonitor = Huddly.Sdk.Monitor.WsDiscoveryIpDeviceMonitor();
ISdk huddlySdk = Huddly.Sdk.Create(new NullLoggerFactory(), usbMonitor, ipMonitor);
After creating an ISdk instance, add appropriate listeners for device connect/disconnect events:
huddlySdk.DeviceConnected += async (sender, eventArgs) =>
{
Console.WriteLine($"Device {eventArgs.Device.Model} connected");
}
huddlySdk.DeviceConnected += async (sender, eventArgs) =>
{
Console.WriteLine($"Device {eventArgs.Device.Model} disconnected");
}
Then start monitoring
CancellationTokenSource cts = new CancellationTokenSource();
huddlySdk.StartMonitoring(cts.Token)
If you have Huddly devices connected, you should now start getting connection events for them. Note that there can be some delay, particularly for IP devices.
The .NET Huddly SDK allows for connecting to USB devices through a proxy. This way, multiple independent processes can talk to a USB device at the same time. When communicating with USB devices, consumers should always default to attempt connecting to this proxy. If this fails, native USB can be used as a fallback. See the above examples for how to do this.
Devices can be interacted with using the IDevice
interface. To obtain an IDevice
instance, use the DeviceConnected
event.
Device calls typically return a Result
object which traps any potential exceptions raised during the interaction. To determine the outcome of an operation, use the IsSuccess
property.
Result result = await device.SetFramingMode(FramingMode.SpeakerFraming);
if (result.IsSuccess)
{
Console.WriteLine("Framing mode set successfully");
}
else
{
// When a result is not successful, it contains a message with diagnostic information
Console.WriteLine($"Could not set framing mode, failed with status code {result.StatusCode} and message {result.Message}");
// Alternatively, it will also contain an exception that can be used for the same purpose, or to be rethrown.
Exception error = result.Error;
_logger.LogError(error, "Could not set framing mode");
}
For operations where a value is included, Result is used. Note that the contained value is safe to use if and only if the Result was successful.
Result<FramingMode> result = await device.GetFramingMode();
if (result.IsSuccess)
{
// Operation was successful and we can safely retrieve the contained value
FramingMode currentFramingMode = result.Value;
Console.WriteLine($"Device is currently using {currentFramingMode}")
}
else
{
// Handle error
}
Alternatively, if you prefer an exception based control flow, you can force the Result
type to throw if the operation was not successful:
Result result = await device.SetFramingMode(FramingMode.SpeakerFraming);
result.ThrowIfError();
Result<FramingMode> result = await device.GetFramingMode();
FramingMode currentFramingMode = result.GetValueOrThrow();