C# Chart 不间断补充

  • 基础
    • [步骤 1: 添加引用](#步骤 1: 添加引用)
    • [步骤 2: 创建图表控件](#步骤 2: 创建图表控件)
    • [步骤 3: 配置图表](#步骤 3: 配置图表)
    • [步骤 4: 添加数据系列](#步骤 4: 添加数据系列)
    • [步骤 5: 显示图表](#步骤 5: 显示图表)
    • 一个简单的示例
    • 注意事项
  • 个人学习
    • 首先
    • 其次
    • 目前用到的
      • [判断某个 `Series` 是否存在](#判断某个 Series 是否存在)
      • [设置某个 `ChartAreas` 的XY轴坐标的范围](#设置某个 ChartAreas 的XY轴坐标的范围)

基础

C# 中使用图表通常涉及到以下几个步骤。这里以 Windows Forms 应用程序为例,使用 System.Windows.Forms.DataVisualization.Charting 命名空间来创建图表。

步骤 1: 添加引用

首先,确保你的项目中已经添加了 System.Windows.Forms.DataVisualization 的引用。这通常可以通过 NuGet 包管理器来完成。

步骤 2: 创建图表控件

在你的窗体上添加一个 Chart 控件。你可以在设计视图中拖拽,或者在代码中创建。

步骤 3: 配置图表

配置图表的基本属性,如标题、图例、轴标签等。

步骤 4: 添加数据系列

创建数据系列,并将数据绑定到图表上。

步骤 5: 显示图表

运行应用程序,查看图表的显示效果。

一个简单的示例

展示如何在 Windows Forms 应用程序中创建一个基本的折线图:

csharp 复制代码
using System;
using System.Windows.Forms;
using System.Windows.Forms.DataVisualization.Charting;

public class ChartDemoForm : Form
{
    private Chart chart1;

    public ChartDemoForm()
    {
        // 初始化组件
        InitializeComponent();

        // 初始化图表控件
        chart1 = new Chart();
        chart1.Dock = DockStyle.Fill;
        this.Controls.Add(chart1);

        // 设置图表标题
        chart1.Titles.Add("Sample Chart");

        // 创建图表区域
        ChartArea chartArea = new ChartArea("ChartArea1");
        chart1.ChartAreas.Add(chartArea);

        // 创建数据系列
        Series series = new Series("Series1");
        series.ChartType = SeriesChartType.Line; // 设置为折线图
        series.Points.DataBindY(new double[] { 1, 2, 3, 4, 5 }); // 绑定数据

        // 将数据系列添加到图表中
        chart1.Series.Add(series);
    }

    [STAThread]
    static void Main()
    {
        Application.EnableVisualStyles();
        Application.SetCompatibleTextRenderingDefault(false);
        Application.Run(new ChartDemoForm());
    }

    private void InitializeComponent()
    {
        // 这里可以添加窗体的初始化代码
    }
}

注意事项

  • 在实际应用中,你可能需要从数据库、文件或其他数据源动态加载数据。
  • 你可能需要添加更多的自定义设置,如轴的范围、网格线、颜色、图例位置等。
  • 如果你使用的是 ASP.NET 或其他类型的应用程序,使用的方法和库可能会有所不同。
  • 如果你有特定的使用场景或需要进一步的帮助,请提供更多的信息。

个人学习

首先

要知道ChartAreasSeries 的关系

  • 一个 Chart 可以有多个图表区( ChartAreas
  • 一个 ChartAreas 可以有多个图表序列( Series
  • 一个 Series 就是你要显示的某一条线
  • 我们为 Chart 添加 Series ,然后为添加的 Series 设定 ChartAreas

如下代码所示

csharp 复制代码
chart.ChartAreas.Clear();
chart.Series.Clear();
chart.ChartAreas.Add("Name");
chart.ChartAreas["Name"].Visible = true;
csharp 复制代码
// 创建一个图标序列,并设置其显示为曲线
var series = new Series(name) { ChartType = SeriesChartType.Spline };

其次

要有一个观念

Chart 是一个图,我们通过不断创建新的图去覆盖老图达到动态效果

csharp 复制代码
Task.Run(async () => {
	while(flag) {
		await Task.Delay(20); //每20ms更新一下
		//DoSomething
		
	}
});

上述代码为异步更新 Chart,个人不想使用 Timer

csharp 复制代码
series.Points.Clear();
series.Points.AddXY(ListX, ListY);
chart.Invalidate(); 

上述代码为先清空某个 Series 的所有点,然后重新写点,然后更新整个 Chart

目前用到的

判断某个 Series 是否存在

csharp 复制代码
!chart.Series.Any(s => s.Name == Name)

设置某个 ChartAreas 的XY轴坐标的范围

csharp 复制代码
double range = maxValue - minValue;
chart.ChartAreas[series.Name].AxisY.Minimum = minValue - (range * 0.5) - 0.01;
chart.ChartAreas[series.Name].AxisY.Maximum = maxValue + (range * 0.5) + 0.01;

上述代码为 Y 值的。

通过数据动态算出 maxValue minValue 然后修改 Axis@Minimum Maximum 属性(通过 range 增加上下余量)使得图像一直在中间

相关推荐
_小柏_15 分钟前
C/C++基础知识复习(46)
c语言·开发语言·c++
SomeB1oody20 分钟前
【Rust自学】6.4. 简单的控制流-if let
开发语言·前端·rust
明月逐人归46420 分钟前
输出语句及变量定义
开发语言·python
tatasix40 分钟前
Go Redis实现排行榜
开发语言·redis·golang
吴冰_hogan43 分钟前
Java虚拟机(JVM)的类加载器与双亲委派机制
java·开发语言·jvm
菜鸟xiaowang1 小时前
Android.bp java_library_static srcs配置
开发语言·python
怎么就重名了1 小时前
MAC M4安装QT使用国内镜像源在线安装
开发语言·qt
Evand J1 小时前
一维、线性卡尔曼滤波的例程(MATLAB)
开发语言·matlab
pl00201 小时前
C++运算符重载实例
开发语言·c++·运算符重载·单目运算符·双目运算符·流运算符
煤泥做不到的!1 小时前
挑战一个月基本掌握C++(第十二天)了解命名空间,模板,预处理器
开发语言·c++