一、目的:基于WPF的DrawingVisual开发的Chart图表和表格绘制
二、预览
钻井井轨迹表格数据演示示例(应用Table布局,模拟井轨迹深度的绘制)
data:image/s3,"s3://crabby-images/bee57/bee57640a56b4d34e2d91c6e1084e322e15384cb" alt=""
饼图表格数据演示示例(应用Table布局,模拟多个饼状图组合显示)
data:image/s3,"s3://crabby-images/883ce/883ce22a88b31387a6f4cf3041d11ed7955d9cd8" alt=""
柱状图表格数据演示示例(应用Table布局,模拟多个柱状图组合显示)
data:image/s3,"s3://crabby-images/49cc4/49cc4a76bc746d7ae19d053aef5584ea2753f054" alt=""
折线图表格数据演示示例(应用Table布局,模拟曲线图数据显示)
data:image/s3,"s3://crabby-images/1ebc3/1ebc32c4f68704dd9411396262761133583047a8" alt=""
组合图表格数据演示示例 (应用Table布局,模拟散点、气泡图、折线图和柱状图显示)
data:image/s3,"s3://crabby-images/765b5/765b5599a37855177052b9908633c8c81de5d28b" alt=""
三、环境
VS2022,NET7
四、主要功能
折线图(支持显示文本,显示点等设置)
data:image/s3,"s3://crabby-images/696a5/696a5581b6658b8169d8b0ac6b2035ccd3f52fd3" alt=""
按聚类显示 (支持横坐标按分类显示)
data:image/s3,"s3://crabby-images/28efc/28efc752fcd6aeac850560b775a82db6683cd0b3" alt=""
按日期显示(支持横坐标或纵坐标按日期数据显示)
data:image/s3,"s3://crabby-images/c85b1/c85b18bbe4d4120d4e378d0002dd986e018f9fb5" alt=""
显示面积(支持折线图显示面积)data:image/s3,"s3://crabby-images/5ea78/5ea78983b2160a461fde60cd1cdc70e118cfeb08" alt=""
散点图
data:image/s3,"s3://crabby-images/73fa3/73fa3e44367a0d671150d6a244b6ed4a9ec535e9" alt=""
气泡图
data:image/s3,"s3://crabby-images/2262c/2262c0d4446fdf4cd49e09a60fdd34fd507fd9b0" alt=""
多轴显示效果
data:image/s3,"s3://crabby-images/d2509/d2509bd7808f6282746672ba8abf1cd2af0975ed" alt=""
柱状图(支持显示文本,显示点,显示折线等设置)
data:image/s3,"s3://crabby-images/334a7/334a7dbf75cbba635935903b1872f85d1a18487c" alt=""
data:image/s3,"s3://crabby-images/c955d/c955db5b571fb962498263f9fe17e6b15ed06f18" alt=""
饼状图
data:image/s3,"s3://crabby-images/51432/5143210cea6699660d3b890f9d5568086f6795ed" alt=""
环形图样式
玫瑰图样式
data:image/s3,"s3://crabby-images/e6cf9/e6cf9c277f209d99ed18f0e3008f345bd30ae28e" alt=""
选中位移效果
data:image/s3,"s3://crabby-images/34d2c/34d2c4684a9fa6aaddc80864fa4e2acbe05de5c3" alt=""
雷达图
data:image/s3,"s3://crabby-images/af5a8/af5a8e1ae894b6f22a27f174a0efde8724ccfbae" alt=""
极坐标图
折线数据示例
data:image/s3,"s3://crabby-images/48d38/48d385dbd7c896a6bce8d88be0caafef26dbc2d5" alt=""
散点数据示例
data:image/s3,"s3://crabby-images/2a0ee/2a0ee8a722e7e04ed681025a2474503351a9beed" alt=""
气泡数据示例
data:image/s3,"s3://crabby-images/ba5c9/ba5c9815a703a6923d9b4ad108e61eba06ed1cbd" alt=""
仪表盘
data:image/s3,"s3://crabby-images/e72cb/e72cbcbb8dc324869d9524a8664c50d11a2dde1c" alt=""
热力图
data:image/s3,"s3://crabby-images/75bfb/75bfb38adb9218fe7e3d399c3dd8a98664a8253a" alt=""
网格热力图
data:image/s3,"s3://crabby-images/ce8af/ce8af13f8c1f7cd79a22d0d93cb5997915c4bbdd" alt=""
组合饼状图
组合曲线图
data:image/s3,"s3://crabby-images/bf8c6/bf8c6d8e8a673b67585c6abf44284dc9b6440c3f" alt=""
组合组合图
data:image/s3,"s3://crabby-images/adad7/adad7c0cd87cf4707d6badc25dc95dbf35d34aad" alt=""
组合热力曲线
data:image/s3,"s3://crabby-images/28652/286528d8fcaef876c29c1bbdc5e0da4d06c2752a" alt=""
标记线(最大值,最小值,平均值,按X轴显示,按Y轴显示等)
data:image/s3,"s3://crabby-images/1cc8b/1cc8b91516fd7dc304848cb645da09d0729f73ba" alt=""
标记点(最大值,最小值等)
data:image/s3,"s3://crabby-images/ec51c/ec51c17a24a5c9e2ef4fc4feb2c007090a61164d" alt=""
多坐标轴(按坐标轴停靠方向自动布局)
data:image/s3,"s3://crabby-images/6b6ba/6b6ba423903119dde047bf417bdf20b7b6fe0dea" alt=""
指数坐标轴
data:image/s3,"s3://crabby-images/0eef3/0eef343d22c87a487ef2f029db5a23faae212ba5" alt=""
自定义坐标轴位置(设置停靠方向或自定义偏移值)
自定义偏移值效果
data:image/s3,"s3://crabby-images/bec93/bec932867c3c59475ec7afc1a750b8e9591d8b30" alt=""
停靠居中效果
data:image/s3,"s3://crabby-images/00cea/00cea2e7c804c574a5c5d198d833ea37b4b0e9f8" alt=""
网格线(根据XY坐标轴自动绘制,可以自定义蒙版显示)
data:image/s3,"s3://crabby-images/70888/70888bc7ba71ec43123ab3faf7052373dfe35754" alt=""
悬停提示(支持显示当前鼠标横纵参考线,坐标轴当前值,Tooltip提示显示当前值)
data:image/s3,"s3://crabby-images/ef6c5/ef6c5f6158dbd60c38e30391688a815069af2fbb" alt=""
图例控制(勾选显示隐藏绘图元素)
直角坐标系效果
data:image/s3,"s3://crabby-images/4d441/4d4415cb0b225b69f29660a10277743f030812d3" alt=""
饼状图效果
data:image/s3,"s3://crabby-images/56cb4/56cb4a87d33bfa50db041fcb6245dc172a2e1cd0" alt=""
雷达图效果
data:image/s3,"s3://crabby-images/cbd64/cbd64034a7b28bbd865f9fbce1a74bc4a246c799" alt=""
极坐标图效果
data:image/s3,"s3://crabby-images/a8e5d/a8e5dd8dea07e77f215eff77ff0eacbfce9d1e2e" alt=""
管道图(显示折线为轨道样式,支持模拟流体滚动效果和流速)
data:image/s3,"s3://crabby-images/21bf0/21bf0ba3bea5f1eda7e53f2e51b317d5395b785f" alt=""
模拟钻井流体和流速
data:image/s3,"s3://crabby-images/b0433/b043352ff3d9c33e8cba5704844c1e4075912c2a" alt=""
平移缩放等操作
表格组合(可以通过布局Table来放置Chart图表)
data:image/s3,"s3://crabby-images/c7ada/c7adadbae61aefa04a6bd84d36c47c171c1fb35b" alt=""
data:image/s3,"s3://crabby-images/e2c37/e2c371495fe52be03a0db328e30e65a417e0913b" alt=""
支持Linq To Chart模式(通过表达式树Expression<Func<T, Point>> selector的方式快速生成图表)
data:image/s3,"s3://crabby-images/3b64e/3b64e9a0124d582ae2f878909007d0e737a71ecb" alt=""
cs
var students = Student.Randoms(100);
var groupAge = students.GroupBy(x => x.Age).OrderBy(x => x.Key);
{
var shape = groupAge.Create(x => new Point(x.Key, x.Sum(l => l.Score)));
shape.Name = $"{shape.Name}-曲线图";
this.Shapes.Add(shape);
}
{
var shape = groupAge.Create(x =>
{
x.UseText = false;
},
x => new Point(x.Key, x.Count()),
x => new Point(x.Key, x.Sum(l => l.Score)),
x => new Point(x.Key, x.Key));
shape.Name = $"{shape.Name}-多轴曲线图";
this.Shapes.Add(shape);
}
{
var shape = groupAge.CreateWithOnexAxis(x => x.UseText = false,
x => x.Key,
x => x.Sum(l => l.Score),
x => x.Count());
shape.Name = $"{shape.Name}-单X轴曲线图";
this.Shapes.Add(shape);
}
var groupName = students.GroupBy(x => x.Name);
{
var shape = groupName.Create(x => new ValueCategory(x.Key, x.Sum(l => l.Age)), s =>
{
s.UseLine = false;
s.UseText = true;
s.UseBar = true;
});
shape.Name = $"{shape.Name}-分组曲线图";
this.Shapes.Add(shape);
}
{
var shape = groupName.Create(s =>
{
s.UseLine = true;
s.UseText = true;
s.UseBar = false;
},
x => new ValueCategory(x.Key, x.Count()),
x => new ValueCategory(x.Key, x.Sum(l => l.Age)));
shape.Name = $"{shape.Name}-多轴分组曲线图";
this.Shapes.Add(shape);
}
{
var shape = groupName.CreatePie(x => new PieCategory()
{
Name = x.Key,
Value = x.Max(l => l.Score)
});
shape.Name = $"{shape.Name}";
this.Shapes.Add(shape);
}
{
var shape = groupName.CreatePie(x => new PieCategory()
{
Name = x.Key,
Value = x.Sum(l => l.Score)
}, x =>
{
x.RingRadius = 0.6;
});
shape.Name = $"{shape.Name}-环形图";
this.Shapes.Add(shape);
}
{
var shape = groupName.CreatePie(x => new PieCategory()
{
Name = x.Key,
Value = x.Count()
}, x =>
{
x.RingRadius = 0.2;
x.RoseType = RoseType.Radius;
});
shape.Name = $"{shape.Name}-玫瑰图";
this.Shapes.Add(shape);
}
{
var shape = groupAge.CreatePolor(x =>
{
x.UseText = false;
},
12.CreateDoubles(0, groupAge.Max(l => l.Key)),
x => new Point(x.Key, x.Sum(l => l.Score)),
x => new Point(x.Key, x.Sum(l => l.Age)));
shape.Name = $"{shape.Name}-极坐标图";
this.Shapes.Add(shape);
}
{
var shape = groupName.CreateRadar(s =>
{
s.UseLine = true;
s.UseText = true;
s.UseArea = true;
},
x => new ValueCategory(x.Key, x.Count()),
x => new ValueCategory(x.Key, x.Min(l => l.Age)));
shape.Name = $"{shape.Name}-雷达图";
this.Shapes.Add(shape);
}
{
var shape = students.ToList().OrderBy(x => x.Class).CreateHeat(x => new xyCategoryValue()
{
X = new Category(x.Name),
Y = new Category(x.Class),
Value = 1.0
//Value = x.Score
});
shape.Name = $"{shape.Name}-热力图";
this.Shapes.Add(shape);
}
{
var shape = groupAge.CreateBubbleWithOnexAxis(x => x.UseText = false,
x => x.Key,
x => new ValuePoint2D(Random.Shared.Next(groupAge.Min(l => l.Key), groupAge.Max(l => l.Key)),
Random.Shared.NextDouble() * x.Count(),
x.Sum(l => l.Score)),
x => new ValuePoint2D(Random.Shared.Next(groupAge.Min(l => l.Key), groupAge.Max(l => l.Key)),
Random.Shared.NextDouble() * x.Count(),
x.Min(l => l.Score)),
x => new ValuePoint2D(Random.Shared.Next(groupAge.Min(l => l.Key), groupAge.Max(l => l.Key)),
Random.Shared.NextDouble() * x.Count(),
x.Max(l => l.Score)),
x => new ValuePoint2D(x.Key,
x.Count(),
x.Average(l => l.Score)));
shape.Name = $"{shape.Name}-单X轴气泡图";
this.Shapes.Add(shape);
}
五、演示视频
【WPF-Chart2D】基于DrawingVisual的图表和表格绘图_哔哩哔哩_bilibili
需要了解的知识点
System.Windows.Controls 命名空间 | Microsoft Learn
控件库 - WPF .NET Framework | Microsoft Learn
XAML概述 - WPF .NET | Microsoft Learn
Windows Presentation Foundation 简介 - WPF .NET | Microsoft Learn
使用 Visual Studio 创建新应用教程 - WPF .NET | Microsoft Learn
了解更多
适用于 .NET 8 的 WPF 的新增功能 - WPF .NET | Microsoft Learn
适用于 .NET 7 的 WPF 的新增功能 - WPF .NET | Microsoft Learn
System.Windows.Controls 命名空间 | Microsoft Learn
Sysinternals - Sysinternals | Microsoft Learn
Windows app development documentation - Windows apps | Microsoft Learn
欢迎使用 Expression Blend | Microsoft Learn
https://learn.microsoft.com/zh-cn/dotnet/desktop/wpf/?view=netdesktop-7.0&WT.mc_id=MVP_380318