- Supports both CM11 and CM15 hardware
- Decoding of CM15 RF messages (both standard and security)
- Event driven
- Hot plug
- Automatically restabilish connection on error/disconnect
- Compatible with Mono
Install the libusb-1.0 package
apt-get install libusb-1.0-0 libusb-1.0-0-dev
Install the CM15 LibUSB driver by executing the InstallDriver.exe file contained in the WindowsUsbDriver folder.
XTenLib is available as a NuGet package.
Run Install-Package XTenLib
in the Package Manager Console or search for “XTenLib” in your IDE’s package management plug-in.
using XTenLib;
//...
var x10 = new XTenManager();
// Listen to XTenManager events
x10.ConnectionStatusChanged += X10_ConnectionStatusChanged;
x10.ModuleChanged += X10_ModuleChanged;
x10.PlcAddressReceived += X10_PlcAddressReceived;
x10.PlcFunctionReceived += X10_PlcFunctionReceived;
// These RF events are only used for CM15
x10.RfDataReceived += X10_RfDataReceived;
x10.RfCommandReceived += X10_RfCommandReceived;
x10.RfSecurityReceived += X10_RfSecurityReceived;
// Setup X10 interface. For CM15 set PortName = "USB",
// for CM11 use serial port path instead (eg. "COM7" or "/dev/ttyUSB0")
x10.PortName = "USB";
x10.HouseCode = "A,C";
// Connect the interface. It supports hot plug/unplug.
x10.Connect();
// Get a module and control it
if (x10.IsConnected)
{
var modC7 = x10.Modules["C7"];
// Turn On
modC7.On();
// Turn Off
modC7.Off();
// Brighten by 10%
modC7.Bright(10);
}
// Sending a raw message.
// The example below is the RF command A1 ON/OFF (RF works with CM15 only)
x10.SendMessage(new byte[] { 0xEB, 0x20, 0x60, 0x9F, 0x00, 0xFF });
x10.SendMessage(new byte[] { 0xEB, 0x20, 0x60, 0x9F, 0x20, 0xDF });
// Disconnect the interface
x10.Disconnect();
//...
void X10_ConnectionStatusChanged(object sender, ConnectionStatusChangedEventArgs args)
{
Console.WriteLine("Interface connection status {0}", args.Connected);
}
void X10_ModuleChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e)
{
var module = sender as X10Module;
Console.WriteLine("Module property changed: {0} {1} = {2}",
module.Code, e.PropertyName, module.Level);
}
void X10_PlcAddressReceived(object sender, PlcAddressReceivedEventArgs args)
{
Console.WriteLine("PLC address received: HouseCode {0} Unit {1}",
args.HouseCode, args.UnitCode);
}
void X10_PlcFunctionReceived(object sender, PlcFunctionReceivedEventArgs args)
{
Console.WriteLine("PLC function received: Command {0} HouseCode {1}",
args.Command, args.HouseCode);
}
void X10_RfDataReceived(object sender, RfDataReceivedEventArgs args)
{
Console.WriteLine("RF data received: {0}", BitConverter.ToString(args.Data));
}
void X10_RfCommandReceived(object sender, RfCommandReceivedEventArgs args)
{
Console.WriteLine("Received RF command {0} House Code {1} Unit {2}",
args.Command, args.HouseCode, args.UnitCode);
}
void X10_RfSecurityReceived(object sender, RfSecurityReceivedEventArgs args)
{
Console.WriteLine("Received RF Security event {0} from address {1}",
args.Event, args.Address.ToString("X3"));
}
XTenLib is open source software, licensed under the terms of Apache license 2.0. See the LICENSE file for details.