当前位置: 首页 > news >正文

WPF 程序监控硬件设备状态变化的实现方案

以下是一个完整的 C# WPF 程序实现方案,用于监控硬件设备状态变化(基于设备 SDK API)。我们将分步骤实现,包含状态轮询、事件通知、UI 绑定和错误处理。


1. 项目结构设计

HardwareMonitor/
├── Models/               # 数据模型
│   └── DeviceStatus.cs
├── Services/            # 硬件服务层
│   ├── IDeviceService.cs
│   └── DeviceService.cs
├── ViewModels/          # MVVM 视图模型
│   └── MainViewModel.cs
├── Views/               # 用户界面
│   └── MainWindow.xaml
└── App.xaml             # 应用程序入口

2. 实现步骤

(1) 定义设备状态模型
// Models/DeviceStatus.cs
public class DeviceStatus : INotifyPropertyChanged
{private bool _isConnected;public bool IsConnected{get => _isConnected;set { _isConnected = value; OnPropertyChanged(); }}private double _temperature;public double Temperature{get => _temperature;set { _temperature = value; OnPropertyChanged(); }}public event PropertyChangedEventHandler? PropertyChanged;protected void OnPropertyChanged([CallerMemberName] string? name = null){PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));}
}
(2) 封装设备 SDK API
// Services/IDeviceService.cs
public interface IDeviceService
{DeviceStatus CurrentStatus { get; }event EventHandler<DeviceStatus> StatusChanged;void StartMonitoring();void StopMonitoring();
}// Services/DeviceService.cs
public class DeviceService : IDeviceService, IDisposable
{private readonly Timer _pollingTimer;private readonly DeviceSDK _sdk; // 假设这是硬件SDK的类public DeviceStatus CurrentStatus { get; } = new DeviceStatus();public event EventHandler<DeviceStatus>? StatusChanged;public DeviceService(){_sdk = new DeviceSDK(); // 初始化SDK_pollingTimer = new Timer(UpdateStatus, null, Timeout.Infinite, 1000);}public void StartMonitoring() => _pollingTimer.Change(0, 1000); // 每秒轮询public void StopMonitoring() => _pollingTimer.Change(Timeout.Infinite, Timeout.Infinite);private void UpdateStatus(object? state){try{// 调用SDK获取状态CurrentStatus.IsConnected = _sdk.GetConnectionStatus();CurrentStatus.Temperature = _sdk.ReadTemperature();// 触发事件StatusChanged?.Invoke(this, CurrentStatus);}catch (Exception ex){Debug.WriteLine($"监控错误: {ex.Message}");}}public void Dispose(){_pollingTimer.Dispose();_sdk.Disconnect();}
}
(3) 实现 ViewModel
// ViewModels/MainViewModel.cs
public class MainViewModel : INotifyPropertyChanged
{private readonly IDeviceService _deviceService;private string _statusMessage = "等待连接...";public DeviceStatus Status { get; }public string StatusMessage{get => _statusMessage;set { _statusMessage = value; OnPropertyChanged(); }}public ICommand StartMonitoringCommand { get; }public ICommand StopMonitoringCommand { get; }public MainViewModel(IDeviceService deviceService){_deviceService = deviceService;Status = _deviceService.CurrentStatus;// 命令绑定StartMonitoringCommand = new RelayCommand(() =>{_deviceService.StartMonitoring();StatusMessage = "监控中...";});StopMonitoringCommand = new RelayCommand(() =>{_deviceService.StopMonitoring();StatusMessage = "已停止";});// 订阅状态变化事件_deviceService.StatusChanged += (s, e) => {StatusMessage = e.IsConnected ? "设备在线" : "设备离线";};}public event PropertyChangedEventHandler? PropertyChanged;protected void OnPropertyChanged([CallerMemberName] string? name = null)=> PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));
}
(4) 创建 WPF 界面
<!-- Views/MainWindow.xaml -->
<Window x:Class="HardwareMonitor.Views.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="硬件监控" Height="300" Width="400"><Grid Margin="10"><StackPanel><TextBlock Text="{Binding StatusMessage}" FontSize="16" Margin="0,10"/><Border Background="{Binding Status.IsConnected, Converter={StaticResource BoolToBrushConverter}}"CornerRadius="5" Padding="10" Margin="0,10"><TextBlock Text="{Binding Status.IsConnected, Converter={StaticResource BoolToStatusConverter}}"HorizontalAlignment="Center"/></Border><TextBlock Text="{Binding Status.Temperature, StringFormat='温度: {0}°C'}" Margin="0,10"/><StackPanel Orientation="Horizontal" HorizontalAlignment="Center"><Button Content="开始监控" Command="{Binding StartMonitoringCommand}" Margin="5" Width="100"/><Button Content="停止监控" Command="{Binding StopMonitoringCommand}" Margin="5" Width="100"/></StackPanel></StackPanel></Grid>
</Window>
(5) 依赖注入配置
// App.xaml.cs
public partial class App : Application
{protected override void OnStartup(StartupEventArgs e){base.OnStartup(e);// 配置DI容器var services = new ServiceCollection();services.AddSingleton<IDeviceService, DeviceService>();services.AddTransient<MainViewModel>();services.AddTransient<MainWindow>();var provider = services.BuildServiceProvider();// 启动主窗口var mainWindow = provider.GetRequiredService<MainWindow>();mainWindow.DataContext = provider.GetRequiredService<MainViewModel>();mainWindow.Show();}
}

3. 关键功能实现

(1) 状态轮询优化
// 使用CancellationToken实现可控轮询
private async Task RunPollingAsync(CancellationToken token)
{while (!token.IsCancellationRequested){UpdateStatus(null);await Task.Delay(1000, token); // 异步延迟}
}
(2) SDK 异常处理
private void UpdateStatus(object? state)
{try{// 添加超时控制using var cts = new CancellationTokenSource(TimeSpan.FromSeconds(2));var status = Task.Run(() => _sdk.GetStatus(), cts.Token).Result;// 更新状态...}catch (OperationCanceledException){StatusMessage = "SDK响应超时";}catch (Exception ex){Debug.WriteLine($"SDK错误: {ex.Message}");}
}
(3) UI 绑定转换器
// BoolToBrushConverter.cs
public class BoolToBrushConverter : IValueConverter
{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){return (bool)value ? Brushes.LightGreen : Brushes.LightPink;}public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture){throw new NotImplementedException();}
}

4. 部署与测试

硬件 SDK 集成
  1. 将厂商提供的 SDK DLL 放入 lib/ 目录

  2. 在项目中添加引用:

<ItemGroup><Reference Include="DeviceSDK" HintPath="lib\DeviceSDK.dll" />
</ItemGroup>
测试方案
测试类型方法预期结果
正常连接测试模拟SDK返回有效数据UI实时更新状态
断开连接测试关闭硬件设备显示"设备离线"
压力测试高频调用SDK API不出现UI卡顿或内存泄漏
异常测试抛出SDK异常显示错误且不崩溃

 

5. 扩展功能建议

  1. 历史数据记录

public void LogStatus(DeviceStatus status)
{File.AppendAllText("log.txt", $"{DateTime.Now}: {status.Temperature}°C, Connected={status.IsConnected}\n");
}
  1. 阈值报警

if (CurrentStatus.Temperature > 80)
{PlayAlertSound();ShowToast("温度过高!");
}
  1. 远程监控

// 使用SignalR将状态推送到Web端
await _hubConnection.SendAsync("ReportStatus", CurrentStatus);

系统优点:

  • 分层清晰(MVVM + 服务隔离)

  • 响应灵敏(异步轮询 + 事件驱动)

  • 健壮可靠(完备的错误处理)

  • 易于扩展(依赖注入支持)

的硬件监控系统。实际开发时,请根据具体 SDK API 调整 DeviceService 中的调用逻辑。

相关文章:

  • MaxScript二维图形布尔(并)运算
  • 【iOS】OC源码阅读——alloc源码分析
  • Android显示学习笔记本
  • 第一天 车联网定义、发展历程与生态体系
  • 机器学习中的标签策略:直接标签、代理标签与人工数据生成
  • 清华大学正式成立人工智能医院
  • 北重数控滑台加工厂家:汽车零部件试验铁地板-安全性能的测试方法
  • 代码片段存储解决方案ByteStash
  • 八大排序——直接插入排序/希尔排序
  • python使用dlib的5点和68点的人脸检测
  • 深入理解缓存淘汰策略:LRU 与 LFU 算法详解及 Java 实现
  • springboot 实现敏感信息脱敏
  • OpenCV 图形API(69)图像与通道拼接函数------将一个 GMat 类型的对象转换为另一个具有不同深度GMat对象函数convertTo()
  • git 修改用户名和邮箱
  • 关于常量指针和指向常量的指针
  • HTML5好看的水果蔬菜在线商城网站源码系列模板7
  • vue复习91~135
  • GPU 架构入门笔记
  • 获得ecovadis徽章资格标准是什么?ecovadis评估失败的风险
  • 【ACL系列论文写作指北07-论文标题与关键词部分怎么写】-赢在第一眼
  • 俄宣布停火三天,外交部:希望各方继续通过对话谈判解决危机
  • 圆桌|特朗普上台百日未能结束俄乌冲突,若美国“退出”会发生什么?
  • 诗词文赋俱当歌,听一听古诗词中的音乐性
  • 新经济与法|如何治理网购刷单与控评?数据合规管理是关键
  • 脱发后怎么把头发养回来?脱发自救指南来了
  • IPO周报|4月最后2只新股周一申购,今年以来最低价股来了