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

3.2 WPF 画散点图

1. 前端xaml代码

        前端代码如下:

<Window x:Class="scatters.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:scatters"mc:Ignorable="d"xmlns:lvc="clr-namespace:LiveCharts.Wpf;assembly=LiveCharts.Wpf"Title="MainWindow" Height="900" Width="1200" WindowStartupLocation="CenterScreen"><Grid><Grid.RowDefinitions><RowDefinition Height="Auto"></RowDefinition><RowDefinition Height="*"></RowDefinition></Grid.RowDefinitions><Button Grid.Row="0" Margin="10" Click="RandomizeOnClick">Randomize</Button><lvc:CartesianChart Grid.Row="1" LegendLocation="Bottom"><lvc:CartesianChart.Series><lvc:ScatterSeries Title="Series A" Values="{Binding ValuesA}"/><lvc:ScatterSeries Title="Series B" Values="{Binding ValuesB}"PointGeometry="{x:Static lvc:DefaultGeometries.Diamond}"/><lvc:ScatterSeries Title="Series C" Values="{Binding ValuesC}"PointGeometry="{x:Static lvc:DefaultGeometries.Triangle}"StrokeThickness="2" Fill="Transparent"/></lvc:CartesianChart.Series><lvc:CartesianChart.AxisY><!--setting the axis unit improved the labels rounding rule--><lvc:Axis Unit="1"></lvc:Axis></lvc:CartesianChart.AxisY></lvc:CartesianChart></Grid>
</Window>

        以上代码中,<Grid>上面的代码是自己生成的,里面有一行是我们加入的,这一行是:

xmlns:lvc="clr-namespace:LiveCharts.Wpf;assembly=LiveCharts.Wpf"

        <Grid> ...</Grid>之间的所有代码复制到里面就行。

2.后端cs文件代码

        在cs文件中的代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using LiveCharts;
using LiveCharts.Defaults;
using LiveCharts.Wpf;
using static System.Net.WebRequestMethods;namespace scatters
{/// <summary>/// MainWindow.xaml 的交互逻辑/// </summary>public partial class MainWindow : Window{public MainWindow(){InitializeComponent();var r = new Random();ValuesA = new ChartValues<ObservablePoint>();ValuesB = new ChartValues<ObservablePoint>();ValuesC = new ChartValues<ObservablePoint>();for (var i = 0; i < 20; i++){ValuesA.Add(new ObservablePoint(r.NextDouble() * 10, r.NextDouble() * 10));ValuesB.Add(new ObservablePoint(r.NextDouble() * 10, r.NextDouble() * 10));ValuesC.Add(new ObservablePoint(r.NextDouble() * 10, r.NextDouble() * 10));}DataContext = this;}public ChartValues<ObservablePoint> ValuesA { get; set; }public ChartValues<ObservablePoint> ValuesB { get; set; }public ChartValues<ObservablePoint> ValuesC { get; set; }private void RandomizeOnClick(object sender, RoutedEventArgs e){var r = new Random();for (var i = 0; i < 20; i++){//ValuesA[i].X = r.NextDouble() * 10;ValuesA[i].X = i;ValuesA[i].Y = r.NextDouble() + 4;//ValuesB[i].X = r.NextDouble() * 10;ValuesB[i].X = i;ValuesB[i].Y = r.NextDouble() + 7;//ValuesC[i].X = r.NextDouble() * 10;ValuesC[i].X = i;ValuesC[i].Y = r.NextDouble() + 10;}}}
}

        在以上代码中,头文件有LiveCharts,这个我们需要进入 工具--->NuNet 包管理器--->管理解决方案,进入后搜索LiveCharts,然后点击安装即可。

3.最终效果

        最后运行代码,运行结果如下:

http://www.lryc.cn/news/587918.html

相关文章:

  • 【Python3教程】Python3高级篇之MySQL - mysql-connector 驱动介绍及示例
  • 【WPF】WPF 自定义控件 实战详解,含命令实现
  • 深地之下的智慧触角:Deepoc具身智能如何为矿业机器人铸就“感知之核”
  • Mac (m1) Java 加载本地C共享库函数 .dylib 函数 Unable to load library ‘liblicense‘
  • 【爬虫】Python实现爬取京东商品信息(超详细)
  • 来时路,零帧起手到Oracle大师
  • FilterRegistationBean报错does not have type parameters。idea启动日志无明显报错提示冲突 kaki的博客
  • IDEA实现纯java项目并打包jar(不使用Maven,Spring)
  • Linux的相关学习
  • Oracle物化视图函数使用注意事项
  • Oracle 递归函数及 其他数据库 CTE 使用小计
  • SpringBoot集成SAP,本地IDEA启动和Windows服务器部署
  • 企业培训笔记:axios 发送 ajax 请求
  • iOS高级开发工程师面试——RunLoop
  • [Nagios Core] struct监控对象 | 配置.cfg加载为内存模型
  • CSS `:root` 伪类深入讲解
  • Reactor 模式详解
  • spring shell 基础使用
  • Transformer江湖录 第五章:江湖争锋 - BERT vs GPT
  • 20250714让荣品RD-RK3588开发板在Android13下长按关机
  • Bash常见条件语句和循环语句
  • vLLM与SGLang在自然语言处理领域的技术架构与性能对比研究
  • 从数据库到播放器:Java视频续播功能完整实现解析
  • cuda优化之softmax
  • 调用 System.runFinalizersOnExit() 的风险与解决方法
  • JavaScript 与 C语言基础知识差别
  • Spark 单机模式安装与测试全攻略​
  • 【HTML】五子棋(精美版)
  • 数据采集卡选型——PCIE和USB型采集卡对比
  • C++类模版与友元