+
+ private void bRescanDevices_Click(object sender, EventArgs e)
+ {
+ if (!SuppressUpdates && ActiveProcess == null)
+ {
+ SetControlsEnabled(false);
+ ActiveProcess = new RescanDevices(ref Lib);
+ ActiveProcess.EventHandler += new EventHandler<UpdateEvent>(ProcessEventHandler);
+ (new Thread(new ThreadStart(ActiveProcess.Run))).Start();
+ }
+ }
+ #endregion
+
+ #region Log tab
+ delegate void UpdateLogCallback();
+ private void UpdateLog()
+ {
+ if (tbLog.InvokeRequired)
+ {
+ UpdateLogCallback d = new UpdateLogCallback(UpdateLog);
+ try
+ {
+ this.Invoke(d, new object[] { });
+ }
+ catch (Exception) { }
+ }
+ else
+ {
+ tbLog.Text = Log;
+ tbLog.Select(tbLog.Text.Length, 0);
+ tbLog.ScrollToCaret();
+ }
+ }
+
+ private void AddLogMessage(CecLogMessage message)
+ {
+ string strLevel = "";
+ bool display = false;
+ switch (message.Level)
+ {
+ case CecLogLevel.Error:
+ strLevel = "ERROR: ";
+ display = cbLogError.Checked;
+ break;
+ case CecLogLevel.Warning:
+ strLevel = "WARNING: ";
+ display = cbLogWarning.Checked;
+ break;
+ case CecLogLevel.Notice:
+ strLevel = "NOTICE: ";
+ display = cbLogNotice.Checked;
+ break;
+ case CecLogLevel.Traffic:
+ strLevel = "TRAFFIC: ";
+ display = cbLogTraffic.Checked;
+ break;
+ case CecLogLevel.Debug:
+ strLevel = "DEBUG: ";
+ display = cbLogDebug.Checked;
+ break;
+ default:
+ break;
+ }
+
+ if (display)
+ {
+ string strLog = string.Format("{0} {1,16} {2}", strLevel, message.Time, message.Message) + System.Environment.NewLine;
+ Log += strLog;
+ }
+
+ if (SelectedTab == ConfigTab.Log)
+ UpdateLog();
+ }
+
+ private void bClearLog_Click(object sender, EventArgs e)
+ {
+ Log = string.Empty;
+ UpdateLog();
+ }
+
+ private void bSaveLog_Click(object sender, EventArgs e)
+ {
+ SaveFileDialog dialog = new SaveFileDialog()
+ {
+ Title = "Where do you want to store the log file?",
+ InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments),
+ FileName = "cec-log.txt",
+ Filter = "txt files (*.txt)|*.txt|All files (*.*)|*.*",
+ FilterIndex = 1
+ };
+
+ if (dialog.ShowDialog() == DialogResult.OK)
+ {
+ FileStream fs = (FileStream)dialog.OpenFile();
+ if (fs == null)
+ {
+ MessageBox.Show("Cannot open '" + dialog.FileName + "' for writing", "Pulse-Eight USB-CEC Adapter", MessageBoxButtons.OK, MessageBoxIcon.Error);
+ }
+ else
+ {
+ StreamWriter writer = new StreamWriter(fs);
+ writer.Write(Log);
+ writer.Close();
+ fs.Close();
+ fs.Dispose();
+ MessageBox.Show("The log file was stored as '" + dialog.FileName + "'.", "Pulse-Eight USB-CEC Adapter", MessageBoxButtons.OK, MessageBoxIcon.Information);
+ }
+ }
+ }
+ #endregion
+
+ #region LibCecSharp callbacks
+ public int ConfigurationChanged(LibCECConfiguration config)
+ {
+ Config = config;
+ SetControlText(tbPhysicalAddress, string.Format("{0,4:X}", Config.PhysicalAddress));
+ SetControlText(cbConnectedDevice, Config.BaseDevice == CecLogicalAddress.AudioSystem ? AVRVendorString : TVVendorString);
+ SetControlText(cbPortNumber, Config.HDMIPort.ToString());
+ switch (config.DeviceTypes.Types[0])
+ {
+ case CecDeviceType.RecordingDevice:
+ SetControlText(cbDeviceType, "Recorder");
+ break;
+ case CecDeviceType.PlaybackDevice:
+ SetControlText(cbDeviceType, "Player");
+ break;
+ case CecDeviceType.Tuner:
+ SetControlText(cbDeviceType, "Tuner");
+ break;
+ default:
+ SetControlText(cbDeviceType, "Recorder");
+ break;
+ }
+ if (config.TvVendor != CecVendorId.Unknown)
+ {
+ SetCheckboxChecked(cbVendorOverride, true);
+ SetControlText(cbVendorId, Lib.ToString(config.TvVendor));
+ }
+ else
+ {
+ SetCheckboxChecked(cbVendorOverride, false);
+ SetControlText(cbVendorId, Lib.ToString(TVVendor));
+ }
+
+ SetCheckboxChecked(cbUseTVMenuLanguage, Config.UseTVMenuLanguage);
+ SetCheckboxChecked(cbActivateSource, Config.ActivateSource);
+ SetCheckboxChecked(cbPowerOffScreensaver, Config.PowerOffScreensaver);
+ SetCheckboxChecked(cbPowerOffOnStandby, Config.PowerOffOnStandby);
+ UpdateSelectedDevice();
+
+ for (int iPtr = 0; iPtr < 15; iPtr++)
+ SetCheckboxItemChecked(cbWakeDevices, iPtr, Config.WakeDevices.IsSet((CecLogicalAddress)iPtr));
+ for (int iPtr = 0; iPtr < 15; iPtr++)
+ SetCheckboxItemChecked(cbPowerOffDevices, iPtr, Config.PowerOffDevices.IsSet((CecLogicalAddress)iPtr));
+
+ SetControlText(this, "Pulse-Eight USB-CEC Adapter - libCEC " + Lib.ToString(Config.ServerVersion));
+ return 1;
+ }
+
+ public int ReceiveCommand(CecCommand command)
+ {
+ return 1;
+ }
+
+ public int ReceiveKeypress(CecKeypress key)
+ {
+ SelectKeypressRow(key);
+ return 1;
+ }
+
+ public int ReceiveLogMessage(CecLogMessage message)
+ {
+ try
+ {
+ AddLogMessage(message);
+ }
+ catch (Exception) { }
+ return 1;
+ }
+ #endregion
+
+ #region Class members
+ public bool HasAVRDevice { get; private set; }
+ #region TV Vendor
+ private CecVendorId _tvVendor = CecVendorId.Unknown;
+ public CecVendorId TVVendor
+ {
+ get { return _tvVendor;}
+ private set { _tvVendor = value; }
+ }
+ public string TVVendorString
+ {
+ get
+ {
+ return TVVendor != CecVendorId.Unknown ?
+ "Television (" + Lib.ToString(TVVendor) + ")" :
+ "Television";
+ }
+ }
+ #endregion
+ #region AVR Vendor
+ private CecVendorId _avrVendor = CecVendorId.Unknown;
+ public CecVendorId AVRVendor
+ {
+ get { return _avrVendor; }
+ private set { _avrVendor = value; }
+ }
+ public string AVRVendorString
+ {
+ get
+ {
+ return AVRVendor != CecVendorId.Unknown ?
+ "AVR (" + Lib.ToString(AVRVendor) + ")" :
+ "AVR";
+ }
+ }
+ #endregion
+ public CecLogicalAddress SelectedConnectedDevice
+ {
+ get
+ {
+ return (cbConnectedDevice.Text.Equals(AVRVendorString)) ? CecLogicalAddress.AudioSystem : CecLogicalAddress.Tv;
+ }
+ }
+ public CecDeviceType SelectedDeviceType
+ {
+ get
+ {
+ switch (cbDeviceType.Text.ToLower())
+ {
+ case "player":
+ return CecDeviceType.PlaybackDevice;
+ case "tuner":
+ return CecDeviceType.Tuner;
+ default:
+ return CecDeviceType.RecordingDevice;
+ }
+ }
+ }
+ public int SelectedPortNumber
+ {
+ get
+ {
+ int iPortNumber = 0;
+ if (!int.TryParse(cbPortNumber.Text, out iPortNumber))
+ iPortNumber = 1;
+ return iPortNumber;
+ }
+ }
+ protected LibCECConfiguration Config;
+ protected LibCecSharp Lib;
+ private CecCallbackWrapper Callbacks;
+ private UpdateProcess ActiveProcess = null;
+ private bool SuppressUpdates = true;
+ private ConfigTab SelectedTab = ConfigTab.Configuration;
+ private string Log = string.Empty;
+ private DeviceInformation UpdatingInfoPanel = null;
+ private bool DeviceChangeWarningDisplayed = false;
+ public CecLogicalAddresses WakeDevices
+ {
+ get
+ {
+ CecLogicalAddresses addr = new CecLogicalAddresses();
+ foreach (object item in this.cbWakeDevices.CheckedItems)
+ {
+ string c = item as string;
+ addr.Set(GetLogicalAddressFromString(c));
+ }
+ return addr;
+ }
+ }
+ public CecLogicalAddresses PowerOffDevices
+ {
+ get
+ {
+ CecLogicalAddresses addr = new CecLogicalAddresses();
+ foreach (object item in this.cbPowerOffDevices.CheckedItems)
+ {
+ string c = item as string;
+ addr.Set(GetLogicalAddressFromString(c));
+ }
+ return addr;
+ }
+ }
+ #endregion