将图形库替换为LiveChartsCore.SkiaSharpView.WPF
This commit is contained in:
@@ -161,11 +161,11 @@
|
|||||||
<PackageReference Include="HandyControl" Version="3.5.1" />
|
<PackageReference Include="HandyControl" Version="3.5.1" />
|
||||||
<PackageReference Include="Hardcodet.NotifyIcon.Wpf" Version="2.0.1" />
|
<PackageReference Include="Hardcodet.NotifyIcon.Wpf" Version="2.0.1" />
|
||||||
<PackageReference Include="iNKORE.UI.WPF.Modern" Version="0.10.0" />
|
<PackageReference Include="iNKORE.UI.WPF.Modern" Version="0.10.0" />
|
||||||
|
<PackageReference Include="LiveChartsCore.SkiaSharpView.WPF" Version="2.0.0-rc2" />
|
||||||
<PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="9.0.5" />
|
<PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="9.0.5" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions" Version="9.0.5" />
|
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions" Version="9.0.5" />
|
||||||
<PackageReference Include="NLog" Version="6.0.0" />
|
<PackageReference Include="NLog" Version="6.0.0" />
|
||||||
<PackageReference Include="ObservableCollections" Version="3.3.4" />
|
<PackageReference Include="ObservableCollections" Version="3.3.4" />
|
||||||
<PackageReference Include="LiveCharts.Wpf" Version="0.9.7" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
using System.Windows.Media;
|
||||||
using AutoMapper;
|
using AutoMapper;
|
||||||
using CommunityToolkit.Mvvm.ComponentModel;
|
using CommunityToolkit.Mvvm.ComponentModel;
|
||||||
using CommunityToolkit.Mvvm.Input;
|
using CommunityToolkit.Mvvm.Input;
|
||||||
@@ -7,10 +8,13 @@ using DMS.Application.Interfaces.Database;
|
|||||||
using DMS.Core.Events;
|
using DMS.Core.Events;
|
||||||
using DMS.WPF.Interfaces;
|
using DMS.WPF.Interfaces;
|
||||||
using DMS.WPF.ViewModels.Items;
|
using DMS.WPF.ViewModels.Items;
|
||||||
using LiveCharts;
|
using LiveChartsCore;
|
||||||
using LiveCharts.Defaults;
|
using LiveChartsCore.Defaults;
|
||||||
using LiveCharts.Wpf;
|
using LiveChartsCore.SkiaSharpView;
|
||||||
|
using LiveChartsCore.SkiaSharpView.Painting;
|
||||||
|
using LiveChartsCore.SkiaSharpView.WPF;
|
||||||
using ObservableCollections;
|
using ObservableCollections;
|
||||||
|
using SkiaSharp;
|
||||||
|
|
||||||
namespace DMS.WPF.ViewModels;
|
namespace DMS.WPF.ViewModels;
|
||||||
|
|
||||||
@@ -54,13 +58,13 @@ partial class VariableHistoryViewModel : ViewModelBase, INavigatable
|
|||||||
public NotifyCollectionChangedSynchronizedViewList<VariableHistoryDto> VariableHistories { get; }
|
public NotifyCollectionChangedSynchronizedViewList<VariableHistoryDto> VariableHistories { get; }
|
||||||
|
|
||||||
// 折线图相关属性
|
// 折线图相关属性
|
||||||
public SeriesCollection LineSeriesCollection { get; set; }
|
public ISeries[] LineSeriesCollection { get; set; }
|
||||||
|
|
||||||
[ObservableProperty]
|
[ObservableProperty]
|
||||||
private AxesCollection _lineAxisX;
|
private Axis[] _lineAxisX;
|
||||||
|
|
||||||
[ObservableProperty]
|
[ObservableProperty]
|
||||||
private AxesCollection _lineAxisY;
|
private Axis[] _lineAxisY;
|
||||||
|
|
||||||
private readonly ObservableList<VariableHistoryDto> _variableHistoryList;
|
private readonly ObservableList<VariableHistoryDto> _variableHistoryList;
|
||||||
private readonly ISynchronizedView<VariableHistoryDto, VariableHistoryDto> _variableHistorySynchronizedView;
|
private readonly ISynchronizedView<VariableHistoryDto, VariableHistoryDto> _variableHistorySynchronizedView;
|
||||||
@@ -89,14 +93,14 @@ partial class VariableHistoryViewModel : ViewModelBase, INavigatable
|
|||||||
_allVariableHistories = new List<VariableHistoryDto>();
|
_allVariableHistories = new List<VariableHistoryDto>();
|
||||||
|
|
||||||
// 初始化默认值
|
// 初始化默认值
|
||||||
_historyLimit = 1000; // 默认限制1000条记录
|
_historyLimit = 50; // 默认限制1000条记录
|
||||||
_startTime = null;
|
_startTime = null;
|
||||||
_endTime = null;
|
_endTime = null;
|
||||||
|
|
||||||
// 初始化图表属性
|
// 初始化图表属性
|
||||||
LineAxisX = new AxesCollection { new Axis() };
|
LineAxisX = new Axis[] { new Axis() };
|
||||||
LineAxisY = new AxesCollection { new Axis() };
|
LineAxisY = new Axis[] { new Axis() };
|
||||||
LineSeriesCollection = new SeriesCollection();
|
LineSeriesCollection = new ISeries[0];
|
||||||
|
|
||||||
_eventService.OnVariableValueChanged += OnVariableValueChanged;
|
_eventService.OnVariableValueChanged += OnVariableValueChanged;
|
||||||
}
|
}
|
||||||
@@ -116,6 +120,8 @@ partial class VariableHistoryViewModel : ViewModelBase, INavigatable
|
|||||||
};
|
};
|
||||||
_variableHistoryList.Add(variableHistory);
|
_variableHistoryList.Add(variableHistory);
|
||||||
|
|
||||||
|
// 更新图表数据
|
||||||
|
UpdateChartData();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -229,13 +235,13 @@ partial class VariableHistoryViewModel : ViewModelBase, INavigatable
|
|||||||
if (_variableHistoryList == null || _variableHistoryList.Count == 0)
|
if (_variableHistoryList == null || _variableHistoryList.Count == 0)
|
||||||
{
|
{
|
||||||
// 清空图表数据
|
// 清空图表数据
|
||||||
LineSeriesCollection?.Clear();
|
LineSeriesCollection = new ISeries[0];
|
||||||
OnPropertyChanged(nameof(LineSeriesCollection));
|
OnPropertyChanged(nameof(LineSeriesCollection));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 创建数值点集合
|
// 创建数值点集合
|
||||||
var values = new ChartValues<DateTimePoint>();
|
var values = new List<DateTimePoint>();
|
||||||
|
|
||||||
foreach (var history in _variableHistoryList)
|
foreach (var history in _variableHistoryList)
|
||||||
{
|
{
|
||||||
@@ -246,40 +252,35 @@ partial class VariableHistoryViewModel : ViewModelBase, INavigatable
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 确保LineSeriesCollection已初始化
|
// 创建线性序列
|
||||||
if (LineSeriesCollection == null)
|
var series = new LineSeries<DateTimePoint>
|
||||||
{
|
{
|
||||||
LineSeriesCollection = new SeriesCollection();
|
Name = "变量值",
|
||||||
}
|
|
||||||
|
|
||||||
// 清空旧数据并添加新系列
|
|
||||||
LineSeriesCollection.Clear();
|
|
||||||
LineSeriesCollection.Add(new LineSeries
|
|
||||||
{
|
|
||||||
Title = "变量值",
|
|
||||||
Values = values,
|
Values = values,
|
||||||
PointGeometry = null, // 不显示数据点,只显示线条
|
Fill = null,
|
||||||
LineSmoothness = 0.5, // 设置线条平滑度
|
Stroke = new SolidColorPaint(new SKColor(41, 128, 185)) { StrokeThickness = 2 },
|
||||||
StrokeThickness = 2
|
GeometrySize = 0 // 不显示数据点,只显示线条
|
||||||
});
|
};
|
||||||
|
|
||||||
// 确保坐标轴集合已初始化
|
// 更新序列集合
|
||||||
if (LineAxisX == null || LineAxisX.Count == 0)
|
LineSeriesCollection = new ISeries[] { series };
|
||||||
|
|
||||||
|
// 更新坐标轴
|
||||||
|
LineAxisX = new Axis[]
|
||||||
{
|
{
|
||||||
LineAxisX = new AxesCollection { new Axis() };
|
new Axis
|
||||||
}
|
|
||||||
if (LineAxisY == null || LineAxisY.Count == 0)
|
|
||||||
{
|
{
|
||||||
LineAxisY = new AxesCollection { new Axis() };
|
Labeler = value => new DateTime((long)value).ToString("MM-dd HH:mm:ss")
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// 设置坐标轴
|
LineAxisY = new Axis[]
|
||||||
// X轴使用时间格式化
|
{
|
||||||
LineAxisX[0].LabelFormatter = value => new DateTime((long)value).ToString("MM-dd HH:mm:ss");
|
new Axis
|
||||||
|
{
|
||||||
// Y轴使用数值格式化
|
Name = "值"
|
||||||
LineAxisY[0].Title = "值";
|
}
|
||||||
LineAxisY[0].LabelFormatter = value => value.ToString("F2");
|
};
|
||||||
|
|
||||||
// 通知属性更改
|
// 通知属性更改
|
||||||
OnPropertyChanged(nameof(LineSeriesCollection));
|
OnPropertyChanged(nameof(LineSeriesCollection));
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
xmlns:valueConverts="clr-namespace:DMS.WPF.ValueConverts"
|
xmlns:valueConverts="clr-namespace:DMS.WPF.ValueConverts"
|
||||||
xmlns:vm="clr-namespace:DMS.WPF.ViewModels"
|
xmlns:vm="clr-namespace:DMS.WPF.ViewModels"
|
||||||
xmlns:converters="clr-namespace:DMS.WPF.Converters"
|
xmlns:converters="clr-namespace:DMS.WPF.Converters"
|
||||||
xmlns:lvc="clr-namespace:LiveCharts.Wpf;assembly=LiveCharts.Wpf"
|
xmlns:lvc="clr-namespace:LiveChartsCore.SkiaSharpView.WPF;assembly=LiveChartsCore.SkiaSharpView.WPF"
|
||||||
d:DataContext="{d:DesignInstance vm:VariableHistoryViewModel}"
|
d:DataContext="{d:DesignInstance vm:VariableHistoryViewModel}"
|
||||||
d:DesignHeight="600"
|
d:DesignHeight="600"
|
||||||
d:DesignWidth="800"
|
d:DesignWidth="800"
|
||||||
@@ -106,8 +106,11 @@
|
|||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
<!-- 变量历史记录列表和图表 -->
|
<!-- 变量历史记录列表和图表 -->
|
||||||
<hc:TabControl Margin="20">
|
<TabControl Margin="20">
|
||||||
<hc:TabItem Header="数据表格">
|
<TabItem Header="数据表格">
|
||||||
|
<ui:TabItemHelper.Icon>
|
||||||
|
<ui:FontIcon Icon="{x:Static ui:SegoeFluentIcons.Settings}"/>
|
||||||
|
</ui:TabItemHelper.Icon>
|
||||||
<DataGrid
|
<DataGrid
|
||||||
AutoGenerateColumns="False"
|
AutoGenerateColumns="False"
|
||||||
CanUserDeleteRows="False"
|
CanUserDeleteRows="False"
|
||||||
@@ -124,13 +127,16 @@
|
|||||||
IsReadOnly="True" />
|
IsReadOnly="True" />
|
||||||
</DataGrid.Columns>
|
</DataGrid.Columns>
|
||||||
</DataGrid>
|
</DataGrid>
|
||||||
</hc:TabItem>
|
</TabItem>
|
||||||
<hc:TabItem Header="数据图表">
|
<TabItem Header="数据图表">
|
||||||
<lvc:CartesianChart Series="{Binding LineSeriesCollection}"
|
<ui:TabItemHelper.Icon>
|
||||||
AxisX="{Binding LineAxisX}"
|
<ui:FontIcon Icon="{x:Static ui:SegoeFluentIcons.Settings}"/>
|
||||||
AxisY="{Binding LineAxisY}"
|
</ui:TabItemHelper.Icon>
|
||||||
|
<lvc:CartesianChart ZoomMode="X" Series="{Binding LineSeriesCollection}"
|
||||||
|
XAxes="{Binding LineAxisX}"
|
||||||
|
YAxes="{Binding LineAxisY}"
|
||||||
Margin="10"/>
|
Margin="10"/>
|
||||||
</hc:TabItem>
|
</TabItem>
|
||||||
</hc:TabControl>
|
</TabControl>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
</UserControl>
|
</UserControl>
|
||||||
Reference in New Issue
Block a user