1 feat: 添加变量导入模板配置和工厂模式实现
2
3 -
在AppSettings中添加VariableImportTemplate配置项,用于设置变量导入的默认参数(IsActive、PollingIn
terval、IsHistoryEnabled、HistoryDeadband)
4 - 修改AppSettings.Load()方法,优化配置加载逻辑
5 -
实现IVariableItemViewModelFactory和VariableItemViewModelFactory,使用工厂模式创建VariableItemVie
wModel实例
6 - 在ImportOpcUaDialogViewModel中使用工厂创建VariableItemViewModel实例,以应用默认配置
7 -
在SettingViewModel和SettingView中添加变量导入设置界面和相关属性(VariablePollingInterval、Variab
leIsActive、VariableIsHistoryEnabled、VariableHistoryDeadband)
8 - 移除VariableItemViewModel构造函数中的轮询间隔默认值设置,改由工厂模式设置
9 - 优化SplashViewModel中配置加载逻辑
10 - 移除MainView.xaml.cs中已注释的代码
11 - 调整VariableTableView.xaml的UI布局和菜单结构
12 - 注册IVariableItemViewModelFactory服务
这些修改主要实现了几个关键功能:
1. 引入了工厂模式来创建VariableItemViewModel实例,确保所有新创建的变量项都应用默认配置
2. 添加了变量导入模板设置,用户可以在设置界面自定义导入变量的默认属性
3. 对相关UI进行了调整和优化
This commit is contained in:
@@ -6,6 +6,7 @@ using CommunityToolkit.Mvvm.Input;
|
||||
using DMS.Core.Enums;
|
||||
using DMS.Infrastructure.Interfaces.Services;
|
||||
using DMS.Infrastructure.Models;
|
||||
using DMS.WPF.Factories;
|
||||
using DMS.WPF.Interfaces;
|
||||
using DMS.WPF.Services;
|
||||
using DMS.WPF.ViewModels.Items;
|
||||
@@ -79,17 +80,18 @@ public partial class ImportOpcUaDialogViewModel : DialogViewModelBase<List<Varia
|
||||
/// OPC UA服务接口实例
|
||||
/// </summary>
|
||||
private readonly IOpcUaService _opcUaService;
|
||||
|
||||
private readonly IVariableItemViewModelFactory _variableItemViewModelFactory;
|
||||
|
||||
/// <summary>
|
||||
/// 对象映射器实例
|
||||
/// </summary>
|
||||
private readonly IMapper _mapper;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 取消令牌源,用于取消长时间运行的操作
|
||||
/// </summary>
|
||||
private readonly CancellationTokenSource _cancellationTokenSource;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 通知服务实例
|
||||
/// </summary>
|
||||
@@ -102,9 +104,11 @@ public partial class ImportOpcUaDialogViewModel : DialogViewModelBase<List<Varia
|
||||
/// <param name="opcUaService">OPC UA服务接口实例</param>
|
||||
/// <param name="mapper">对象映射器实例</param>
|
||||
/// <param name="notificationService">通知服务实例</param>
|
||||
public ImportOpcUaDialogViewModel(IOpcUaService opcUaService, IMapper mapper, INotificationService notificationService)
|
||||
public ImportOpcUaDialogViewModel(IOpcUaService opcUaService, IVariableItemViewModelFactory variableItemViewModelFactory,
|
||||
IMapper mapper, INotificationService notificationService)
|
||||
{
|
||||
_opcUaService = opcUaService;
|
||||
_variableItemViewModelFactory = variableItemViewModelFactory;
|
||||
_mapper = mapper;
|
||||
_notificationService = notificationService;
|
||||
// 初始化根节点
|
||||
@@ -319,7 +323,7 @@ public partial class ImportOpcUaDialogViewModel : DialogViewModelBase<List<Varia
|
||||
|
||||
// 异步浏览节点获取子节点列表
|
||||
var children = await _opcUaService.BrowseNode(_mapper.Map<OpcUaNode>(node));
|
||||
|
||||
|
||||
// 再次检查是否有取消请求
|
||||
_cancellationTokenSource.Token.ThrowIfCancellationRequested();
|
||||
|
||||
@@ -332,15 +336,15 @@ public partial class ImportOpcUaDialogViewModel : DialogViewModelBase<List<Varia
|
||||
// 判断节点类型是否为变量
|
||||
if (child.NodeClass == NodeClass.Variable)
|
||||
{
|
||||
var variableItem = _variableItemViewModelFactory.CreateNewVariableItemViewModel();
|
||||
variableItem.Name = child.DisplayName;
|
||||
variableItem.OpcUaNodeId = child.NodeId.ToString();
|
||||
variableItem.Protocol = ProtocolType.OpcUa;
|
||||
variableItem.DataType = child.DataType;
|
||||
|
||||
|
||||
// 创建并添加变量项到变量列表
|
||||
OpcUaNodeVariables.Add(new VariableItemViewModel
|
||||
{
|
||||
Name = child.DisplayName, // 变量名称
|
||||
OpcUaNodeId = child.NodeId.ToString(), // OPC UA节点ID
|
||||
Protocol = ProtocolType.OpcUa, // 协议类型
|
||||
DataType = child.DataType, // C#数据类型
|
||||
IsActive = true // 默认激活状态
|
||||
});
|
||||
OpcUaNodeVariables.Add(variableItem);
|
||||
}
|
||||
// 如果是递归模式且节点不是变量,则递归浏览子节点
|
||||
else if (isRecursive)
|
||||
|
||||
@@ -122,9 +122,6 @@ public partial class VariableItemViewModel : ObservableObject
|
||||
|
||||
public VariableItemViewModel()
|
||||
{
|
||||
// 使用默认值,实际的默认值应该从外部传入或通过其他方式设置
|
||||
// 保持构造函数轻量级,不加载配置文件
|
||||
_pollingInterval = App.Current.Services.GetRequiredService<AppSettings>().DefaultPollingInterval; // 默认值,可通过外部设置覆盖
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -135,19 +135,63 @@ public partial class SettingViewModel : ViewModelBase
|
||||
}
|
||||
}
|
||||
|
||||
public int DefaultPollingInterval
|
||||
public int VariablePollingInterval
|
||||
{
|
||||
get => _settings.DefaultPollingInterval;
|
||||
get => _settings.VariableImportTemplate.PollingInterval;
|
||||
set
|
||||
{
|
||||
if (_settings.DefaultPollingInterval != value)
|
||||
if (_settings.VariableImportTemplate.PollingInterval != value)
|
||||
{
|
||||
_settings.DefaultPollingInterval = value;
|
||||
_settings.VariableImportTemplate.PollingInterval = value;
|
||||
OnPropertyChanged();
|
||||
_settings.Save();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public bool VariableIsActive
|
||||
{
|
||||
get => _settings.VariableImportTemplate.IsActive;
|
||||
set
|
||||
{
|
||||
if (_settings.VariableImportTemplate.IsActive != value)
|
||||
{
|
||||
_settings.VariableImportTemplate.IsActive = value;
|
||||
OnPropertyChanged();
|
||||
_settings.Save();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public bool VariableIsHistoryEnabled
|
||||
{
|
||||
get => _settings.VariableImportTemplate.IsHistoryEnabled;
|
||||
set
|
||||
{
|
||||
if (_settings.VariableImportTemplate.IsHistoryEnabled != value)
|
||||
{
|
||||
_settings.VariableImportTemplate.IsHistoryEnabled = value;
|
||||
OnPropertyChanged();
|
||||
_settings.Save();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public double VariableHistoryDeadband
|
||||
{
|
||||
get => _settings.VariableImportTemplate.HistoryDeadband;
|
||||
set
|
||||
{
|
||||
if (_settings.VariableImportTemplate.HistoryDeadband != value)
|
||||
{
|
||||
_settings.VariableImportTemplate.HistoryDeadband = value;
|
||||
OnPropertyChanged();
|
||||
_settings.Save();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
[RelayCommand]
|
||||
private async Task TestConnection()
|
||||
|
||||
@@ -52,10 +52,7 @@ public partial class SplashViewModel : ObservableObject
|
||||
try
|
||||
{
|
||||
LoadingMessage = "正在加载系统配置...";
|
||||
if (_appSettings.Load() == null)
|
||||
{
|
||||
//程序第一次启动
|
||||
}
|
||||
_appSettings.Load();
|
||||
|
||||
_logger.LogInformation("正在初始化数据库...");
|
||||
LoadingMessage = "正在初始化数据库...";
|
||||
|
||||
@@ -11,7 +11,6 @@ using DMS.Core.Events;
|
||||
using DMS.Core.Models;
|
||||
using DMS.WPF.Interfaces;
|
||||
using DMS.WPF.ViewModels.Dialogs;
|
||||
using DMS.WPF.ViewModels.Dialogs;
|
||||
using DMS.WPF.ViewModels.Items;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using ObservableCollections;
|
||||
@@ -329,6 +328,8 @@ partial class VariableTableViewModel : ViewModelBase, INavigatable
|
||||
return; // 用户取消或没有选择任何变量
|
||||
}
|
||||
|
||||
|
||||
|
||||
// 将导入的变量转换为DTO并设置必要的属性
|
||||
var importedVariableDtos = _mapper.Map<List<VariableDto>>(importedVariables);
|
||||
foreach (var variableDto in importedVariableDtos)
|
||||
|
||||
Reference in New Issue
Block a user